Mercurial > pub > dyncall > dyncall
annotate dyncallback/dyncall_callback_mips_o32_gas.s @ 104:dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
* currently tested on little endian, only
* todo update, manual update, cleanups
author | cslag |
---|---|
date | Thu, 09 Jun 2016 15:13:53 +0200 |
parents | b15d814ba274 |
children | d595eb90efdd |
rev | line source |
---|---|
94 | 1 /* |
2 | |
3 Package: dyncall | |
4 Library: dyncallback | |
5 File: dyncallback/dyncall_callback_mips_o32_gas.s | |
102
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
6 Description: Callback Thunk - Implementation mips32 o32 |
94 | 7 License: |
8 | |
9 Copyright (c) 2016 Tassilo Philipp <tphilipp@potion-studios.com> | |
10 | |
11 Permission to use, copy, modify, and distribute this software for any | |
12 purpose with or without fee is hereby granted, provided that the above | |
13 copyright notice and this permission notice appear in all copies. | |
14 | |
15 THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | |
16 WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | |
17 MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | |
18 ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | |
19 WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | |
20 ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | |
21 OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | |
22 | |
23 */ | |
24 | |
102
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
25 /* input: |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
26 $t4 -> thunk |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
27 $t4+20 -> cb handler |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
28 $t4+24 -> userdata |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
29 */ |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
30 |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
31 .section .mdebug.abi32 |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
32 .previous |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
33 .abicalls |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
34 .text |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
35 .align 2 |
94 | 36 .globl dcCallbackThunkEntry |
102
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
37 .ent dcCallbackThunkEntry |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
38 .type dcCallbackThunkEntry, @function |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
39 |
104
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
40 /* Called by thunk - thunk stores pointer to DCCallback in $12 ($t4), and */ |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
41 /* pointer to called function in $25 ($t9, required for PIC) */ |
94 | 42 dcCallbackThunkEntry: |
102
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
43 .set noreorder |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
44 .set nomacro |
94 | 45 |
104
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
46 /* Prolog. Just store the minimum, return address, spill area. */ |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
47 /* Frame size of 48b comes from following areas (each 8b aligned); */ |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
48 /* local: fpregs:16 + retval:8 + DCArgs:8 */ |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
49 /* save: ra:4 (+ pad:4) */ |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
50 /* param: spill:16 */ |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
51 subu $sp, 56 /* open frame */ |
103
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
52 sw $ra, 20($sp) /* save link register */ |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
53 |
104
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
54 .frame $fp,56,$31 /* specify our frame: fp,size,lr; creates virt $fp */ |
103
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
55 |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
56 /* Init return value */ |
104
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
57 sw $zero, 32($sp) |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
58 sw $zero, 36($sp) |
102
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
59 |
104
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
60 /* Store the arguments passed via registers somewhere for dcArg* to access. */ |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
61 /* For $4-$7 ($a0-$a3), use dedicated spill area (caller doesn't spill, but */ |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
62 /* provides it at end of _caller's_ frame, so $fp points right to it). */ |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
63 /* For $f12 and $f14 use our space (in local data), which is adjacent. */ |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
64 s.d $f12, 40($sp) /* -16($fp) */ |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
65 s.d $f14, 48($sp) /* -8($fp) */ |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
66 sw $4, 0($fp) |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
67 sw $5, 4($fp) |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
68 sw $6, 8($fp) |
103
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
69 sw $7, 12($fp) |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
70 |
104
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
71 /* Init DCArg, which contains reg_count and stackptr* to the args. Point */ |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
72 /* stackptr to the area where the non-float args start (which is at $fp). */ |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
73 sw $zero, 24($sp) |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
74 sw $fp, 28($sp) |
102
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
75 |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
76 /* Prepare callback handler call. */ |
103
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
77 move $4, $12 /* Param 0 = DCCallback*, $12 ($t4) holds pointer to thunk */ |
104
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
78 addiu $5, $sp, 24 /* Param 1 = DCArgs*, pointer to where pointer to args is stored */ |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
79 addiu $6, $sp, 32 /* Param 2 = results pointer to 8b of local data on stack */ |
103
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
80 lw $7, 24($12) /* Param 3 = userdata pointer */ |
102
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
81 |
103
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
82 lw $25, 20($12) /* store handler entry in $25 ($t9), required for PIC */ |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
83 jalr $25 /* jump */ |
104
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
84 nop /* branch delay nop */ |
102
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
85 |
104
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
86 /* Copy result in corresponding registers $2-$3 ($v0-$v1) and $f0 */ |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
87 lw $2, 32($sp) |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
88 lw $3, 36($sp) |
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
89 l.d $f0, 32($sp) |
103
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
90 |
102
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
91 /* Epilog. Tear down frame and return. */ |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
92 lw $ra, 20($sp) /* restore return address */ |
104
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
93 addiu $sp, $sp, 56 /* close frame */ |
102
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
94 j $ra /* return */ |
104
dbca6763f2be
- complete, working mips o32 callback (using hardware fp); fixes error from last commit, which ignored first 2 float args
cslag
parents:
103
diff
changeset
|
95 nop /* branch delay nop */ |
102
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
96 |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
97 .set macro |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
98 .set reorder |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
99 .end dcCallbackThunkEntry |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
100 .ident "handwritten" |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
101 |