annotate dyncall/dyncall_callvm_mips_o32.c @ 281:f5577f6bf97a

- file header cleanups for release
author Tassilo Philipp
date Thu, 19 Apr 2018 20:10:26 +0200
parents 1ce60358fbad
children d55f9d508074
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_o32.c
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
6 Description: mips "o32" ABI callvm implementation
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
281
f5577f6bf97a - file header cleanups for release
Tassilo Philipp
parents: 101
diff changeset
9 Copyright (c) 2007-2018 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 mips o32 abi
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
31
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
32 REVISION
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
33 2010/06/03 initial
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
34
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
35 NOTES:
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
36 we need an argument counter for supporting floating point arguments
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
37 correctly.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
38
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
39 first two (if any) double/float arguments are mapped via a common structure --
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
40 code must take care to write the right float argument indices which
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
41 differs on C and Assembly-side depending on endianness. (therefore
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
42 both sources have two variants 'mipseb' and 'mipsel'.)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
43 (only for the first two float/double arguments) see float/double handling
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
44
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
45 although, the abi does not expect usage of floats if first argument is
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
46 not floating point, the call kernel can be used universal for all cases.
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 #include "dyncall_callvm_mips_o32.h"
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
52 #include "dyncall_alloc.h"
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
53 #include "dyncall_utils.h"
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
54
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
55
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
56 static void dc_callvm_reset_mips_o32(DCCallVM* in_self)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
57 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
58 DCCallVM_mips_o32* self = (DCCallVM_mips_o32*)in_self;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
59 dcVecReset(&self->mVecHead);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
60 self->mArgCount = 0;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
61 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
62
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
63
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
64 static void dc_callvm_free_mips_o32(DCCallVM* in_self)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
65 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
66 dcFreeMem(in_self);
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 /* arg int -- fillup integer register file OR push on stack */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
70
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
71 static void dc_callvm_argInt_mips_o32(DCCallVM* in_self, DCint i)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
72 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
73 DCCallVM_mips_o32* self = (DCCallVM_mips_o32*)in_self;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
74 dcVecAppend(&self->mVecHead, &i, sizeof(DCint));
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
75 self->mArgCount++;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
76 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
77
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
78 static void dc_callvm_argPointer_mips_o32(DCCallVM* in_self, DCpointer x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
79 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
80 dc_callvm_argInt_mips_o32(in_self, * (DCint*) &x );
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 static void dc_callvm_argBool_mips_o32(DCCallVM* in_self, DCbool x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
84 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
85 dc_callvm_argInt_mips_o32(in_self, (DCint)x);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
86 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
87
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
88 static void dc_callvm_argChar_mips_o32(DCCallVM* in_self, DCchar x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
89 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
90 dc_callvm_argInt_mips_o32(in_self, (DCint)x);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
91 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
92
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
93 static void dc_callvm_argShort_mips_o32(DCCallVM* in_self, DCshort x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
94 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
95 dc_callvm_argInt_mips_o32(in_self, (DCint)x);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
96 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
97
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
98 static void dc_callvm_argLong_mips_o32(DCCallVM* in_self, DClong x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
99 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
100 dc_callvm_argInt_mips_o32(in_self, (DCint)x);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
101 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
102
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
103 static void dc_callvm_argLongLong_mips_o32(DCCallVM* in_self, DClonglong Lv)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
104 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
105 DCCallVM_mips_o32* self = (DCCallVM_mips_o32*)in_self;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
106
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
107 /* 64-bit values need to be aligned on 8 byte boundaries */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
108 dcVecSkip(&self->mVecHead, dcVecSize(&self->mVecHead) & 4);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
109 dcVecAppend(&self->mVecHead, &Lv, sizeof(DClonglong));
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
110 self->mArgCount += 1;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
111 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
112
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
113 static void dc_callvm_argFloat_mips_o32(DCCallVM* in_self, DCfloat x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
114 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
115 DCCallVM_mips_o32* self = (DCCallVM_mips_o32*)in_self;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
116
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
117 dcVecAppend(&self->mVecHead, &x, sizeof(DCfloat) );
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
118 if (self->mArgCount < 2) {
101
1ce60358fbad - mips related cleanup, mostly comments, cpp macro lib
cslag
parents: 84
diff changeset
119 #if defined(DC__Endian_LITTLE)
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
120 self->mRegData.u[self->mArgCount].f[0] = x;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
121 #else
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
122 self->mRegData.u[self->mArgCount].f[1] = x;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
123 #endif
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
124 #if 0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
125 self->mRegData.u[self->mArgCount].f[1] = x;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
126 call kernel
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
127
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
128 mips:
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
129 lwc1 $f12, 4($5) <--- byte offset 4
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
130 lwc1 $f13, 0($5)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
131 lwc1 $f14, 12($5) <--- byte offset 12
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
132 lwc1 $f15, 8($5)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
133 mipsel:
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
134 lwc1 $f12, 0($5) <--- byte offset 4
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
135 lwc1 $f13, 4($5)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
136 lwc1 $f14, 8($5) <--- byte offset 12
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
137 lwc1 $f15, 12($5)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
138
101
1ce60358fbad - mips related cleanup, mostly comments, cpp macro lib
cslag
parents: 84
diff changeset
139 #if defined(DC__Endian_LITTLE)
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
140 /* index 0 and 2 */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
141 self->mRegData.floats[self->mArgCount*2] = x;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
142 #else
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
143 /* index 1 and 3 */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
144 self->mRegData.floats[self->mArgCount*2+1] = x;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
145 #endif
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
146 #endif
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
147 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
148 self->mArgCount++;
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_o32(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 DCCallVM_mips_o32* self = (DCCallVM_mips_o32*)in_self;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
154 /* 64-bit values need to be aligned on 8 byte boundaries */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
155 dcVecSkip(&self->mVecHead, dcVecSize(&self->mVecHead) & 4);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
156 dcVecAppend(&self->mVecHead, &x, sizeof(DCdouble) );
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
157 if (self->mArgCount < 2)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
158 self->mRegData.u[self->mArgCount].d = x;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
159 self->mArgCount++;
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 void dc_callvm_call_mips_o32(DCCallVM* in_self, DCpointer target)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
164 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
165 DCCallVM_mips_o32* self = (DCCallVM_mips_o32*)in_self;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
166 /* at minimum provide 16-bytes
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
167 which hold the first four integer register as spill area
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
168 and are automatically loaded to $4-$7
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
169 */
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
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
173 dcCall_mips_o32(target, &self->mRegData, size, dcVecData(&self->mVecHead));
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
174 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
175
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
176 static void dc_callvm_mode_mips_o32(DCCallVM* in_self, DCint mode);
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
177
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
178 DCCallVM_vt gVT_mips_o32 =
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_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
181 , &dc_callvm_reset_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
182 , &dc_callvm_mode_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
183 , &dc_callvm_argBool_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
184 , &dc_callvm_argChar_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
185 , &dc_callvm_argShort_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
186 , &dc_callvm_argInt_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
187 , &dc_callvm_argLong_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
188 , &dc_callvm_argLongLong_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
189 , &dc_callvm_argFloat_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
190 , &dc_callvm_argDouble_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
191 , &dc_callvm_argPointer_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
192 , NULL /* argStruct */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
193 , (DCvoidvmfunc*) &dc_callvm_call_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
194 , (DCboolvmfunc*) &dc_callvm_call_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
195 , (DCcharvmfunc*) &dc_callvm_call_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
196 , (DCshortvmfunc*) &dc_callvm_call_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
197 , (DCintvmfunc*) &dc_callvm_call_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
198 , (DClongvmfunc*) &dc_callvm_call_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
199 , (DClonglongvmfunc*) &dc_callvm_call_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
200 , (DCfloatvmfunc*) &dc_callvm_call_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
201 , (DCdoublevmfunc*) &dc_callvm_call_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
202 , (DCpointervmfunc*) &dc_callvm_call_mips_o32
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
203 , NULL /* callStruct */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
204 };
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
205
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
206 /* mode: only a single mode available currently. */
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
207 static void dc_callvm_mode_mips_o32(DCCallVM* in_self, DCint mode)
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
208 {
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
209 DCCallVM_mips_o32* self = (DCCallVM_mips_o32*)in_self;
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
210 DCCallVM_vt* vt;
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
211
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
212 switch(mode) {
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
213 case DC_CALL_C_DEFAULT:
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
214 case DC_CALL_C_MIPS32_O32:
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
215 case DC_CALL_C_ELLIPSIS:
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
216 case DC_CALL_C_ELLIPSIS_VARARGS:
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
217 vt = &gVT_mips_o32;
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
218 break;
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
219 default:
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
220 self->mInterface.mError = DC_ERROR_UNSUPPORTED_MODE;
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
221 return;
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
222 }
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
223 dc_callvm_base_init(&self->mInterface, vt);
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
224 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
225
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
226 /* Public API. */
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
227 DCCallVM* dcNewCallVM(DCsize size)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
228 {
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
229 DCCallVM_mips_o32* p = (DCCallVM_mips_o32*)dcAllocMem(sizeof(DCCallVM_mips_o32)+size);
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
230
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
231 dc_callvm_mode_mips_o32((DCCallVM*)p, DC_CALL_C_DEFAULT);
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
232
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
233 dcVecInit(&p->mVecHead, size);
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
234 dc_callvm_reset_mips_o32((DCCallVM*)p);
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
235
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
236 return (DCCallVM*)p;
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
237 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
238