Mercurial > pub > dyncall > dyncall
annotate dyncallback/dyncall_callback_mips_o32_gas.s @ 103:b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
author | cslag |
---|---|
date | Wed, 08 Jun 2016 02:27:12 +0200 |
parents | b7a9b524f0c3 |
children | dbca6763f2be |
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 |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
40 /* Called by thunk - thunk stores pointer to DCCallback in $12 ($t4), and pointer to called function in $25 ($t9, required for PIC) */ |
94 | 41 dcCallbackThunkEntry: |
102
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
42 .set noreorder |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
43 .set nomacro |
94 | 44 |
102
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
45 /* Prolog. Just store the minimum, return address, frame pointer, spill area. */ |
103
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
46 subu $sp, 32 /* open frame: 32b for 8b aligned frame (retval+ra+fp+spill) */ |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
47 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
|
48 |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
49 .frame $fp,32,$31 /* specify our frame: fp,size,lr; creates virt $fp */ |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
50 |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
51 /* Init return value */ |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
52 sw $zero, 24($sp) |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
53 sw $zero, 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
|
54 |
103
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
55 /* If we spill the first four, all arguments will be in one out in consecutive block */ |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
56 /* Caller doesn't and it's up to us to spill, so let's write $4-$7 ($a0-$a3) to the */ |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
57 /* dedicated spill area, first (at end of _caller's_ frame, so $fp points right to it). */ |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
58 sw $7, 12($fp) |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
59 sw $6, 8($fp) |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
60 sw $5, 4($fp) |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
61 sw $4, 0($fp) |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
62 |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
63 /* Init DCArg, which contains stackptr* to the args, which is $fp. Use padding between */ |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
64 /* stored return address and parameter area as place to store it (hacky, but saves 8b) */ |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
65 sw $fp, 16($sp) |
102
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
66 |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
67 /* Prepare callback handler call. */ |
103
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
68 move $4, $12 /* Param 0 = DCCallback*, $12 ($t4) holds pointer to thunk */ |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
69 addiu $5, $sp, 16 /* Param 1 = DCArgs*, pointer to where pointer to args is stored */ |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
70 addiu $6, $sp, 24 /* Param 2 = results pointer to 8b of local data on stack */ |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
71 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
|
72 |
103
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
73 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
|
74 jalr $25 /* jump */ |
102
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
75 nop |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
76 |
103
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
77 /* Copy result in corresponding registers $2-$3 ($v0-$v1) */ |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
78 lw $2, 24($sp) |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
79 lw $3, 28($sp) |
b15d814ba274
- mostly functional mips o32 callbacks (seems to still have problems with 64bit params)
cslag
parents:
102
diff
changeset
|
80 |
102
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
81 /* 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
|
82 lw $ra, 20($sp) /* restore return address */ |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
83 addiu $sp, $sp, 32 /* close frame */ |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
84 j $ra /* return */ |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
85 nop |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
86 |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
87 .set macro |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
88 .set reorder |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
89 .end dcCallbackThunkEntry |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
90 .ident "handwritten" |
b7a9b524f0c3
- mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents:
94
diff
changeset
|
91 |