comparison test/suite2_x86win32fast/main.cc @ 0:3e629dc19168

initial from svn dyncall-1745
author Daniel Adler
date Thu, 19 Mar 2015 22:24:28 +0100
parents
children f5577f6bf97a
comparison
equal deleted inserted replaced
-1:000000000000 0:3e629dc19168
1 /*
2
3 Package: dyncall
4 Library: test
5 File: test/suite2_x86win32fast/main.cc
6 Description:
7 License:
8
9 Copyright (c) 2007-2015 Daniel Adler <dadler@uni-goettingen.de>,
10 Tassilo Philipp <tphilipp@potion-studios.com>
11
12 Permission to use, copy, modify, and distribute this software for any
13 purpose with or without fee is hereby granted, provided that the above
14 copyright notice and this permission notice appear in all copies.
15
16 THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
17 WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
18 MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
19 ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
20 WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
21 ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
22 OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
23
24 */
25
26
27
28 #include "../../dyncall/dyncall.h"
29 #include "config.h"
30 #include "../../dyncall/dyncall_value.h"
31 #include "../../dyncall/dyncall_macros.h"
32 #include "funcinfo.h"
33 #include <stdlib.h>
34 #include "../common/platformInit.h"
35 #include "../common/platformInit.c" /* Impl. for functions only used in this translation unit */
36
37
38 int getId();
39 DCpointer getFunc(int x);
40 DCValue* getArg(int pos);
41
42
43
44 DCbool valueBool[MAXARGS];
45 DCchar valueChar[MAXARGS];
46 DCshort valueShort[MAXARGS];
47 DCint valueInt[MAXARGS];
48 DClonglong valueLongLong[MAXARGS];
49 DCdouble valueDouble[MAXARGS];
50 DCpointer valuePointer[MAXARGS];
51 DCfloat valueFloat[MAXARGS];
52
53
54 void clearValues();
55
56 void init()
57 {
58 for (int i = 0 ; i < MAXARGS ; ++i ) {
59
60 valueBool[i] = DCbool( (i % 1) ? DC_TRUE : DC_FALSE );
61 valueChar[i] = DCchar(i);
62 valueShort[i] = DCshort(i);
63 valueInt[i] = DCint(i);
64 valueLongLong[i] = DClonglong(i);
65 valueDouble[i] = DCdouble(i);
66 valuePointer[i] = DCpointer(i);
67 valueFloat[i] = DCfloat(i);
68 }
69 }
70
71 void error(const char* message)
72 {
73 fprintf(stderr, "error: %s\n", message);
74 exit(-1);
75 }
76
77
78 bool test(int x)
79 {
80 bool r = true;
81 clearValues();
82
83 DCCallVM* pCall;
84
85 funcinfo* fi = &gFuncInfos[x];
86
87 const DCsigchar* sig = &fi->sig[2];
88 const DCsigchar* ptr = sig;
89 DCsigchar ch;
90 int pos;
91
92 pos = 0;
93
94 pCall = dcNewCallVM(4096);
95 #ifdef DC__C_GNU
96 dcMode(pCall, DC_CALL_C_X86_WIN32_FAST_GNU);
97 #else
98 dcMode(pCall, DC_CALL_C_X86_WIN32_FAST_MS);
99 #endif
100 dcReset(pCall);
101
102 while ( (ch=*ptr++) != '\0' ) {
103 switch(ch) {
104 case DC_SIGCHAR_BOOL: dcArgBool( pCall, valueBool[pos] ); break;
105 case DC_SIGCHAR_CHAR: dcArgChar( pCall, valueChar[pos] ); break;
106 case DC_SIGCHAR_SHORT: dcArgShort( pCall, valueShort[pos] ); break;
107 case DC_SIGCHAR_INT: dcArgInt( pCall, valueInt[pos] ); break;
108 case DC_SIGCHAR_LONGLONG: dcArgLongLong( pCall, valueLongLong[pos] ); break;
109 case DC_SIGCHAR_FLOAT: dcArgFloat( pCall, valueFloat[pos] ); break;
110 case DC_SIGCHAR_DOUBLE: dcArgDouble( pCall, valueDouble[pos] ); break;
111 case DC_SIGCHAR_POINTER: dcArgPointer( pCall, valuePointer[pos] ); break;
112 default: error("unsupported signature character"); break;
113 }
114 ++pos;
115 }
116
117 dcCallVoid( pCall, fi->funcptr );
118
119
120 if ( getId() == x ) {
121
122 ptr = sig;
123 pos = 0;
124 while( ( ch=*ptr++ ) != '\0' ) {
125
126 switch(ch) {
127 case DC_SIGCHAR_BOOL: if ( getArg(pos)->B != valueBool [pos] ) r = false; break;
128 case DC_SIGCHAR_CHAR: if ( getArg(pos)->c != valueChar [pos] ) r = false; break;
129 case DC_SIGCHAR_SHORT: if ( getArg(pos)->s != valueShort [pos] ) r = false; break;
130 case DC_SIGCHAR_INT: if ( getArg(pos)->i != valueInt [pos] ) r = false; break;
131 case DC_SIGCHAR_LONGLONG: if ( getArg(pos)->L != valueLongLong [pos] ) r = false; break;
132 case DC_SIGCHAR_FLOAT: if ( getArg(pos)->f != valueFloat [pos] ) r = false; break;
133 case DC_SIGCHAR_DOUBLE: if ( getArg(pos)->d != valueDouble[pos] ) r = false; break;
134 case DC_SIGCHAR_POINTER: if ( getArg(pos)->p != valuePointer [pos] ) r = false; break;
135 default: error("unsupported signature character"); break;
136 }
137 ++pos;
138 }
139
140 } else {
141 r = false;
142 }
143
144 printf("%d-%s:%d\n", x, sig, r);
145
146 dcFree(pCall);
147
148 return r;
149 }
150
151
152 bool run_range(int from, int to)
153 {
154 bool r = true;
155 for (int i = from ; i < to ; ++i )
156 r &= test(i);
157 return r;
158 }
159
160 extern "C" {
161
162 int main(int argc, char* argv[])
163 {
164 dcTest_initPlatform();
165
166 bool success = false;
167 init();
168 if (argc == 2) {
169 int index = atoi(argv[1]);
170 success = run_range( index, index+1 );
171 } else if (argc == 3) {
172 int from = atoi(argv[1]);
173 int to = atoi(argv[2])+1;
174 success = run_range(from,to);
175 } else {
176 success = run_range(0,NCASES);
177 }
178
179 printf("result: suite2_x86win32fast: %s\n", success ? "1" : "0");
180
181 dcTest_deInitPlatform();
182
183 return (success) ? 0 : -1;
184 }
185
186 } // extern "C"
187