annotate dyncall/dyncall_callvm_arm32_arm_armhf.c @ 51:9e9d6a90492a r0.9-RC4

- armhf experimental vararg call support
author cslag
date Sun, 20 Dec 2015 20:27:43 +0100
parents c4de113dc1e9
children 67961454902b
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_arm32_arm_armhf.c
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
6 Description: ARM 'armhf' ABI 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
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
9 Copyright (c) 2007-2015 Daniel Adler <dadler@uni-goettingen.de>,
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 #include "dyncall_callvm_arm32_arm_armhf.h"
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
28 #include "dyncall_alloc.h"
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
29
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
30
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
31 static DCCallVM* dc_callvm_new_arm32_armhf(DCCallVM_vt* vt, DCsize size)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
32 {
51
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
33 /* Store at least 16 bytes (4 words for first 4 int args) for internal spill area. Assembly code depends on it. */
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
34 DCCallVM_arm32_armhf* p = (DCCallVM_arm32_armhf*)dcAllocMem(sizeof(DCCallVM_arm32_armhf)+size+16);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
35 dc_callvm_base_init(&p->mInterface, vt);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
36 dcVecInit(&p->mVecHead, size);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
37 p->i = 0;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
38 p->s = 0;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
39 p->d = 0;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
40 return (DCCallVM*)p;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
41 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
42
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
43 static void mode(DCCallVM* in_self,DCint mode);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
44
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
45 static void deinit(DCCallVM* in_self)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
46 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
47 dcFreeMem(in_self);
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 static void reset(DCCallVM* in_p)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
52 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
53 DCCallVM_arm32_armhf* p = (DCCallVM_arm32_armhf*)in_p;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
54 p->i = 0;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
55 p->s = 0;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
56 p->d = 0;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
57 dcVecResize(&p->mVecHead, 16);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
58 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
59
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
60 static void a_int(DCCallVM* in_self, DCint x)
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_arm32_armhf* p = (DCCallVM_arm32_armhf*)in_self;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
63 if (p->i < 16) {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
64 * (DCint*) dcVecAt(&p->mVecHead, p->i) = x;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
65 p->i += 4;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
66 } else {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
67 dcVecAppend(&p->mVecHead, &x, sizeof(DCint));
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 a_bool (DCCallVM* in_self, DCbool x) { a_int(in_self, (DCint)x); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
72 static void a_char (DCCallVM* in_self, DCchar x) { a_int(in_self, x); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
73 static void a_short (DCCallVM* in_self, DCshort x) { a_int(in_self, x); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
74 static void a_long (DCCallVM* in_self, DClong x) { a_int(in_self, x); }
51
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
75
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
76 static void a_longlong(DCCallVM* in_self, DClonglong x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
77 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
78 DCCallVM_arm32_armhf* p = (DCCallVM_arm32_armhf*)in_self;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
79
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
80 p->i = (p->i+4) & -8;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
81 if (p->i < 16) {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
82 * (DClonglong*) dcVecAt(&p->mVecHead, p->i) = x;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
83 p->i += 8;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
84 } else {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
85 /* 64 bit values need to be aligned on 8 byte boundaries */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
86 dcVecSkip(&p->mVecHead, dcVecSize(&p->mVecHead) & 4);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
87 dcVecAppend(&p->mVecHead, &x, sizeof(DClonglong));
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
88 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
89 }
51
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
90
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
91 static void a_pointer(DCCallVM* in_p, DCpointer x) { a_int(in_p, (DCint) x ); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
92
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
93 static void a_float(DCCallVM* in_p, DCfloat x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
94 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
95 DCCallVM_arm32_armhf* p = (DCCallVM_arm32_armhf*)in_p;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
96 if (p->s < 16) {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
97 p->S[p->s++] = x;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
98 if (p->d < p->s) {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
99 p->d = (p->s+1) & ~(1U);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
100 } else {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
101 p->s = p->d;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
102 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
103 } else {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
104 dcVecAppend(&p->mVecHead, &x, sizeof(DCfloat));
51
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
105 }
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
106 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
107
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
108 static void a_double(DCCallVM* in_p, DCdouble x)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
109 {
47
c4de113dc1e9 - some armhf comments, doc clarification, cleanup
cslag
parents: 39
diff changeset
110 union {
c4de113dc1e9 - some armhf comments, doc clarification, cleanup
cslag
parents: 39
diff changeset
111 DCdouble d;
c4de113dc1e9 - some armhf comments, doc clarification, cleanup
cslag
parents: 39
diff changeset
112 DCchar b[8];
c4de113dc1e9 - some armhf comments, doc clarification, cleanup
cslag
parents: 39
diff changeset
113 } v;
c4de113dc1e9 - some armhf comments, doc clarification, cleanup
cslag
parents: 39
diff changeset
114
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
115 DCCallVM_arm32_armhf* p = (DCCallVM_arm32_armhf*)in_p;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
116 if (p->d < 16) {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
117 * (double*) &p->S[p->d] = x;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
118 p->d += 2;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
119 if (!(p->s & 1)) {
51
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
120 /* if s is even it always equals d. otherwise, s points to an odd float register. */
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
121 p->s = p->d;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
122 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
123 } else {
47
c4de113dc1e9 - some armhf comments, doc clarification, cleanup
cslag
parents: 39
diff changeset
124 p->s = 16; /* fp registers all full - need to use stack now: stop filling gaps for single precision, also */
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
125 v.d = x;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
126 /* 64 bit values need to be aligned on 8 byte boundaries */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
127 dcVecSkip(&p->mVecHead, dcVecSize(&p->mVecHead) & 4);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
128 dcVecAppend(&p->mVecHead, &v.b[0], sizeof(DCdouble));
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
129 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
130 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
131
51
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
132 static void a_float_ellipsis(DCCallVM* in_p, DCfloat x)
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
133 {
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
134 a_int(in_p, *(DCint*)&x);
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
135 }
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
136
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
137 static void a_double_ellipsis(DCCallVM* in_p, DCdouble x)
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
138 {
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
139 a_longlong(in_p, *(DClonglong*)&x);
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
140 }
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
141
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
142 void call(DCCallVM* in_p, DCpointer target)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
143 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
144 DCCallVM_arm32_armhf* p = (DCCallVM_arm32_armhf*)in_p;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
145 dcCall_arm32_armhf(target, dcVecData(&p->mVecHead), dcVecSize(&p->mVecHead), &p->S[0]);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
146 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
147
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
148 DCCallVM_vt vt_armhf =
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
149 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
150 &deinit
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
151 , &reset
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
152 , &mode
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
153 , &a_bool
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
154 , &a_char
51
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
155 , &a_short
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
156 , &a_int
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
157 , &a_long
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
158 , &a_longlong
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
159 , &a_float
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
160 , &a_double
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
161 , &a_pointer
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
162 , NULL /* argStruct */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
163 , (DCvoidvmfunc*) &call
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
164 , (DCboolvmfunc*) &call
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
165 , (DCcharvmfunc*) &call
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
166 , (DCshortvmfunc*) &call
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
167 , (DCintvmfunc*) &call
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
168 , (DClongvmfunc*) &call
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
169 , (DClonglongvmfunc*) &call
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
170 , (DCfloatvmfunc*) &call
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
171 , (DCdoublevmfunc*) &call
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
172 , (DCpointervmfunc*) &call
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
173 , NULL /* callStruct */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
174 };
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
175
51
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
176 DCCallVM_vt vt_armhf_ellipsis =
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
177 {
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
178 &deinit
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
179 , &reset
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
180 , &mode
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
181 , &a_bool
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
182 , &a_char
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
183 , &a_short
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
184 , &a_int
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
185 , &a_long
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
186 , &a_longlong
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
187 , &a_float_ellipsis
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
188 , &a_double_ellipsis
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
189 , &a_pointer
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
190 , NULL /* argStruct */
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
191 , (DCvoidvmfunc*) &call
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
192 , (DCboolvmfunc*) &call
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
193 , (DCcharvmfunc*) &call
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
194 , (DCshortvmfunc*) &call
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
195 , (DCintvmfunc*) &call
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
196 , (DClongvmfunc*) &call
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
197 , (DClonglongvmfunc*) &call
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
198 , (DCfloatvmfunc*) &call
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
199 , (DCdoublevmfunc*) &call
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
200 , (DCpointervmfunc*) &call
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
201 , NULL /* callStruct */
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
202 };
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
203
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
204 DCCallVM* dcNewCallVM(DCsize size)
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
205 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
206 #if defined(DC__ABI_ARM_EABI)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
207 return dc_callvm_new_arm32_arm(&eabi, size);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
208 #elif defined(DC__ABI_ARM_HF)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
209 return dc_callvm_new_arm32_armhf(&vt_armhf, size);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
210 #elif defined(DC__ABI_ARM_OABI)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
211 return dc_callvm_new_arm32_arm(&oabi, size);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
212 #else
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
213 #error unknown ARM abi
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
214 #endif
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
215 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
216
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
217 static void mode(DCCallVM* in_self,DCint mode)
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_arm32_armhf* self = (DCCallVM_arm32_armhf*) in_self;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
220 switch(mode) {
51
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
221 case DC_CALL_C_DEFAULT:
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
222 case DC_CALL_C_ARM_ARMHF:
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
223 self->mInterface.mVTpointer = &vt_armhf;
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
224 break;
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
225 case DC_CALL_C_ELLIPSIS:
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
226 case DC_CALL_C_ELLIPSIS_VARARGS:
51
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
227 self->mInterface.mVTpointer = &vt_armhf_ellipsis;
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
228 break;
51
9e9d6a90492a - armhf experimental vararg call support
cslag
parents: 47
diff changeset
229 default:
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
230 in_self->mError = DC_ERROR_UNSUPPORTED_MODE;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
231 return;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
232 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
233 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
234