annotate dyncall/dyncall_call_mips_o32_gas.s @ 0:3e629dc19168

initial from svn dyncall-1745
author Daniel Adler
date Thu, 19 Mar 2015 22:24:28 +0100
parents
children 1ce60358fbad
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
1 /*
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
2
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
3 Package: dyncall
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
4 Library: dyncall
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
5 File: dyncall/dyncall_call_mips_o32_gas.s
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
6 Description: mips "o32" abi call kernel implementation in GNU Assembler
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
7 License:
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
8
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
9 Copyright (c) 2007-2011 Daniel Adler <dadler@uni-goettingen.de>,
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
10 Tassilo Philipp <tphilipp@potion-studios.com>
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
11
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
12 Permission to use, copy, modify, and distribute this software for any
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
13 purpose with or without fee is hereby granted, provided that the above
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
14 copyright notice and this permission notice appear in all copies.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
15
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
16 THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
17 WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
18 MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
19 ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
20 WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
21 ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
22 OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
23
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
24 */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
25 /* $4 target function */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
26 /* $5 register data */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
27 /* $6 stack size (min 16-byte aligned to 8-bytes already) */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
28 /* $7 stack data */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
29
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
30
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
31
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
32 .section .mdebug.abi32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
33 .previous
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
34 .abicalls
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
35 .text
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
36 .align 2
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
37 .globl dcCall_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
38 .ent dcCall_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
39 .type dcCall_mips_o32, @function
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
40 dcCall_mips_o32:
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
41 .frame $fp,40,$31 /* vars=8, regs=2/0, args=16, gp=8 */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
42 .mask 0xc0000000,-4
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
43 .fmask 0x00000000,0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
44 .set noreorder
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
45 .set nomacro
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
46
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
47 addiu $sp,$sp,-8
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
48 sw $31,4($sp) /* save link register */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
49 sw $fp,0($sp) /* save frame pointer */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
50 nop
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
51 move $fp,$sp /* frame pointer = sp */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
52 sub $sp, $sp, $6 /* increment stack */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
53
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
54 /* copy stack data */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
55
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
56 /* $12 source pointer (parameter stack data) */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
57 /* $14 destination (stack pointer) */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
58 /* $6 byte count */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
59
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
60 move $12, $7
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
61 move $14, $sp
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
62
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
63 .next:
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
64 beq $6, $0, .skip
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
65 nop
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
66 lw $2, 0($12)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
67 nop
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
68 sw $2, 0($14)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
69 addiu $12,$12, 4
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
70 addiu $14,$14, 4
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
71 addiu $6, $6, -4
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
72 j .next
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
73 nop
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
74 .skip:
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
75
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
76 /* load two double-precision floating-point argument registers ($f12, $f14) */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
77
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
78 l.d $f12, 0($5)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
79 l.d $f14, 8($5)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
80 /* prepare call */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
81
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
82
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
83 move $12, $7 /* $12 stack data */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
84 move $25, $4 /* $25 target function */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
85
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
86 /* load first four integer arguments ($4-$7) */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
87
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
88 lw $4, 0($12)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
89 lw $5, 4($12)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
90 lw $6, 8($12)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
91 lw $7,12($12)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
92
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
93 /* call target function */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
94
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
95 jalr $25
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
96 nop
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
97 move $sp,$fp /* restore stack pointer */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
98 nop
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
99 lw $31,4($sp) /* restore return address */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
100 lw $fp,0($sp) /* restore frame pointer */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
101 addiu $sp,$sp,8 /* end stack frame */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
102 j $31 /* return */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
103 nop
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
104
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
105 .set macro
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
106 .set reorder
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
107 .end dcCall_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
108 .ident "handwritten"
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
109