annotate dyncall/dyncall_callvm_mips_n64.c @ 533:71c884e610f0

- integration of patches from Raphael Luba, Thekla, Inc.: * integration of aggregate-by-value (struct, union) support patch for x64 (win and sysv) * windows/x64 asm additions to specify how stack unwinds (help for debuggers, exception handling, etc.) * see Changelog for details - new calling convention modes for thiscalls (platform agnostic, was specific before) * new signature character for platform agnostic thiscalls ('*' / DC_SIGCHAR_CC_THISCALL) - dcCallF(), dcVCallF(), dcArgF() and dcVArgF(): * added support for aggregates-by-value (wasn't part of patch) * change that those functions don't implicitly call dcReset() anymore, which was unflexible (breaking change) - added macros to feature test implementation for aggregate-by-value and syscall support - changed libdyncall_s.lib and libdyncallback_s.lib order in callback test makefiles, as some toolchains are picky about order - doc: * man page updates to describe aggregate interface * manual overview changes to highlight platforms with aggregate-by-value support - test/plain: replaced tests w/ old/stale sctruct interface with new aggregate one
author Tassilo Philipp
date Thu, 21 Apr 2022 13:35:47 +0200
parents ddfb9577a00e
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_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)
465
e2899b4ff713 - // -> /* */, mainly for consistency (but also for a few obscure compilers)
Tassilo Philipp
parents: 366
diff changeset
153 /* floats in regs always right justified */
305
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
533
71c884e610f0 - integration of patches from Raphael Luba, Thekla, Inc.:
Tassilo Philipp
parents: 466
diff changeset
209 , NULL /* argAggr */
0
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
533
71c884e610f0 - integration of patches from Raphael Luba, Thekla, Inc.:
Tassilo Philipp
parents: 466
diff changeset
220 , NULL /* callAggr */
71c884e610f0 - integration of patches from Raphael Luba, Thekla, Inc.:
Tassilo Philipp
parents: 466
diff changeset
221 , NULL /* beginAggr */
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
222 };
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
223
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
224 DCCallVM_vt gVT_mips_n64_ellipsis =
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
225 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
226 &dc_callvm_free_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
227 , &dc_callvm_reset_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
228 , &dc_callvm_mode_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
229 , &dc_callvm_argBool_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
230 , &dc_callvm_argChar_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
231 , &dc_callvm_argShort_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
232 , &dc_callvm_argInt_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
233 , &dc_callvm_argLong_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
234 , &dc_callvm_argLongLong_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
235 , &dc_callvm_argFloat_mips_n64_ellipsis
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
236 , &dc_callvm_argDouble_mips_n64_ellipsis
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
237 , &dc_callvm_argPointer_mips_n64
533
71c884e610f0 - integration of patches from Raphael Luba, Thekla, Inc.:
Tassilo Philipp
parents: 466
diff changeset
238 , NULL /* argAggr */
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
239 , (DCvoidvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
240 , (DCboolvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
241 , (DCcharvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
242 , (DCshortvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
243 , (DCintvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
244 , (DClongvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
245 , (DClonglongvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
246 , (DCfloatvmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
247 , (DCdoublevmfunc*) &dc_callvm_call_mips_n64
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
248 , (DCpointervmfunc*) &dc_callvm_call_mips_n64
533
71c884e610f0 - integration of patches from Raphael Luba, Thekla, Inc.:
Tassilo Philipp
parents: 466
diff changeset
249 , NULL /* callAggr */
71c884e610f0 - integration of patches from Raphael Luba, Thekla, Inc.:
Tassilo Philipp
parents: 466
diff changeset
250 , NULL /* beginAggr */
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
251 };
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 static void dc_callvm_mode_mips_n64(DCCallVM* in_self, DCint mode)
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 DCCallVM_mips_n64* self = (DCCallVM_mips_n64*)in_self;
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
256 DCCallVM_vt* vt;
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
257
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
258 switch(mode) {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
259 case DC_CALL_C_DEFAULT:
466
ddfb9577a00e introduced platform-native thiscall mode (DC_CALL_C_DEFAULT_THIS), as needed
Tassilo Philipp
parents: 465
diff changeset
260 case DC_CALL_C_DEFAULT_THIS:
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
261 case DC_CALL_C_MIPS64_N64:
128
9a554d1c4da6 - mips n64 vararg call fixes if non-variadic arguments are floats
cslag
parents: 84
diff changeset
262 case DC_CALL_C_ELLIPSIS:
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
263 vt = &gVT_mips_n64;
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
264 break;
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
265 case DC_CALL_C_ELLIPSIS_VARARGS:
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
266 vt = &gVT_mips_n64_ellipsis;
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
267 break;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
268 default:
131
21537652361e - fixed mips64 n32 build (not sure if working, though)
cslag
parents: 128
diff changeset
269 self->mInterface.mError = DC_ERROR_UNSUPPORTED_MODE;
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
270 return;
0
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 dc_callvm_base_init(&self->mInterface, vt);
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
273 }
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 /* Public API. */
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
276 DCCallVM* dcNewCallVM(DCsize size)
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
277 {
84
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
278 DCCallVM_mips_n64* p = (DCCallVM_mips_n64*)dcAllocMem(sizeof(DCCallVM_mips_n64)+size);
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
279
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
280 dc_callvm_mode_mips_n64((DCCallVM*)p, DC_CALL_C_DEFAULT);
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
281
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
282 dcVecInit(&p->mVecHead, size);
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
283 dc_callvm_reset_mips_n64((DCCallVM*)p);
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
284
67961454902b - bigger cleanup in callvm code
cslag
parents: 0
diff changeset
285 return (DCCallVM*)p;
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
286 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
287