sljitConfigInternal.h revision 1.7 1 1.1 alnsn /*
2 1.1 alnsn * Stack-less Just-In-Time compiler
3 1.1 alnsn *
4 1.1 alnsn * Copyright 2009-2012 Zoltan Herczeg (hzmester (at) freemail.hu). All rights reserved.
5 1.1 alnsn *
6 1.1 alnsn * Redistribution and use in source and binary forms, with or without modification, are
7 1.1 alnsn * permitted provided that the following conditions are met:
8 1.1 alnsn *
9 1.1 alnsn * 1. Redistributions of source code must retain the above copyright notice, this list of
10 1.1 alnsn * conditions and the following disclaimer.
11 1.1 alnsn *
12 1.1 alnsn * 2. Redistributions in binary form must reproduce the above copyright notice, this list
13 1.1 alnsn * of conditions and the following disclaimer in the documentation and/or other materials
14 1.1 alnsn * provided with the distribution.
15 1.1 alnsn *
16 1.1 alnsn * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER(S) AND CONTRIBUTORS ``AS IS'' AND ANY
17 1.1 alnsn * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
18 1.1 alnsn * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
19 1.1 alnsn * SHALL THE COPYRIGHT HOLDER(S) OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
20 1.1 alnsn * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
21 1.1 alnsn * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
22 1.1 alnsn * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
23 1.1 alnsn * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
24 1.1 alnsn * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25 1.1 alnsn */
26 1.1 alnsn
27 1.1 alnsn #ifndef _SLJIT_CONFIG_INTERNAL_H_
28 1.1 alnsn #define _SLJIT_CONFIG_INTERNAL_H_
29 1.1 alnsn
30 1.1 alnsn /*
31 1.1 alnsn SLJIT defines the following macros depending on the target architecture:
32 1.1 alnsn
33 1.1 alnsn Feature detection (boolean) macros:
34 1.1 alnsn SLJIT_32BIT_ARCHITECTURE : 32 bit architecture
35 1.1 alnsn SLJIT_64BIT_ARCHITECTURE : 64 bit architecture
36 1.7 alnsn SLJIT_WORD_SHIFT : the shift required to apply when accessing a sljit_sw/sljit_uw array by index
37 1.7 alnsn SLJIT_DOUBLE_SHIFT : the shift required to apply when accessing a double array by index
38 1.1 alnsn SLJIT_LITTLE_ENDIAN : little endian architecture
39 1.1 alnsn SLJIT_BIG_ENDIAN : big endian architecture
40 1.1 alnsn SLJIT_UNALIGNED : allows unaligned memory accesses for non-fpu operations (only!)
41 1.1 alnsn SLJIT_INDIRECT_CALL : see SLJIT_FUNC_OFFSET() for more information
42 1.4 alnsn SLJIT_RETURN_ADDRESS_OFFSET : a return instruction always adds this offset to the return address
43 1.1 alnsn
44 1.1 alnsn Types and useful macros:
45 1.7 alnsn sljit_sb, sljit_ub : signed and unsigned 8 bit byte
46 1.7 alnsn sljit_sh, sljit_uh : signed and unsigned 16 bit half-word (short) type
47 1.7 alnsn sljit_si, sljit_ui : signed and unsigned 32 bit integer type
48 1.7 alnsn sljit_sw, sljit_uw : signed and unsigned machine word, enough to store a pointer
49 1.7 alnsn sljit_p : unsgined pointer value (usually the same as sljit_uw, but
50 1.7 alnsn some 64 bit ABIs may use 32 bit pointers)
51 1.7 alnsn sljit_s : single precision floating point value
52 1.7 alnsn sljit_d : double precision floating point value
53 1.1 alnsn SLJIT_CALL : C calling convention define for both calling JIT form C and C callbacks for JIT
54 1.1 alnsn SLJIT_W(number) : defining 64 bit constants on 64 bit architectures (compiler independent helper)
55 1.1 alnsn */
56 1.1 alnsn
57 1.1 alnsn #if !((defined SLJIT_CONFIG_X86_32 && SLJIT_CONFIG_X86_32) \
58 1.1 alnsn || (defined SLJIT_CONFIG_X86_64 && SLJIT_CONFIG_X86_64) \
59 1.1 alnsn || (defined SLJIT_CONFIG_ARM_V5 && SLJIT_CONFIG_ARM_V5) \
60 1.1 alnsn || (defined SLJIT_CONFIG_ARM_V7 && SLJIT_CONFIG_ARM_V7) \
61 1.1 alnsn || (defined SLJIT_CONFIG_ARM_THUMB2 && SLJIT_CONFIG_ARM_THUMB2) \
62 1.7 alnsn || (defined SLJIT_CONFIG_ARM_64 && SLJIT_CONFIG_ARM_64) \
63 1.1 alnsn || (defined SLJIT_CONFIG_PPC_32 && SLJIT_CONFIG_PPC_32) \
64 1.1 alnsn || (defined SLJIT_CONFIG_PPC_64 && SLJIT_CONFIG_PPC_64) \
65 1.1 alnsn || (defined SLJIT_CONFIG_MIPS_32 && SLJIT_CONFIG_MIPS_32) \
66 1.7 alnsn || (defined SLJIT_CONFIG_MIPS_64 && SLJIT_CONFIG_MIPS_64) \
67 1.4 alnsn || (defined SLJIT_CONFIG_SPARC_32 && SLJIT_CONFIG_SPARC_32) \
68 1.7 alnsn || (defined SLJIT_CONFIG_TILEGX && SLJIT_CONFIG_TILEGX) \
69 1.1 alnsn || (defined SLJIT_CONFIG_AUTO && SLJIT_CONFIG_AUTO) \
70 1.1 alnsn || (defined SLJIT_CONFIG_UNSUPPORTED && SLJIT_CONFIG_UNSUPPORTED))
71 1.1 alnsn #error "An architecture must be selected"
72 1.1 alnsn #endif
73 1.1 alnsn
74 1.1 alnsn /* Sanity check. */
75 1.1 alnsn #if (defined SLJIT_CONFIG_X86_32 && SLJIT_CONFIG_X86_32) \
76 1.1 alnsn + (defined SLJIT_CONFIG_X86_64 && SLJIT_CONFIG_X86_64) \
77 1.1 alnsn + (defined SLJIT_CONFIG_ARM_V5 && SLJIT_CONFIG_ARM_V5) \
78 1.1 alnsn + (defined SLJIT_CONFIG_ARM_V7 && SLJIT_CONFIG_ARM_V7) \
79 1.1 alnsn + (defined SLJIT_CONFIG_ARM_THUMB2 && SLJIT_CONFIG_ARM_THUMB2) \
80 1.7 alnsn + (defined SLJIT_CONFIG_ARM_64 && SLJIT_CONFIG_ARM_64) \
81 1.1 alnsn + (defined SLJIT_CONFIG_PPC_32 && SLJIT_CONFIG_PPC_32) \
82 1.1 alnsn + (defined SLJIT_CONFIG_PPC_64 && SLJIT_CONFIG_PPC_64) \
83 1.7 alnsn + (defined SLJIT_CONFIG_TILEGX && SLJIT_CONFIG_TILEGX) \
84 1.1 alnsn + (defined SLJIT_CONFIG_MIPS_32 && SLJIT_CONFIG_MIPS_32) \
85 1.7 alnsn + (defined SLJIT_CONFIG_MIPS_64 && SLJIT_CONFIG_MIPS_64) \
86 1.4 alnsn + (defined SLJIT_CONFIG_SPARC_32 && SLJIT_CONFIG_SPARC_32) \
87 1.1 alnsn + (defined SLJIT_CONFIG_AUTO && SLJIT_CONFIG_AUTO) \
88 1.1 alnsn + (defined SLJIT_CONFIG_UNSUPPORTED && SLJIT_CONFIG_UNSUPPORTED) >= 2
89 1.1 alnsn #error "Multiple architectures are selected"
90 1.1 alnsn #endif
91 1.1 alnsn
92 1.1 alnsn /* Auto select option (requires compiler support) */
93 1.1 alnsn #if (defined SLJIT_CONFIG_AUTO && SLJIT_CONFIG_AUTO)
94 1.1 alnsn
95 1.1 alnsn #ifndef _WIN32
96 1.1 alnsn
97 1.1 alnsn #if defined(__i386__) || defined(__i386)
98 1.1 alnsn #define SLJIT_CONFIG_X86_32 1
99 1.1 alnsn #elif defined(__x86_64__)
100 1.1 alnsn #define SLJIT_CONFIG_X86_64 1
101 1.1 alnsn #elif defined(__arm__) || defined(__ARM__)
102 1.1 alnsn #ifdef __thumb2__
103 1.1 alnsn #define SLJIT_CONFIG_ARM_THUMB2 1
104 1.1 alnsn #elif defined(__ARM_ARCH_7__) || defined(__ARM_ARCH_7A__) || defined(__ARM_ARCH_7R__)
105 1.1 alnsn #define SLJIT_CONFIG_ARM_V7 1
106 1.1 alnsn #else
107 1.1 alnsn #define SLJIT_CONFIG_ARM_V5 1
108 1.1 alnsn #endif
109 1.7 alnsn #elif defined (__aarch64__)
110 1.7 alnsn #define SLJIT_CONFIG_ARM_64 1
111 1.1 alnsn #elif defined(__ppc64__) || defined(__powerpc64__) || defined(_ARCH_PPC64) || (defined(_POWER) && defined(__64BIT__))
112 1.1 alnsn #define SLJIT_CONFIG_PPC_64 1
113 1.1 alnsn #elif defined(__ppc__) || defined(__powerpc__) || defined(_ARCH_PPC) || defined(_ARCH_PWR) || defined(_ARCH_PWR2) || defined(_POWER)
114 1.1 alnsn #define SLJIT_CONFIG_PPC_32 1
115 1.7 alnsn #elif defined(__mips__) && !defined(_LP64)
116 1.1 alnsn #define SLJIT_CONFIG_MIPS_32 1
117 1.7 alnsn #elif defined(__mips64)
118 1.7 alnsn #define SLJIT_CONFIG_MIPS_64 1
119 1.4 alnsn #elif defined(__sparc__) || defined(__sparc)
120 1.4 alnsn #define SLJIT_CONFIG_SPARC_32 1
121 1.7 alnsn #elif defined(__tilegx__)
122 1.7 alnsn #define SLJIT_CONFIG_TILEGX 1
123 1.1 alnsn #else
124 1.1 alnsn /* Unsupported architecture */
125 1.1 alnsn #define SLJIT_CONFIG_UNSUPPORTED 1
126 1.1 alnsn #endif
127 1.1 alnsn
128 1.1 alnsn #else /* !_WIN32 */
129 1.1 alnsn
130 1.1 alnsn #if defined(_M_X64) || defined(__x86_64__)
131 1.1 alnsn #define SLJIT_CONFIG_X86_64 1
132 1.1 alnsn #elif defined(_ARM_)
133 1.1 alnsn #define SLJIT_CONFIG_ARM_V5 1
134 1.1 alnsn #else
135 1.1 alnsn #define SLJIT_CONFIG_X86_32 1
136 1.1 alnsn #endif
137 1.1 alnsn
138 1.1 alnsn #endif /* !WIN32 */
139 1.1 alnsn #endif /* SLJIT_CONFIG_AUTO */
140 1.1 alnsn
141 1.1 alnsn #if (defined SLJIT_CONFIG_UNSUPPORTED && SLJIT_CONFIG_UNSUPPORTED)
142 1.1 alnsn #undef SLJIT_EXECUTABLE_ALLOCATOR
143 1.1 alnsn #endif
144 1.1 alnsn
145 1.1 alnsn #if !(defined SLJIT_STD_MACROS_DEFINED && SLJIT_STD_MACROS_DEFINED)
146 1.1 alnsn
147 1.2 alnsn #ifndef _KERNEL
148 1.1 alnsn /* These libraries are needed for the macros below. */
149 1.1 alnsn #include <stdlib.h>
150 1.1 alnsn #include <string.h>
151 1.2 alnsn #endif
152 1.1 alnsn
153 1.1 alnsn #endif /* STD_MACROS_DEFINED */
154 1.1 alnsn
155 1.1 alnsn /* General macros:
156 1.1 alnsn Note: SLJIT is designed to be independent from them as possible.
157 1.1 alnsn
158 1.1 alnsn In release mode (SLJIT_DEBUG is not defined) only the following macros are needed:
159 1.1 alnsn */
160 1.1 alnsn
161 1.1 alnsn #ifndef SLJIT_MALLOC
162 1.1 alnsn #define SLJIT_MALLOC(size) malloc(size)
163 1.1 alnsn #endif
164 1.1 alnsn
165 1.1 alnsn #ifndef SLJIT_FREE
166 1.1 alnsn #define SLJIT_FREE(ptr) free(ptr)
167 1.1 alnsn #endif
168 1.1 alnsn
169 1.1 alnsn #ifndef SLJIT_MEMMOVE
170 1.1 alnsn #define SLJIT_MEMMOVE(dest, src, len) memmove(dest, src, len)
171 1.1 alnsn #endif
172 1.1 alnsn
173 1.1 alnsn #ifndef SLJIT_ZEROMEM
174 1.1 alnsn #define SLJIT_ZEROMEM(dest, len) memset(dest, 0, len)
175 1.1 alnsn #endif
176 1.1 alnsn
177 1.1 alnsn #if !defined(SLJIT_LIKELY) && !defined(SLJIT_UNLIKELY)
178 1.1 alnsn
179 1.1 alnsn #if defined(__GNUC__) && (__GNUC__ >= 3)
180 1.1 alnsn #define SLJIT_LIKELY(x) __builtin_expect((x), 1)
181 1.1 alnsn #define SLJIT_UNLIKELY(x) __builtin_expect((x), 0)
182 1.1 alnsn #else
183 1.1 alnsn #define SLJIT_LIKELY(x) (x)
184 1.1 alnsn #define SLJIT_UNLIKELY(x) (x)
185 1.1 alnsn #endif
186 1.1 alnsn
187 1.1 alnsn #endif /* !defined(SLJIT_LIKELY) && !defined(SLJIT_UNLIKELY) */
188 1.1 alnsn
189 1.1 alnsn #ifndef SLJIT_INLINE
190 1.7 alnsn /* Inline functions. Some old compilers do not support them. */
191 1.7 alnsn #if defined(__SUNPRO_C) && __SUNPRO_C <= 0x510
192 1.7 alnsn #define SLJIT_INLINE
193 1.7 alnsn #else
194 1.1 alnsn #define SLJIT_INLINE __inline
195 1.1 alnsn #endif
196 1.7 alnsn #endif /* !SLJIT_INLINE */
197 1.1 alnsn
198 1.1 alnsn #ifndef SLJIT_CONST
199 1.1 alnsn /* Const variables. */
200 1.1 alnsn #define SLJIT_CONST const
201 1.1 alnsn #endif
202 1.1 alnsn
203 1.1 alnsn #ifndef SLJIT_UNUSED_ARG
204 1.1 alnsn /* Unused arguments. */
205 1.1 alnsn #define SLJIT_UNUSED_ARG(arg) (void)arg
206 1.1 alnsn #endif
207 1.1 alnsn
208 1.1 alnsn #if (defined SLJIT_CONFIG_STATIC && SLJIT_CONFIG_STATIC)
209 1.1 alnsn /* Static ABI functions. For all-in-one programs. */
210 1.1 alnsn
211 1.1 alnsn #if defined(__GNUC__)
212 1.1 alnsn /* Disable unused warnings in gcc. */
213 1.1 alnsn #define SLJIT_API_FUNC_ATTRIBUTE static __attribute__((unused))
214 1.1 alnsn #else
215 1.1 alnsn #define SLJIT_API_FUNC_ATTRIBUTE static
216 1.1 alnsn #endif
217 1.1 alnsn
218 1.1 alnsn #else
219 1.1 alnsn #define SLJIT_API_FUNC_ATTRIBUTE
220 1.1 alnsn #endif /* (defined SLJIT_CONFIG_STATIC && SLJIT_CONFIG_STATIC) */
221 1.1 alnsn
222 1.1 alnsn #ifndef SLJIT_CACHE_FLUSH
223 1.1 alnsn
224 1.1 alnsn #if (defined SLJIT_CONFIG_X86_32 && SLJIT_CONFIG_X86_32) || (defined SLJIT_CONFIG_X86_64 && SLJIT_CONFIG_X86_64)
225 1.1 alnsn
226 1.1 alnsn /* Not required to implement on archs with unified caches. */
227 1.1 alnsn #define SLJIT_CACHE_FLUSH(from, to)
228 1.1 alnsn
229 1.1 alnsn #elif defined __APPLE__
230 1.1 alnsn
231 1.1 alnsn /* Supported by all macs since Mac OS 10.5.
232 1.1 alnsn However, it does not work on non-jailbroken iOS devices,
233 1.1 alnsn although the compilation is successful. */
234 1.1 alnsn
235 1.1 alnsn #define SLJIT_CACHE_FLUSH(from, to) \
236 1.1 alnsn sys_icache_invalidate((char*)(from), (char*)(to) - (char*)(from))
237 1.1 alnsn
238 1.7 alnsn #elif defined __ANDROID__
239 1.7 alnsn
240 1.7 alnsn /* Android lacks __clear_cache; instead, cacheflush should be used. */
241 1.7 alnsn
242 1.7 alnsn #define SLJIT_CACHE_FLUSH(from, to) \
243 1.7 alnsn cacheflush((long)(from), (long)(to), 0)
244 1.7 alnsn
245 1.1 alnsn #elif (defined SLJIT_CONFIG_PPC_32 && SLJIT_CONFIG_PPC_32) || (defined SLJIT_CONFIG_PPC_64 && SLJIT_CONFIG_PPC_64)
246 1.1 alnsn
247 1.1 alnsn /* The __clear_cache() implementation of GCC is a dummy function on PowerPC. */
248 1.1 alnsn #define SLJIT_CACHE_FLUSH(from, to) \
249 1.1 alnsn ppc_cache_flush((from), (to))
250 1.1 alnsn
251 1.4 alnsn #elif (defined SLJIT_CONFIG_SPARC_32 && SLJIT_CONFIG_SPARC_32)
252 1.4 alnsn
253 1.4 alnsn /* The __clear_cache() implementation of GCC is a dummy function on Sparc. */
254 1.4 alnsn #define SLJIT_CACHE_FLUSH(from, to) \
255 1.4 alnsn sparc_cache_flush((from), (to))
256 1.4 alnsn
257 1.1 alnsn #else
258 1.1 alnsn
259 1.1 alnsn /* Calls __ARM_NR_cacheflush on ARM-Linux. */
260 1.1 alnsn #define SLJIT_CACHE_FLUSH(from, to) \
261 1.1 alnsn __clear_cache((char*)(from), (char*)(to))
262 1.1 alnsn
263 1.1 alnsn #endif
264 1.1 alnsn
265 1.1 alnsn #endif /* !SLJIT_CACHE_FLUSH */
266 1.1 alnsn
267 1.1 alnsn /* 8 bit byte type. */
268 1.1 alnsn typedef unsigned char sljit_ub;
269 1.7 alnsn typedef signed char sljit_sb;
270 1.1 alnsn
271 1.1 alnsn /* 16 bit half-word type. */
272 1.1 alnsn typedef unsigned short int sljit_uh;
273 1.7 alnsn typedef signed short int sljit_sh;
274 1.1 alnsn
275 1.1 alnsn /* 32 bit integer type. */
276 1.1 alnsn typedef unsigned int sljit_ui;
277 1.7 alnsn typedef signed int sljit_si;
278 1.1 alnsn
279 1.1 alnsn /* Machine word type. Can encapsulate a pointer.
280 1.1 alnsn 32 bit for 32 bit machines.
281 1.1 alnsn 64 bit for 64 bit machines. */
282 1.1 alnsn #if (defined SLJIT_CONFIG_UNSUPPORTED && SLJIT_CONFIG_UNSUPPORTED)
283 1.1 alnsn /* Just to have something. */
284 1.1 alnsn #define SLJIT_WORD_SHIFT 0
285 1.1 alnsn typedef unsigned long int sljit_uw;
286 1.7 alnsn typedef long int sljit_sw;
287 1.7 alnsn #elif !(defined SLJIT_CONFIG_X86_64 && SLJIT_CONFIG_X86_64) \
288 1.7 alnsn && !(defined SLJIT_CONFIG_ARM_64 && SLJIT_CONFIG_ARM_64) \
289 1.7 alnsn && !(defined SLJIT_CONFIG_PPC_64 && SLJIT_CONFIG_PPC_64) \
290 1.7 alnsn && !(defined SLJIT_CONFIG_MIPS_64 && SLJIT_CONFIG_MIPS_64) \
291 1.7 alnsn && !(defined SLJIT_CONFIG_TILEGX && SLJIT_CONFIG_TILEGX)
292 1.1 alnsn #define SLJIT_32BIT_ARCHITECTURE 1
293 1.1 alnsn #define SLJIT_WORD_SHIFT 2
294 1.1 alnsn typedef unsigned int sljit_uw;
295 1.7 alnsn typedef int sljit_sw;
296 1.1 alnsn #else
297 1.1 alnsn #define SLJIT_64BIT_ARCHITECTURE 1
298 1.1 alnsn #define SLJIT_WORD_SHIFT 3
299 1.1 alnsn #ifdef _WIN32
300 1.1 alnsn typedef unsigned __int64 sljit_uw;
301 1.7 alnsn typedef __int64 sljit_sw;
302 1.1 alnsn #else
303 1.1 alnsn typedef unsigned long int sljit_uw;
304 1.7 alnsn typedef long int sljit_sw;
305 1.1 alnsn #endif
306 1.1 alnsn #endif
307 1.1 alnsn
308 1.7 alnsn typedef sljit_uw sljit_p;
309 1.7 alnsn
310 1.7 alnsn /* Floating point types. */
311 1.7 alnsn typedef float sljit_s;
312 1.7 alnsn typedef double sljit_d;
313 1.7 alnsn
314 1.7 alnsn /* Shift for pointer sized data. */
315 1.7 alnsn #define SLJIT_POINTER_SHIFT SLJIT_WORD_SHIFT
316 1.7 alnsn
317 1.7 alnsn /* Shift for double precision sized data. */
318 1.7 alnsn #define SLJIT_DOUBLE_SHIFT 3
319 1.1 alnsn
320 1.1 alnsn #ifndef SLJIT_W
321 1.1 alnsn
322 1.1 alnsn /* Defining long constants. */
323 1.1 alnsn #if (defined SLJIT_64BIT_ARCHITECTURE && SLJIT_64BIT_ARCHITECTURE)
324 1.1 alnsn #define SLJIT_W(w) (w##ll)
325 1.1 alnsn #else
326 1.1 alnsn #define SLJIT_W(w) (w)
327 1.1 alnsn #endif
328 1.1 alnsn
329 1.1 alnsn #endif /* !SLJIT_W */
330 1.1 alnsn
331 1.1 alnsn #ifndef SLJIT_CALL
332 1.1 alnsn
333 1.1 alnsn /* ABI (Application Binary Interface) types. */
334 1.1 alnsn #if (defined SLJIT_CONFIG_X86_32 && SLJIT_CONFIG_X86_32)
335 1.1 alnsn
336 1.7 alnsn #if defined(__GNUC__) && !defined(__APPLE__)
337 1.1 alnsn
338 1.1 alnsn #define SLJIT_CALL __attribute__ ((fastcall))
339 1.1 alnsn #define SLJIT_X86_32_FASTCALL 1
340 1.1 alnsn
341 1.7 alnsn #elif defined(_MSC_VER)
342 1.7 alnsn
343 1.7 alnsn #define SLJIT_CALL __fastcall
344 1.7 alnsn #define SLJIT_X86_32_FASTCALL 1
345 1.7 alnsn
346 1.7 alnsn #elif defined(__BORLANDC__)
347 1.1 alnsn
348 1.1 alnsn #define SLJIT_CALL __msfastcall
349 1.1 alnsn #define SLJIT_X86_32_FASTCALL 1
350 1.1 alnsn
351 1.7 alnsn #else /* Unknown compiler. */
352 1.7 alnsn
353 1.6 alnsn /* The cdecl attribute is the default. */
354 1.6 alnsn #define SLJIT_CALL
355 1.7 alnsn
356 1.1 alnsn #endif
357 1.1 alnsn
358 1.7 alnsn #else /* Non x86-32 architectures. */
359 1.1 alnsn
360 1.1 alnsn #define SLJIT_CALL
361 1.1 alnsn
362 1.1 alnsn #endif /* SLJIT_CONFIG_X86_32 */
363 1.1 alnsn
364 1.1 alnsn #endif /* !SLJIT_CALL */
365 1.1 alnsn
366 1.1 alnsn #if !defined(SLJIT_BIG_ENDIAN) && !defined(SLJIT_LITTLE_ENDIAN)
367 1.1 alnsn
368 1.7 alnsn /* These macros are useful for the applications. */
369 1.4 alnsn #if (defined SLJIT_CONFIG_PPC_32 && SLJIT_CONFIG_PPC_32) \
370 1.7 alnsn || (defined SLJIT_CONFIG_PPC_64 && SLJIT_CONFIG_PPC_64)
371 1.7 alnsn
372 1.7 alnsn #ifdef __LITTLE_ENDIAN__
373 1.7 alnsn #define SLJIT_LITTLE_ENDIAN 1
374 1.7 alnsn #else
375 1.1 alnsn #define SLJIT_BIG_ENDIAN 1
376 1.7 alnsn #endif
377 1.1 alnsn
378 1.7 alnsn #elif (defined SLJIT_CONFIG_MIPS_32 && SLJIT_CONFIG_MIPS_32) \
379 1.7 alnsn || (defined SLJIT_CONFIG_MIPS_64 && SLJIT_CONFIG_MIPS_64)
380 1.1 alnsn
381 1.1 alnsn #ifdef __MIPSEL__
382 1.1 alnsn #define SLJIT_LITTLE_ENDIAN 1
383 1.1 alnsn #else
384 1.1 alnsn #define SLJIT_BIG_ENDIAN 1
385 1.1 alnsn #endif
386 1.1 alnsn
387 1.7 alnsn #elif (defined SLJIT_CONFIG_SPARC_32 && SLJIT_CONFIG_SPARC_32)
388 1.7 alnsn
389 1.7 alnsn #define SLJIT_BIG_ENDIAN 1
390 1.7 alnsn
391 1.1 alnsn #else
392 1.1 alnsn #define SLJIT_LITTLE_ENDIAN 1
393 1.1 alnsn #endif
394 1.1 alnsn
395 1.1 alnsn #endif /* !defined(SLJIT_BIG_ENDIAN) && !defined(SLJIT_LITTLE_ENDIAN) */
396 1.1 alnsn
397 1.1 alnsn /* Sanity check. */
398 1.1 alnsn #if (defined SLJIT_BIG_ENDIAN && SLJIT_BIG_ENDIAN) && (defined SLJIT_LITTLE_ENDIAN && SLJIT_LITTLE_ENDIAN)
399 1.1 alnsn #error "Exactly one endianness must be selected"
400 1.1 alnsn #endif
401 1.1 alnsn
402 1.1 alnsn #if !(defined SLJIT_BIG_ENDIAN && SLJIT_BIG_ENDIAN) && !(defined SLJIT_LITTLE_ENDIAN && SLJIT_LITTLE_ENDIAN)
403 1.1 alnsn #error "Exactly one endianness must be selected"
404 1.1 alnsn #endif
405 1.1 alnsn
406 1.4 alnsn #ifndef SLJIT_INDIRECT_CALL
407 1.7 alnsn #if ((defined SLJIT_CONFIG_PPC_64 && SLJIT_CONFIG_PPC_64) && (defined SLJIT_BIG_ENDIAN && SLJIT_BIG_ENDIAN)) \
408 1.7 alnsn || ((defined SLJIT_CONFIG_PPC_32 && SLJIT_CONFIG_PPC_32) && defined _AIX)
409 1.1 alnsn /* It seems certain ppc compilers use an indirect addressing for functions
410 1.1 alnsn which makes things complicated. */
411 1.1 alnsn #define SLJIT_INDIRECT_CALL 1
412 1.1 alnsn #endif
413 1.4 alnsn #endif /* SLJIT_INDIRECT_CALL */
414 1.4 alnsn
415 1.4 alnsn #ifndef SLJIT_RETURN_ADDRESS_OFFSET
416 1.4 alnsn #if (defined SLJIT_CONFIG_SPARC_32 && SLJIT_CONFIG_SPARC_32)
417 1.4 alnsn #define SLJIT_RETURN_ADDRESS_OFFSET 8
418 1.4 alnsn #else
419 1.4 alnsn #define SLJIT_RETURN_ADDRESS_OFFSET 0
420 1.4 alnsn #endif
421 1.4 alnsn #endif /* SLJIT_RETURN_ADDRESS_OFFSET */
422 1.1 alnsn
423 1.1 alnsn #ifndef SLJIT_SSE2
424 1.1 alnsn
425 1.1 alnsn #if (defined SLJIT_CONFIG_X86_32 && SLJIT_CONFIG_X86_32) || (defined SLJIT_CONFIG_X86_64 && SLJIT_CONFIG_X86_64)
426 1.1 alnsn /* Turn on SSE2 support on x86. */
427 1.1 alnsn #define SLJIT_SSE2 1
428 1.1 alnsn
429 1.1 alnsn #if (defined SLJIT_CONFIG_X86_32 && SLJIT_CONFIG_X86_32)
430 1.1 alnsn /* Auto detect SSE2 support using CPUID.
431 1.1 alnsn On 64 bit x86 cpus, sse2 must be present. */
432 1.1 alnsn #define SLJIT_DETECT_SSE2 1
433 1.1 alnsn #endif
434 1.1 alnsn
435 1.1 alnsn #endif /* (defined SLJIT_CONFIG_X86_32 && SLJIT_CONFIG_X86_32) || (defined SLJIT_CONFIG_X86_64 && SLJIT_CONFIG_X86_64) */
436 1.1 alnsn
437 1.1 alnsn #endif /* !SLJIT_SSE2 */
438 1.1 alnsn
439 1.1 alnsn #ifndef SLJIT_UNALIGNED
440 1.1 alnsn
441 1.1 alnsn #if (defined SLJIT_CONFIG_X86_32 && SLJIT_CONFIG_X86_32) \
442 1.1 alnsn || (defined SLJIT_CONFIG_X86_64 && SLJIT_CONFIG_X86_64) \
443 1.1 alnsn || (defined SLJIT_CONFIG_ARM_V7 && SLJIT_CONFIG_ARM_V7) \
444 1.1 alnsn || (defined SLJIT_CONFIG_ARM_THUMB2 && SLJIT_CONFIG_ARM_THUMB2) \
445 1.7 alnsn || (defined SLJIT_CONFIG_ARM_64 && SLJIT_CONFIG_ARM_64) \
446 1.1 alnsn || (defined SLJIT_CONFIG_PPC_32 && SLJIT_CONFIG_PPC_32) \
447 1.1 alnsn || (defined SLJIT_CONFIG_PPC_64 && SLJIT_CONFIG_PPC_64)
448 1.1 alnsn #define SLJIT_UNALIGNED 1
449 1.1 alnsn #endif
450 1.1 alnsn
451 1.1 alnsn #endif /* !SLJIT_UNALIGNED */
452 1.1 alnsn
453 1.1 alnsn #if (defined SLJIT_EXECUTABLE_ALLOCATOR && SLJIT_EXECUTABLE_ALLOCATOR)
454 1.1 alnsn SLJIT_API_FUNC_ATTRIBUTE void* sljit_malloc_exec(sljit_uw size);
455 1.1 alnsn SLJIT_API_FUNC_ATTRIBUTE void sljit_free_exec(void* ptr);
456 1.7 alnsn SLJIT_API_FUNC_ATTRIBUTE void sljit_free_unused_memory_exec(void);
457 1.1 alnsn #define SLJIT_MALLOC_EXEC(size) sljit_malloc_exec(size)
458 1.1 alnsn #define SLJIT_FREE_EXEC(ptr) sljit_free_exec(ptr)
459 1.1 alnsn #endif
460 1.1 alnsn
461 1.7 alnsn #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
462 1.3 alnsn #ifdef _KERNEL
463 1.3 alnsn #include <sys/systm.h>
464 1.3 alnsn #else
465 1.1 alnsn #include <stdio.h>
466 1.1 alnsn #endif
467 1.3 alnsn #endif
468 1.1 alnsn
469 1.1 alnsn #if (defined SLJIT_DEBUG && SLJIT_DEBUG)
470 1.1 alnsn
471 1.7 alnsn #if !defined(SLJIT_ASSERT) || !defined(SLJIT_ASSERT_STOP)
472 1.7 alnsn
473 1.7 alnsn /* SLJIT_HALT_PROCESS must halt the process. */
474 1.7 alnsn #ifndef SLJIT_HALT_PROCESS
475 1.7 alnsn #include <stdlib.h>
476 1.7 alnsn
477 1.7 alnsn #define SLJIT_HALT_PROCESS() \
478 1.7 alnsn abort();
479 1.7 alnsn #endif /* !SLJIT_HALT_PROCESS */
480 1.7 alnsn
481 1.7 alnsn #include <stdio.h>
482 1.7 alnsn
483 1.7 alnsn #endif /* !SLJIT_ASSERT || !SLJIT_ASSERT_STOP */
484 1.7 alnsn
485 1.1 alnsn /* Feel free to redefine these two macros. */
486 1.1 alnsn #ifndef SLJIT_ASSERT
487 1.1 alnsn
488 1.5 alnsn #include <assert.h>
489 1.5 alnsn #include <stdlib.h>
490 1.1 alnsn
491 1.5 alnsn #define SLJIT_HALT_PROCESS() abort()
492 1.5 alnsn
493 1.5 alnsn #define SLJIT_ASSERT(x) assert(x)
494 1.1 alnsn
495 1.1 alnsn #endif /* !SLJIT_ASSERT */
496 1.1 alnsn
497 1.1 alnsn #ifndef SLJIT_ASSERT_STOP
498 1.1 alnsn
499 1.1 alnsn #define SLJIT_ASSERT_STOP() \
500 1.1 alnsn do { \
501 1.1 alnsn printf("Should never been reached " __FILE__ ":%d\n", __LINE__); \
502 1.1 alnsn SLJIT_HALT_PROCESS(); \
503 1.1 alnsn } while (0)
504 1.1 alnsn
505 1.1 alnsn #endif /* !SLJIT_ASSERT_STOP */
506 1.1 alnsn
507 1.1 alnsn #else /* (defined SLJIT_DEBUG && SLJIT_DEBUG) */
508 1.1 alnsn
509 1.7 alnsn /* Forcing empty, but valid statements. */
510 1.1 alnsn #undef SLJIT_ASSERT
511 1.1 alnsn #undef SLJIT_ASSERT_STOP
512 1.1 alnsn
513 1.1 alnsn #define SLJIT_ASSERT(x) \
514 1.1 alnsn do { } while (0)
515 1.1 alnsn #define SLJIT_ASSERT_STOP() \
516 1.1 alnsn do { } while (0)
517 1.1 alnsn
518 1.1 alnsn #endif /* (defined SLJIT_DEBUG && SLJIT_DEBUG) */
519 1.1 alnsn
520 1.1 alnsn #ifndef SLJIT_COMPILE_ASSERT
521 1.1 alnsn
522 1.1 alnsn /* Should be improved eventually. */
523 1.1 alnsn #define SLJIT_COMPILE_ASSERT(x, description) \
524 1.1 alnsn SLJIT_ASSERT(x)
525 1.1 alnsn
526 1.1 alnsn #endif /* !SLJIT_COMPILE_ASSERT */
527 1.1 alnsn
528 1.1 alnsn #endif
529