configure.in: if byte order is unknown or ill defined, don't define any
[nasm.git] / compiler.h
blob310e79b962d369d623c3523dc914deadbf2dc08b
1 /* ----------------------------------------------------------------------- *
2 *
3 * Copyright 2007-2016 The NASM Authors - All Rights Reserved
4 * See the file AUTHORS included with the NASM distribution for
5 * the specific copyright holders.
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following
9 * conditions are met:
11 * * Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * * Redistributions in binary form must reproduce the above
14 * copyright notice, this list of conditions and the following
15 * disclaimer in the documentation and/or other materials provided
16 * with the distribution.
18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
19 * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
20 * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
21 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
22 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
23 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
25 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
26 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
29 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
30 * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 * ----------------------------------------------------------------------- */
35 * compiler.h
37 * Compiler-specific macros for NASM. Feel free to add support for
38 * other compilers in here.
40 * This header file should be included before any other header.
43 #ifndef NASM_COMPILER_H
44 #define NASM_COMPILER_H 1
46 #ifdef __DJGPP__
47 /* DJGPP has header file problems if __STRICT_ANSI__ is defined */
48 # undef __STRICT_ANSI__
49 #endif
51 /* On Microsoft platforms we support multibyte character sets in filenames */
52 #define _MBCS 1
54 #ifdef HAVE_CONFIG_H
55 # include "config.h"
56 /* autoconf doesn't define these if they are redundant, but we want to
57 be able to #ifdef them... */
58 #else
59 /* Default these to unsupported unless we have config.h */
60 # ifndef inline
61 # define inline
62 # endif
63 # ifndef restrict
64 # define restrict
65 # endif
66 #endif /* HAVE_CONFIG_H */
68 /* This is required to get the standard <inttypes.h> macros when compiling
69 with a C++ compiler. This must be defined *before* <inttypes.h> is
70 included, directly or indirectly. */
71 #define __STDC_CONSTANT_MACROS 1
72 #define __STDC_LIMIT_MACROS 1
73 #define __STDC_FORMAT_MACROS 1
75 #ifdef __GNUC__
76 # define _unused __attribute__((unused))
77 #else
78 # define _unused
79 #endif
81 /* Some versions of MSVC have these only with underscores in front */
82 #include <stddef.h>
83 #include <stdarg.h>
84 #include <stdio.h>
86 #ifndef HAVE_SNPRINTF
87 # ifdef HAVE__SNPRINTF
88 # define snprintf _snprintf
89 # else
90 int snprintf(char *, size_t, const char *, ...);
91 # endif
92 #endif
94 #ifndef HAVE_VSNPRINTF
95 # ifdef HAVE__VSNPRINTF
96 # define vsnprintf _vsnprintf
97 # else
98 int vsnprintf(char *, size_t, const char *, va_list);
99 # endif
100 #endif
102 /* Missing fseeko/ftello */
103 #ifndef HAVE_FSEEKO
104 # undef off_t /* Just in case it is a macro */
105 # ifdef HAVE__FSEEKI64
106 # define fseeko _fseeki64
107 # define ftello _ftelli64
108 # define off_t int64_t
109 # else
110 # define fseeko fseek
111 # define ftello ftell
112 # define off_t long
113 # endif
114 #endif
116 #if !defined(HAVE_STRLCPY) || !HAVE_DECL_STRLCPY
117 size_t strlcpy(char *, const char *, size_t);
118 #endif
120 #ifndef __cplusplus /* C++ has false, true, bool as keywords */
121 # ifdef HAVE_STDBOOL_H
122 # include <stdbool.h>
123 # elif defined(HAVE__BOOL)
124 # typedef _Bool bool
125 # define false 0
126 # define true 1
127 # else
128 /* This is sort of dangerous, since casts will behave different than
129 casting to the standard boolean type. Always use !!, not (bool). */
130 typedef enum bool { false, true } bool;
131 # endif
132 #endif
134 /* Provide a substitute for offsetof() if we don't have one. This
135 variant works on most (but not *all*) systems... */
136 #ifndef offsetof
137 # define offsetof(t,m) ((size_t)&(((t *)0)->m))
138 #endif
140 /* The container_of construct: if p is a pointer to member m of
141 container class c, then return a pointer to the container of which
142 *p is a member. */
143 #ifndef container_of
144 # define container_of(p, c, m) ((c *)((char *)(p) - offsetof(c,m)))
145 #endif
147 /* Some misguided platforms hide the defs for these */
148 #if defined(HAVE_STRCASECMP) && !HAVE_DECL_STRCASECMP
149 int strcasecmp(const char *, const char *);
150 #endif
152 #if defined(HAVE_STRICMP) && !HAVE_DECL_STRICMP
153 int stricmp(const char *, const char *);
154 #endif
156 #if defined(HAVE_STRNCASECMP) && !HAVE_DECL_STRNCASECMP
157 int strncasecmp(const char *, const char *, size_t);
158 #endif
160 #if defined(HAVE_STRNICMP) && !HAVE_DECL_STRNICMP
161 int strnicmp(const char *, const char *, size_t);
162 #endif
164 #if defined(HAVE_STRSEP) && !HAVE_DECL_STRSEP
165 char *strsep(char **, const char *);
166 #endif
169 * Define this to 1 for faster performance if this is a littleendian
170 * platform which can do unaligned memory references. It is safe
171 * to leave it defined to 0 even if that is true.
173 #if defined(__386__) || defined(__i386__) || defined(__x86_64__)
174 # define X86_MEMORY 1
175 # ifndef WORDS_LITTLEENDIAN
176 # define WORDS_LITTLEENDIAN 1
177 # endif
178 #else
179 # define X86_MEMORY 0
180 #endif
183 * Hints to the compiler that a particular branch of code is more or
184 * less likely to be taken.
186 #if defined(__GNUC__) && __GNUC__ >= 3
187 # define likely(x) __builtin_expect(!!(x), 1)
188 # define unlikely(x) __builtin_expect(!!(x), 0)
189 #else
190 # define likely(x) (!!(x))
191 # define unlikely(x) (!!(x))
192 #endif
195 * How to tell the compiler that a function doesn't return
197 #ifdef __GNUC__
198 # define no_return void __attribute__((noreturn))
199 #else
200 # define no_return void
201 #endif
204 * How to tell the compiler that a function takes a printf-like string
206 #ifdef __GNUC__
207 # define printf_func(fmt, list) __attribute__((format(printf, fmt, list)))
208 #else
209 # define printf_func(fmt, list)
210 #endif
212 #endif /* NASM_COMPILER_H */