annotate dyncall/dyncall_callvm_mips_n64.c @ 457:90b1d927912a

- suite_aggrs: make sure random memory used doesn't ever result in NaN fp values (for every possible address), as this messes with result comparison
author Tassilo Philipp
date Fri, 28 Jan 2022 14:11:21 +0100
parents ad5f9803f52f
children e2899b4ff713
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_n64.c
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
6 Description: mips "n64" 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
366
ad5f9803f52f - removal of some unnecessary headers that only contained internally used forward declarations, so no need to have them
Tassilo Philipp
parents: 305
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 n64
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_n64.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: 305
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: 305
diff changeset
57 void dcCall_mips_n64(DCpointer target, DCRegData_mips_n64* 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: 305
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: 305
diff changeset
59
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
60 static void dc_callvm_reset_mips_n64(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_n64* self = (DCCallVM_mips_n64*)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;
305
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
65 #if defined(DC__ABI_HARDFLOAT)
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
66 self->mRegData.mUseDouble = 0LL;
305
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
67 #endif /* DC__ABI_HARDFLOAT */
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
68 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
69
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_free_mips_n64(DCCallVM* 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 dcFreeMem(in_self);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
74 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
75
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
76 /* pass arguments :
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
77
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
78 - promote to 64-bit integer.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
79 - fill up integers and float - left-to-right otherwise go over stack.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
80 */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
81
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
82 /* arg int -- fillup 64-bit integer register file OR push on stack */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
83
305
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
84 static void dc_callvm_argLongLong_mips_n64(DCCallVM* in_self, DClonglong x)
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
85 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
86 DCCallVM_mips_n64* self = (DCCallVM_mips_n64*)in_self;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
87 /* fillup integer register file */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
88 if (self->mRegCount < 8)
305
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
89 self->mRegData.mIntData[self->mRegCount++] = x;
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
90 else
305
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
91 dcVecAppend(&self->mVecHead, &x, sizeof(DClonglong));
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
92 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
93
305
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
94 static void dc_callvm_argInt_mips_n64(DCCallVM* in_self, DCint x)
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
95 {
305
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
96 dc_callvm_argLongLong_mips_n64(in_self, (DClonglong)x);
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
97 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
98
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
99 static void dc_callvm_argPointer_mips_n64(DCCallVM* in_self, DCpointer x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
100 {
305
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
101 dc_callvm_argLongLong_mips_n64(in_self, *(DClonglong*)&x);
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
102 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
103
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
104 static void dc_callvm_argBool_mips_n64(DCCallVM* in_self, DCbool 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 dc_callvm_argLongLong_mips_n64(in_self, (DClonglong)x);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
107 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
108
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
109 static void dc_callvm_argChar_mips_n64(DCCallVM* in_self, DCchar 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 dc_callvm_argLongLong_mips_n64(in_self, (DClonglong)x);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
112 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
113
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
114 static void dc_callvm_argShort_mips_n64(DCCallVM* in_self, DCshort 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 dc_callvm_argLongLong_mips_n64(in_self, (DClonglong)x);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
117 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
118
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
119 static void dc_callvm_argLong_mips_n64(DCCallVM* in_self, DClong 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 dc_callvm_argLongLong_mips_n64(in_self, (DClonglong)x);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
122 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
123
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
124 static void dc_callvm_argDouble_mips_n64(DCCallVM* in_self, DCdouble x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
125 {
305
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
126 #if defined(DC__ABI_HARDFLOAT)
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
127 DCCallVM_mips_n64* self = (DCCallVM_mips_n64*)in_self;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
128 if (self->mRegCount < 8) {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
129 self->mRegData.mUseDouble |= 1<<( self->mRegCount );
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
130 self->mRegData.mFloatData[self->mRegCount++].d = x;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
131 } else {
305
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
132 dcVecAppend(&self->mVecHead, &x, sizeof(DCdouble));
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
133 }
305
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
134 #else
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
135 dc_callvm_argLongLong_mips_n64(in_self, *(DClonglong*)&x);
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
136 #endif /* DC__ABI_HARDFLOAT */
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
137 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
138
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
139 static void dc_callvm_argFloat_mips_n64(DCCallVM* in_self, DCfloat x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
140 {
305
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
141 #if defined(DC__ABI_HARDFLOAT)
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
142 DCCallVM_mips_n64* self = (DCCallVM_mips_n64*)in_self;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
143 if (self->mRegCount < 8) {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
144 /*self->mRegData.mFloatData[self->mRegCount++].d = (DCdouble) x;*/
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
145 self->mRegData.mFloatData[self->mRegCount++].f = x;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
146 } else {
305
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
147 dcVecAppend(&self->mVecHead, &x, sizeof(DCfloat));
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
148 dcVecSkip(&self->mVecHead, sizeof(DCfloat));
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
149 }
305
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
150 #else
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
151 DCfloat f[] = {x,0.f};
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
152 # if defined(DC__Endian_BIG)
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
153 // floats in regs always right justified
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
154 if (((DCCallVM_mips_n64*)in_self)->mRegCount < 8) {
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
155 f[1] = f[0];
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
156 f[0] = 0.f;
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
157 }
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
158 # endif /* DC__Endian_BIG */
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
159 dc_callvm_argLongLong_mips_n64(in_self, *(DClonglong*)&f);
b104c5beec8b - softfloat support for mips64/n64 abi
Tassilo Philipp
parents: 281
diff changeset
160 #endif /* DC__ABI_HARDFLOAT */
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
161 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
162
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
163
131
21537652361e - fixed mips64 n32 build (not sure if working, though)
cslag
parents: 128
diff changeset
164 /* Ellipsis calls:
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
165 - float is promoted to double (due to ANSI C).
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
166 - double is passed via integer register-file (due to MIPS ABI).
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
167 */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
168
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
169 static void dc_callvm_argDouble_mips_n64_ellipsis(DCCallVM* in_self, DCdouble x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
170 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
171 dc_callvm_argLongLong_mips_n64(in_self, * ( (DClonglong*) &x ) );
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
172 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
173
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
174 static void dc_callvm_argFloat_mips_n64_ellipsis(DCCallVM* in_self, DCfloat x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
175 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
176 dc_callvm_argDouble_mips_n64_ellipsis(in_self, (DCdouble) x );
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
177 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
178
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
179
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
180 /* Call. */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
181
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
182 void dc_callvm_call_mips_n64(DCCallVM* in_self, DCpointer target)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
183 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
184 DCCallVM_mips_n64* self = (DCCallVM_mips_n64*)in_self;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
185 /* at minimum provide 16-bytes
131
21537652361e - fixed mips64 n32 build (not sure if working, though)
cslag
parents: 128
diff changeset
186 which hold the first four integer register as spill area
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
187 and are automatically loaded to $4-$7
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
188 */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
189 size_t size = DC_MAX(16, ( ( (unsigned) dcVecSize(&self->mVecHead) ) +7UL ) & (-8UL) );
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
190 dcCall_mips_n64(target, &self->mRegData, size, dcVecData(&self->mVecHead));
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
191 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
192
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
193 static void dc_callvm_mode_mips_n64(DCCallVM* in_self,DCint mode);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
194
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
195 DCCallVM_vt gVT_mips_n64 =
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
196 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
197 &dc_callvm_free_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
198 , &dc_callvm_reset_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
199 , &dc_callvm_mode_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
200 , &dc_callvm_argBool_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
201 , &dc_callvm_argChar_mips_n64
131
21537652361e - fixed mips64 n32 build (not sure if working, though)
cslag
parents: 128
diff changeset
202 , &dc_callvm_argShort_mips_n64
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
203 , &dc_callvm_argInt_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
204 , &dc_callvm_argLong_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
205 , &dc_callvm_argLongLong_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
206 , &dc_callvm_argFloat_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
207 , &dc_callvm_argDouble_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
208 , &dc_callvm_argPointer_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
209 , NULL /* argStruct */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
210 , (DCvoidvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
211 , (DCboolvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
212 , (DCcharvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
213 , (DCshortvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
214 , (DCintvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
215 , (DClongvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
216 , (DClonglongvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
217 , (DCfloatvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
218 , (DCdoublevmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
219 , (DCpointervmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
220 , NULL /* callStruct */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
221 };
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
222
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
223 DCCallVM_vt gVT_mips_n64_ellipsis =
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
224 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
225 &dc_callvm_free_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
226 , &dc_callvm_reset_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
227 , &dc_callvm_mode_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
228 , &dc_callvm_argBool_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
229 , &dc_callvm_argChar_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
230 , &dc_callvm_argShort_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
231 , &dc_callvm_argInt_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
232 , &dc_callvm_argLong_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
233 , &dc_callvm_argLongLong_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
234 , &dc_callvm_argFloat_mips_n64_ellipsis
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
235 , &dc_callvm_argDouble_mips_n64_ellipsis
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
236 , &dc_callvm_argPointer_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
237 , NULL /* argStruct */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
238 , (DCvoidvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
239 , (DCboolvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
240 , (DCcharvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
241 , (DCshortvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
242 , (DCintvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
243 , (DClongvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
244 , (DClonglongvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
245 , (DCfloatvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
246 , (DCdoublevmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
247 , (DCpointervmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
248 , NULL /* callStruct */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
249 };
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
250
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
251 static void dc_callvm_mode_mips_n64(DCCallVM* in_self, DCint mode)
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
252 {
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
253 DCCallVM_mips_n64* self = (DCCallVM_mips_n64*)in_self;
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
254 DCCallVM_vt* vt;
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
255
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
256 switch(mode) {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
257 case DC_CALL_C_DEFAULT:
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
258 case DC_CALL_C_MIPS64_N64:
128
9a554d1c4da6 - mips n64 vararg call fixes if non-variadic arguments are floats
cslag
parents: 84
diff changeset
259 case DC_CALL_C_ELLIPSIS:
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
260 vt = &gVT_mips_n64;
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
261 break;
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
262 case DC_CALL_C_ELLIPSIS_VARARGS:
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
263 vt = &gVT_mips_n64_ellipsis;
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
264 break;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
265 default:
131
21537652361e - fixed mips64 n32 build (not sure if working, though)
cslag
parents: 128
diff changeset
266 self->mInterface.mError = DC_ERROR_UNSUPPORTED_MODE;
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
267 return;
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
268 }
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
269 dc_callvm_base_init(&self->mInterface, vt);
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
270 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
271
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
272 /* Public API. */
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
273 DCCallVM* dcNewCallVM(DCsize size)
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
274 {
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
275 DCCallVM_mips_n64* p = (DCCallVM_mips_n64*)dcAllocMem(sizeof(DCCallVM_mips_n64)+size);
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
276
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
277 dc_callvm_mode_mips_n64((DCCallVM*)p, DC_CALL_C_DEFAULT);
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
278
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
279 dcVecInit(&p->mVecHead, size);
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
280 dc_callvm_reset_mips_n64((DCCallVM*)p);
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
281
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
282 return (DCCallVM*)p;
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
283 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
284