annotate dyncall/dyncall_callvm_mips_n64.c @ 305:b104c5beec8b

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