annotate libffi/src/m88k/obsd.S @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /*
kono
parents:
diff changeset
2 * Copyright (c) 2013 Miodrag Vallat. <miod@openbsd.org>
kono
parents:
diff changeset
3 *
kono
parents:
diff changeset
4 * Permission is hereby granted, free of charge, to any person obtaining
kono
parents:
diff changeset
5 * a copy of this software and associated documentation files (the
kono
parents:
diff changeset
6 * ``Software''), to deal in the Software without restriction, including
kono
parents:
diff changeset
7 * without limitation the rights to use, copy, modify, merge, publish,
kono
parents:
diff changeset
8 * distribute, sublicense, and/or sell copies of the Software, and to
kono
parents:
diff changeset
9 * permit persons to whom the Software is furnished to do so, subject to
kono
parents:
diff changeset
10 * the following conditions:
kono
parents:
diff changeset
11 *
kono
parents:
diff changeset
12 * The above copyright notice and this permission notice shall be included
kono
parents:
diff changeset
13 * in all copies or substantial portions of the Software.
kono
parents:
diff changeset
14 *
kono
parents:
diff changeset
15 * THE SOFTWARE IS PROVIDED ``AS IS'', WITHOUT WARRANTY OF ANY KIND,
kono
parents:
diff changeset
16 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
kono
parents:
diff changeset
17 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
kono
parents:
diff changeset
18 * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
kono
parents:
diff changeset
19 * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
kono
parents:
diff changeset
20 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
kono
parents:
diff changeset
21 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
kono
parents:
diff changeset
22 */
kono
parents:
diff changeset
23
kono
parents:
diff changeset
24 /*
kono
parents:
diff changeset
25 * m88k Foreign Function Interface
kono
parents:
diff changeset
26 */
kono
parents:
diff changeset
27
kono
parents:
diff changeset
28 #define LIBFFI_ASM
kono
parents:
diff changeset
29 #include <fficonfig.h>
kono
parents:
diff changeset
30 #include <ffi.h>
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 .text
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 /*
kono
parents:
diff changeset
35 * ffi_cacheflush_OBSD(unsigned int addr, %r2
kono
parents:
diff changeset
36 * unsigned int size); %r3
kono
parents:
diff changeset
37 */
kono
parents:
diff changeset
38 .align 4
kono
parents:
diff changeset
39 .globl ffi_cacheflush_OBSD
kono
parents:
diff changeset
40 .type ffi_cacheflush_OBSD,@function
kono
parents:
diff changeset
41 ffi_cacheflush_OBSD:
kono
parents:
diff changeset
42 tb0 0, %r0, 451
kono
parents:
diff changeset
43 or %r0, %r0, %r0
kono
parents:
diff changeset
44 jmp %r1
kono
parents:
diff changeset
45 .size ffi_cacheflush_OBSD, . - ffi_cacheflush_OBSD
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 /*
kono
parents:
diff changeset
48 * ffi_call_OBSD(unsigned bytes, %r2
kono
parents:
diff changeset
49 * extended_cif *ecif, %r3
kono
parents:
diff changeset
50 * unsigned flags, %r4
kono
parents:
diff changeset
51 * void *rvalue, %r5
kono
parents:
diff changeset
52 * void (*fn)()); %r6
kono
parents:
diff changeset
53 */
kono
parents:
diff changeset
54 .align 4
kono
parents:
diff changeset
55 .globl ffi_call_OBSD
kono
parents:
diff changeset
56 .type ffi_call_OBSD,@function
kono
parents:
diff changeset
57 ffi_call_OBSD:
kono
parents:
diff changeset
58 subu %r31, %r31, 32
kono
parents:
diff changeset
59 st %r30, %r31, 4
kono
parents:
diff changeset
60 st %r1, %r31, 0
kono
parents:
diff changeset
61 addu %r30, %r31, 32
kono
parents:
diff changeset
62
kono
parents:
diff changeset
63 | Save the few arguments we'll need after ffi_prep_args()
kono
parents:
diff changeset
64 st.d %r4, %r31, 8
kono
parents:
diff changeset
65 st %r6, %r31, 16
kono
parents:
diff changeset
66
kono
parents:
diff changeset
67 | Allocate room for the image of r2-r9, and the stack space for
kono
parents:
diff changeset
68 | the args (rounded to a 16-byte boundary)
kono
parents:
diff changeset
69 addu %r2, %r2, (8 * 4) + 15
kono
parents:
diff changeset
70 clr %r2, %r2, 4<0>
kono
parents:
diff changeset
71 subu %r31, %r31, %r2
kono
parents:
diff changeset
72
kono
parents:
diff changeset
73 | Fill register and stack image
kono
parents:
diff changeset
74 or %r2, %r31, %r0
kono
parents:
diff changeset
75 #ifdef PIC
kono
parents:
diff changeset
76 bsr ffi_prep_args#plt
kono
parents:
diff changeset
77 #else
kono
parents:
diff changeset
78 bsr ffi_prep_args
kono
parents:
diff changeset
79 #endif
kono
parents:
diff changeset
80
kono
parents:
diff changeset
81 | Save pointer to return struct address, if any
kono
parents:
diff changeset
82 or %r12, %r2, %r0
kono
parents:
diff changeset
83
kono
parents:
diff changeset
84 | Get function pointer
kono
parents:
diff changeset
85 subu %r4, %r30, 32
kono
parents:
diff changeset
86 ld %r1, %r4, 16
kono
parents:
diff changeset
87
kono
parents:
diff changeset
88 | Fetch the register arguments
kono
parents:
diff changeset
89 ld.d %r2, %r31, (0 * 4)
kono
parents:
diff changeset
90 ld.d %r4, %r31, (2 * 4)
kono
parents:
diff changeset
91 ld.d %r6, %r31, (4 * 4)
kono
parents:
diff changeset
92 ld.d %r8, %r31, (6 * 4)
kono
parents:
diff changeset
93 addu %r31, %r31, (8 * 4)
kono
parents:
diff changeset
94
kono
parents:
diff changeset
95 | Invoke the function
kono
parents:
diff changeset
96 jsr %r1
kono
parents:
diff changeset
97
kono
parents:
diff changeset
98 | Restore stack now that we don't need the args anymore
kono
parents:
diff changeset
99 subu %r31, %r30, 32
kono
parents:
diff changeset
100
kono
parents:
diff changeset
101 | Figure out what to return as the function's return value
kono
parents:
diff changeset
102 ld %r5, %r31, 12 | rvalue
kono
parents:
diff changeset
103 ld %r4, %r31, 8 | flags
kono
parents:
diff changeset
104
kono
parents:
diff changeset
105 bcnd eq0, %r5, 9f
kono
parents:
diff changeset
106
kono
parents:
diff changeset
107 bb0 0, %r4, 1f | CIF_FLAGS_INT
kono
parents:
diff changeset
108 st %r2, %r5, 0
kono
parents:
diff changeset
109 br 9f
kono
parents:
diff changeset
110
kono
parents:
diff changeset
111 1:
kono
parents:
diff changeset
112 bb0 1, %r4, 1f | CIF_FLAGS_DINT
kono
parents:
diff changeset
113 st.d %r2, %r5, 0
kono
parents:
diff changeset
114 br 9f
kono
parents:
diff changeset
115
kono
parents:
diff changeset
116 1:
kono
parents:
diff changeset
117 9:
kono
parents:
diff changeset
118 ld %r1, %r31, 0
kono
parents:
diff changeset
119 ld %r30, %r31, 4
kono
parents:
diff changeset
120 jmp.n %r1
kono
parents:
diff changeset
121 addu %r31, %r31, 32
kono
parents:
diff changeset
122 .size ffi_call_OBSD, . - ffi_call_OBSD
kono
parents:
diff changeset
123
kono
parents:
diff changeset
124 /*
kono
parents:
diff changeset
125 * ffi_closure_OBSD(ffi_closure *closure); %r13
kono
parents:
diff changeset
126 */
kono
parents:
diff changeset
127 .align 4
kono
parents:
diff changeset
128 .globl ffi_closure_OBSD
kono
parents:
diff changeset
129 .type ffi_closure_OBSD, @function
kono
parents:
diff changeset
130 ffi_closure_OBSD:
kono
parents:
diff changeset
131 subu %r31, %r31, 16
kono
parents:
diff changeset
132 st %r30, %r31, 4
kono
parents:
diff changeset
133 st %r1, %r31, 0
kono
parents:
diff changeset
134 addu %r30, %r31, 16
kono
parents:
diff changeset
135
kono
parents:
diff changeset
136 | Make room on the stack for saved register arguments and return
kono
parents:
diff changeset
137 | value
kono
parents:
diff changeset
138 subu %r31, %r31, (8 * 4) + (2 * 4)
kono
parents:
diff changeset
139 st.d %r2, %r31, (0 * 4)
kono
parents:
diff changeset
140 st.d %r4, %r31, (2 * 4)
kono
parents:
diff changeset
141 st.d %r6, %r31, (4 * 4)
kono
parents:
diff changeset
142 st.d %r8, %r31, (6 * 4)
kono
parents:
diff changeset
143
kono
parents:
diff changeset
144 | Invoke the closure function
kono
parents:
diff changeset
145 or %r5, %r30, 0 | calling stack
kono
parents:
diff changeset
146 addu %r4, %r31, 0 | saved registers
kono
parents:
diff changeset
147 addu %r3, %r31, (8 * 4) | return value
kono
parents:
diff changeset
148 or %r2, %r13, %r0 | closure
kono
parents:
diff changeset
149 #ifdef PIC
kono
parents:
diff changeset
150 bsr ffi_closure_OBSD_inner#plt
kono
parents:
diff changeset
151 #else
kono
parents:
diff changeset
152 bsr ffi_closure_OBSD_inner
kono
parents:
diff changeset
153 #endif
kono
parents:
diff changeset
154
kono
parents:
diff changeset
155 | Figure out what to return as the function's return value
kono
parents:
diff changeset
156 bb0 0, %r2, 1f | CIF_FLAGS_INT
kono
parents:
diff changeset
157 ld %r2, %r31, (8 * 4)
kono
parents:
diff changeset
158 br 9f
kono
parents:
diff changeset
159
kono
parents:
diff changeset
160 1:
kono
parents:
diff changeset
161 bb0 1, %r2, 1f | CIF_FLAGS_DINT
kono
parents:
diff changeset
162 ld.d %r2, %r31, (8 * 4)
kono
parents:
diff changeset
163 br 9f
kono
parents:
diff changeset
164
kono
parents:
diff changeset
165 1:
kono
parents:
diff changeset
166 9:
kono
parents:
diff changeset
167 subu %r31, %r30, 16
kono
parents:
diff changeset
168 ld %r1, %r31, 0
kono
parents:
diff changeset
169 ld %r30, %r31, 4
kono
parents:
diff changeset
170 jmp.n %r1
kono
parents:
diff changeset
171 addu %r31, %r31, 16
kono
parents:
diff changeset
172 .size ffi_closure_OBSD,.-ffi_closure_OBSD
kono
parents:
diff changeset
173
kono
parents:
diff changeset
174 /*
kono
parents:
diff changeset
175 * ffi_closure_struct_OBSD(ffi_closure *closure); %r13
kono
parents:
diff changeset
176 */
kono
parents:
diff changeset
177 .align 4
kono
parents:
diff changeset
178 .globl ffi_closure_struct_OBSD
kono
parents:
diff changeset
179 .type ffi_closure_struct_OBSD, @function
kono
parents:
diff changeset
180 ffi_closure_struct_OBSD:
kono
parents:
diff changeset
181 subu %r31, %r31, 16
kono
parents:
diff changeset
182 st %r30, %r31, 4
kono
parents:
diff changeset
183 st %r1, %r31, 0
kono
parents:
diff changeset
184 addu %r30, %r31, 16
kono
parents:
diff changeset
185
kono
parents:
diff changeset
186 | Make room on the stack for saved register arguments
kono
parents:
diff changeset
187 subu %r31, %r31, (8 * 4)
kono
parents:
diff changeset
188 st.d %r2, %r31, (0 * 4)
kono
parents:
diff changeset
189 st.d %r4, %r31, (2 * 4)
kono
parents:
diff changeset
190 st.d %r6, %r31, (4 * 4)
kono
parents:
diff changeset
191 st.d %r8, %r31, (6 * 4)
kono
parents:
diff changeset
192
kono
parents:
diff changeset
193 | Invoke the closure function
kono
parents:
diff changeset
194 or %r5, %r30, 0 | calling stack
kono
parents:
diff changeset
195 addu %r4, %r31, 0 | saved registers
kono
parents:
diff changeset
196 or %r3, %r12, 0 | return value
kono
parents:
diff changeset
197 or %r2, %r13, %r0 | closure
kono
parents:
diff changeset
198 #ifdef PIC
kono
parents:
diff changeset
199 bsr ffi_closure_OBSD_inner#plt
kono
parents:
diff changeset
200 #else
kono
parents:
diff changeset
201 bsr ffi_closure_OBSD_inner
kono
parents:
diff changeset
202 #endif
kono
parents:
diff changeset
203
kono
parents:
diff changeset
204 subu %r31, %r30, 16
kono
parents:
diff changeset
205 ld %r1, %r31, 0
kono
parents:
diff changeset
206 ld %r30, %r31, 4
kono
parents:
diff changeset
207 jmp.n %r1
kono
parents:
diff changeset
208 addu %r31, %r31, 16
kono
parents:
diff changeset
209 .size ffi_closure_struct_OBSD,.-ffi_closure_struct_OBSD