annotate dyncall/dyncall_callvm_mips_n32.c @ 663:127b569978cc default tip

- another tweak handling clang trying to be too smart (see last commit)
author Tassilo Philipp
date Sun, 24 Mar 2024 13:52:44 +0100
parents 71c884e610f0
children
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_callvm_mips_n32.c
131
21537652361e - fixed mips64 n32 build (not sure if working, though)
cslag
parents: 84
diff changeset
6 Description: mips64 "n32" ABI callvm implementation
0
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
366
ad5f9803f52f - removal of some unnecessary headers that only contained internally used forward declarations, so no need to have them
Tassilo Philipp
parents: 281
diff changeset
9 Copyright (c) 2007-2020 Daniel Adler <dadler@uni-goettingen.de>,
0
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
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
26
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
27
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
28 /*
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
29
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
30 dyncall callvm for 64bit MIPS family of processors
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
31
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
32 SUPPORTED CALLING CONVENTIONS
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
33 n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
34
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
35 REVISION
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
36 2010/05/30 initial
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
37
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
38 in contrast to o32, there is no space reserved for parameters
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
39 passed over registers.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
40 more registers are used and registers are always used.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
41
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
42 stack is always 16-byte aligned at entry (call to call-kernel automatically
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
43 aligns argument stack.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
44
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
45 integer and float register-file is interleaved either taking one slot up
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
46 skipping the other.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
47
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
48
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
49 */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
50
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
51
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
52 #include "dyncall_callvm_mips_n32.h"
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
53 #include "dyncall_alloc.h"
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
54 #include "dyncall_utils.h"
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
55
366
ad5f9803f52f - removal of some unnecessary headers that only contained internally used forward declarations, so no need to have them
Tassilo Philipp
parents: 281
diff changeset
56
ad5f9803f52f - removal of some unnecessary headers that only contained internally used forward declarations, so no need to have them
Tassilo Philipp
parents: 281
diff changeset
57 void dcCall_mips_n32(DCpointer target, DCRegData_mips_n32* regdata, DCsize stksize, DCpointer stkdata);
ad5f9803f52f - removal of some unnecessary headers that only contained internally used forward declarations, so no need to have them
Tassilo Philipp
parents: 281
diff changeset
58
ad5f9803f52f - removal of some unnecessary headers that only contained internally used forward declarations, so no need to have them
Tassilo Philipp
parents: 281
diff changeset
59
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
60 static void dc_callvm_reset_mips_n32(DCCallVM* in_self)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
61 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
62 DCCallVM_mips_n32* self = (DCCallVM_mips_n32*)in_self;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
63 dcVecReset(&self->mVecHead);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
64 self->mRegCount = 0;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
65 self->mRegData.mUseDouble = 0LL;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
66 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
67
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
68
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
69 static void dc_callvm_free_mips_n32(DCCallVM* in_self)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
70 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
71 dcFreeMem(in_self);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
72 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
73
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
74 /* pass arguments :
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
75
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
76 - promote to 64-bit integer.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
77 - fill up integers and float - left-to-right otherwise go over stack.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
78 */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
79
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
80 /* arg int -- fillup 64-bit integer register file OR push on stack */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
81
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
82 static void dc_callvm_argLongLong_mips_n32(DCCallVM* in_self, DClonglong Lv)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
83 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
84 DCCallVM_mips_n32* self = (DCCallVM_mips_n32*)in_self;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
85 /* fillup integer register file */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
86 if (self->mRegCount < 8)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
87 self->mRegData.mIntData[self->mRegCount++] = Lv;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
88 else
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
89 dcVecAppend(&self->mVecHead, &Lv, sizeof(DClonglong));
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
90 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
91
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
92 static void dc_callvm_argInt_mips_n32(DCCallVM* in_self, DCint i)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
93 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
94 dc_callvm_argLongLong_mips_n32(in_self, (DClonglong) i );
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
95 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
96
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
97 static void dc_callvm_argPointer_mips_n32(DCCallVM* in_self, DCpointer x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
98 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
99 dc_callvm_argLongLong_mips_n32(in_self, * (DClonglong*) &x );
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
100 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
101
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
102 static void dc_callvm_argBool_mips_n32(DCCallVM* in_self, DCbool x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
103 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
104 dc_callvm_argLongLong_mips_n32(in_self, (DClonglong)x);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
105 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
106
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
107 static void dc_callvm_argChar_mips_n32(DCCallVM* in_self, DCchar x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
108 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
109 dc_callvm_argLongLong_mips_n32(in_self, (DClonglong)x);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
110 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
111
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
112 static void dc_callvm_argShort_mips_n32(DCCallVM* in_self, DCshort x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
113 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
114 dc_callvm_argLongLong_mips_n32(in_self, (DClonglong)x);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
115 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
116
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
117 static void dc_callvm_argLong_mips_n32(DCCallVM* in_self, DClong x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
118 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
119 dc_callvm_argLongLong_mips_n32(in_self, (DClonglong)x);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
120 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
121
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
122 static void dc_callvm_argDouble_mips_n32(DCCallVM* in_self, DCdouble x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
123 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
124 DCCallVM_mips_n32* self = (DCCallVM_mips_n32*)in_self;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
125 if (self->mRegCount < 8) {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
126 self->mRegData.mUseDouble |= 1<<( self->mRegCount );
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
127 self->mRegData.mFloatData[self->mRegCount++].d = x;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
128 } else {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
129 dcVecAppend(&self->mVecHead, &x, sizeof(DCdouble) );
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
130 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
131 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
132
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
133 static void dc_callvm_argFloat_mips_n32(DCCallVM* in_self, DCfloat x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
134 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
135 DCCallVM_mips_n32* self = (DCCallVM_mips_n32*)in_self;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
136 if (self->mRegCount < 8) {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
137 /*self->mRegData.mFloatData[self->mRegCount++].d = (DCdouble) x;*/
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
138 self->mRegData.mFloatData[self->mRegCount++].f = x;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
139 } else {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
140 dcVecAppend(&self->mVecHead, &x, sizeof(DCfloat) );
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
141 dcVecSkip(&self->mVecHead, sizeof(DCfloat) );
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
142 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
143 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
144
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
145
131
21537652361e - fixed mips64 n32 build (not sure if working, though)
cslag
parents: 84
diff changeset
146 /* Ellipsis calls:
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
147 - float is promoted to double (due to ANSI C).
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
148 - double is passed via integer register-file (due to MIPS ABI).
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
149 */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
150
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
151 static void dc_callvm_argDouble_mips_n32_ellipsis(DCCallVM* in_self, DCdouble x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
152 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
153 dc_callvm_argLongLong_mips_n32(in_self, * ( (DClonglong*) &x ) );
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
154 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
155
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
156 static void dc_callvm_argFloat_mips_n32_ellipsis(DCCallVM* in_self, DCfloat x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
157 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
158 dc_callvm_argDouble_mips_n32_ellipsis(in_self, (DCdouble) x );
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
159 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
160
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
161
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
162 /* Call. */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
163
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
164 void dc_callvm_call_mips_n32(DCCallVM* in_self, DCpointer target)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
165 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
166 DCCallVM_mips_n32* self = (DCCallVM_mips_n32*)in_self;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
167 /* at minimum provide 16-bytes
131
21537652361e - fixed mips64 n32 build (not sure if working, though)
cslag
parents: 84
diff changeset
168 which hold the first four integer register as spill area
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
169 and are automatically loaded to $4-$7
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
170 */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
171 size_t size = DC_MAX(16, ( ( (unsigned) dcVecSize(&self->mVecHead) ) +7UL ) & (-8UL) );
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
172 dcCall_mips_n32(target, &self->mRegData, size, dcVecData(&self->mVecHead));
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
173 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
174
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
175 /* Forward Declaration. */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
176 static void dc_callvm_mode_mips_n32(DCCallVM* in_self,DCint mode);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
177
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
178 DCCallVM_vt gVT_mips_n32 =
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
179 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
180 &dc_callvm_free_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
181 , &dc_callvm_reset_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
182 , &dc_callvm_mode_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
183 , &dc_callvm_argBool_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
184 , &dc_callvm_argChar_mips_n32
131
21537652361e - fixed mips64 n32 build (not sure if working, though)
cslag
parents: 84
diff changeset
185 , &dc_callvm_argShort_mips_n32
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
186 , &dc_callvm_argInt_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
187 , &dc_callvm_argLong_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
188 , &dc_callvm_argLongLong_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
189 , &dc_callvm_argFloat_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
190 , &dc_callvm_argDouble_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
191 , &dc_callvm_argPointer_mips_n32
533
71c884e610f0 - integration of patches from Raphael Luba, Thekla, Inc.:
Tassilo Philipp
parents: 466
diff changeset
192 , NULL /* argAggr */
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
193 , (DCvoidvmfunc*) &dc_callvm_call_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
194 , (DCboolvmfunc*) &dc_callvm_call_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
195 , (DCcharvmfunc*) &dc_callvm_call_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
196 , (DCshortvmfunc*) &dc_callvm_call_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
197 , (DCintvmfunc*) &dc_callvm_call_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
198 , (DClongvmfunc*) &dc_callvm_call_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
199 , (DClonglongvmfunc*) &dc_callvm_call_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
200 , (DCfloatvmfunc*) &dc_callvm_call_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
201 , (DCdoublevmfunc*) &dc_callvm_call_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
202 , (DCpointervmfunc*) &dc_callvm_call_mips_n32
533
71c884e610f0 - integration of patches from Raphael Luba, Thekla, Inc.:
Tassilo Philipp
parents: 466
diff changeset
203 , NULL /* callAggr */
71c884e610f0 - integration of patches from Raphael Luba, Thekla, Inc.:
Tassilo Philipp
parents: 466
diff changeset
204 , NULL /* beginAggr */
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
205 };
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
206
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
207 DCCallVM_vt gVT_mips_n32_ellipsis =
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
208 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
209 &dc_callvm_free_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
210 , &dc_callvm_reset_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
211 , &dc_callvm_mode_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
212 , &dc_callvm_argBool_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
213 , &dc_callvm_argChar_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
214 , &dc_callvm_argShort_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
215 , &dc_callvm_argInt_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
216 , &dc_callvm_argLong_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
217 , &dc_callvm_argLongLong_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
218 , &dc_callvm_argFloat_mips_n32_ellipsis
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
219 , &dc_callvm_argDouble_mips_n32_ellipsis
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
220 , &dc_callvm_argPointer_mips_n32
533
71c884e610f0 - integration of patches from Raphael Luba, Thekla, Inc.:
Tassilo Philipp
parents: 466
diff changeset
221 , NULL /* argAggr */
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
222 , (DCvoidvmfunc*) &dc_callvm_call_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
223 , (DCboolvmfunc*) &dc_callvm_call_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
224 , (DCcharvmfunc*) &dc_callvm_call_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
225 , (DCshortvmfunc*) &dc_callvm_call_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
226 , (DCintvmfunc*) &dc_callvm_call_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
227 , (DClongvmfunc*) &dc_callvm_call_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
228 , (DClonglongvmfunc*) &dc_callvm_call_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
229 , (DCfloatvmfunc*) &dc_callvm_call_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
230 , (DCdoublevmfunc*) &dc_callvm_call_mips_n32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
231 , (DCpointervmfunc*) &dc_callvm_call_mips_n32
533
71c884e610f0 - integration of patches from Raphael Luba, Thekla, Inc.:
Tassilo Philipp
parents: 466
diff changeset
232 , NULL /* callAggr */
71c884e610f0 - integration of patches from Raphael Luba, Thekla, Inc.:
Tassilo Philipp
parents: 466
diff changeset
233 , NULL /* beginAggr */
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
234 };
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
235
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
236 static void dc_callvm_mode_mips_n32(DCCallVM* in_self, DCint mode)
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
237 {
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
238 DCCallVM_mips_n32* self = (DCCallVM_mips_n32*)in_self;
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
239 DCCallVM_vt* vt;
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
240
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
241 switch(mode) {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
242 case DC_CALL_C_DEFAULT:
466
ddfb9577a00e introduced platform-native thiscall mode (DC_CALL_C_DEFAULT_THIS), as needed
Tassilo Philipp
parents: 366
diff changeset
243 case DC_CALL_C_DEFAULT_THIS:
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
244 case DC_CALL_C_MIPS64_N32:
131
21537652361e - fixed mips64 n32 build (not sure if working, though)
cslag
parents: 84
diff changeset
245 case DC_CALL_C_ELLIPSIS:
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
246 vt = &gVT_mips_n32;
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
247 break;
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
248 case DC_CALL_C_ELLIPSIS_VARARGS:
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
249 vt = &gVT_mips_n32_ellipsis;
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
250 break;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
251 default:
131
21537652361e - fixed mips64 n32 build (not sure if working, though)
cslag
parents: 84
diff changeset
252 self->mInterface.mError = DC_ERROR_UNSUPPORTED_MODE;
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
253 return;
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
254 }
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
255 dc_callvm_base_init(&self->mInterface, vt);
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
256 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
257
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
258 /* Public API. */
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
259 DCCallVM* dcNewCallVM(DCsize size)
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
260 {
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
261 DCCallVM_mips_n32* p = (DCCallVM_mips_n32*)dcAllocMem(sizeof(DCCallVM_mips_n32)+size);
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
262
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
263 dc_callvm_mode_mips_n32((DCCallVM*)p, DC_CALL_C_DEFAULT);
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
264
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
265 dcVecInit(&p->mVecHead, size);
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
266 dc_callvm_reset_mips_n32((DCCallVM*)p);
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
267
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
268 return (DCCallVM*)p;
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
269 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
270