blob: 74e5101f001d3fbf857f7e261d23f5b0e24fca8c [file] [log] [blame]
H. Peter Anvinc1494ac2007-04-13 19:58:42 +00001/* ----------------------------------------------------------------------- *
H. Peter Anvin (Intel)65ab3ab2020-06-30 10:14:21 -07002 *
H. Peter Anvin (Intel)178148c2020-07-06 17:13:02 -07003 * Copyright 2007-2020 The NASM Authors - All Rights Reserved
H. Peter Anvin9e6747c2009-06-28 17:13:04 -07004 * See the file AUTHORS included with the NASM distribution for
5 * the specific copyright holders.
H. Peter Anvinc1494ac2007-04-13 19:58:42 +00006 *
H. Peter Anvin9e6747c2009-06-28 17:13:04 -07007 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following
9 * conditions are met:
H. Peter Anvinc1494ac2007-04-13 19:58:42 +000010 *
H. Peter Anvin9e6747c2009-06-28 17:13:04 -070011 * * 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.
H. Peter Anvin (Intel)65ab3ab2020-06-30 10:14:21 -070017 *
H. Peter Anvin9e6747c2009-06-28 17:13:04 -070018 * 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.
H. Peter Anvinc1494ac2007-04-13 19:58:42 +000031 *
32 * ----------------------------------------------------------------------- */
33
34/*
35 * compiler.h
36 *
37 * Compiler-specific macros for NASM. Feel free to add support for
38 * other compilers in here.
H. Peter Anvinfe501952007-10-02 21:53:51 -070039 *
40 * This header file should be included before any other header.
H. Peter Anvinc1494ac2007-04-13 19:58:42 +000041 */
42
H. Peter Anvinfe501952007-10-02 21:53:51 -070043#ifndef NASM_COMPILER_H
44#define NASM_COMPILER_H 1
H. Peter Anvinc40f89e2007-04-13 20:06:41 +000045
H. Peter Anvin2fc232b2016-07-14 13:51:01 -070046/*
47 * At least DJGPP and Cygwin have broken header files if __STRICT_ANSI__
48 * is defined.
49 */
50#ifdef __GNUC__
H. Peter Anvine8677d62016-01-27 14:29:40 -080051# undef __STRICT_ANSI__
52#endif
53
H. Peter Anvinb423c022016-02-18 11:57:53 -080054/* On Microsoft platforms we support multibyte character sets in filenames */
55#define _MBCS 1
56
H. Peter Anvinc40f89e2007-04-13 20:06:41 +000057#ifdef HAVE_CONFIG_H
H. Peter Anvin397c1692016-10-04 17:01:59 -070058# include "config/config.h"
H. Peter Anvin253a4e72008-06-10 13:00:27 -070059#else
H. Peter Anvin (Intel)8b6e6bf2019-08-16 00:08:27 -070060# if defined(_MSC_VER) && (_MSC_VER >= 1310)
61# include "config/msvc.h"
62# elif defined(__WATCOMC__)
63# include "config/watcom.h"
64# else
65# include "config/unknown.h"
66# endif
67/* This unconditionally defines some macros we really want */
68# include "config/unconfig.h"
H. Peter Anvin397c1692016-10-04 17:01:59 -070069#endif /* Configuration file */
H. Peter Anvinc1494ac2007-04-13 19:58:42 +000070
H. Peter Anvin687b3632007-10-11 12:50:24 -070071/* This is required to get the standard <inttypes.h> macros when compiling
72 with a C++ compiler. This must be defined *before* <inttypes.h> is
73 included, directly or indirectly. */
74#define __STDC_CONSTANT_MACROS 1
75#define __STDC_LIMIT_MACROS 1
76#define __STDC_FORMAT_MACROS 1
77
H. Peter Anvin3ef4f002016-03-08 12:14:55 -080078#ifdef HAVE_INTTYPES_H
79# include <inttypes.h>
80#else
81# include "nasmint.h"
82#endif
83
H. Peter Anvinabd28c92016-12-20 02:29:58 -080084#include <assert.h>
H. Peter Anvin304b6052007-09-28 10:50:20 -070085#include <stddef.h>
86#include <stdarg.h>
H. Peter Anvinfe501952007-10-02 21:53:51 -070087#include <stdio.h>
H. Peter Anvin (Intel)eb5b3ae2018-12-12 14:34:34 -080088#include <stdlib.h>
H. Peter Anvin2e53f272018-12-26 06:32:37 -080089#include <string.h>
H. Peter Anvin9b4b92b2017-02-20 00:36:53 -080090#include <limits.h>
H. Peter Anvin (Intel)5d68f982020-06-01 12:32:35 -070091#include <errno.h>
H. Peter Anvinb8af9aa2007-09-17 13:53:14 -070092
H. Peter Anvin4c50b6c2018-12-27 12:46:55 -080093#ifdef HAVE_STRINGS_H
94# include <strings.h>
95#endif
H. Peter Anvin4c9132e2016-10-19 13:13:38 -070096#ifdef HAVE_SYS_TYPES_H
97# include <sys/types.h>
98#endif
H. Peter Anvin573112e2017-04-24 13:28:14 -070099
H. Peter Anvind3e22572017-04-24 12:58:30 -0700100#ifdef HAVE_ENDIAN_H
101# include <endian.h>
H. Peter Anvin573112e2017-04-24 13:28:14 -0700102#elif defined(HAVE_SYS_ENDIAN_H)
103# include <sys/endian.h>
104#elif defined(HAVE_MACHINE_ENDIAN_H)
105# include <machine/endian.h>
H. Peter Anvind3e22572017-04-24 12:58:30 -0700106#endif
107
108/*
H. Peter Anvin53cd7c72017-04-25 12:51:17 -0700109 * If we have BYTE_ORDER defined, or the compiler provides
110 * __BIG_ENDIAN__ or __LITTLE_ENDIAN__, trust it over what autoconf
111 * came up with, especially since autoconf obviously can't figure
112 * things out for a universal compiler.
H. Peter Anvind3e22572017-04-24 12:58:30 -0700113 */
H. Peter Anvin53cd7c72017-04-25 12:51:17 -0700114#if defined(__BIG_ENDIAN__) && !defined(__LITTLE_ENDIAN__)
115# undef WORDS_LITTLEENDIAN
116# undef WORDS_BIGENDIAN
117# define WORDS_BIGENDIAN 1
118#elif defined(__LITTLE_ENDIAN__) && !defined(__BIG_ENDIAN__)
119# undef WORDS_LITTLEENDIAN
120# undef WORDS_BIGENDIAN
121# define WORDS_LITTLEENDIAN 1
122#elif defined(BYTE_ORDER) && defined(LITTLE_ENDIAN) && defined(BIG_ENDIAN)
H. Peter Anvind3e22572017-04-24 12:58:30 -0700123# undef WORDS_LITTLEENDIAN
124# undef WORDS_BIGENDIAN
125# if BYTE_ORDER == LITTLE_ENDIAN
126# define WORDS_LITTLEENDIAN 1
127# elif BYTE_ORDER == BIG_ENDIAN
128# define WORDS_BIGENDIAN 1
129# endif
130#endif
131
132/*
133 * Define this to 1 for faster performance if this is a littleendian
H. Peter Anvin53cd7c72017-04-25 12:51:17 -0700134 * platform *and* it can do arbitrary unaligned memory references. It
135 * is safe to leave it defined to 0 even if that is true.
H. Peter Anvind3e22572017-04-24 12:58:30 -0700136 */
137#if defined(__386__) || defined(__i386__) || defined(__x86_64__) \
138 || defined(_M_IX86) || defined(_M_X64)
139# define X86_MEMORY 1
H. Peter Anvin53cd7c72017-04-25 12:51:17 -0700140# undef WORDS_BIGENDIAN
141# undef WORDS_LITTLEENDIAN
142# define WORDS_LITTLEENDIAN 1
H. Peter Anvind3e22572017-04-24 12:58:30 -0700143#else
144# define X86_MEMORY 0
145#endif
H. Peter Anvin4c9132e2016-10-19 13:13:38 -0700146
H. Peter Anvin3ef4f002016-03-08 12:14:55 -0800147/* Some versions of MSVC have these only with underscores in front */
H. Peter Anvin304b6052007-09-28 10:50:20 -0700148#ifndef HAVE_SNPRINTF
149# ifdef HAVE__SNPRINTF
150# define snprintf _snprintf
151# else
152int snprintf(char *, size_t, const char *, ...);
153# endif
H. Peter Anvinb8af9aa2007-09-17 13:53:14 -0700154#endif
155
H. Peter Anvin304b6052007-09-28 10:50:20 -0700156#ifndef HAVE_VSNPRINTF
Cyrill Gorcunovb2c34492014-11-26 10:44:19 +0300157# ifdef HAVE__VSNPRINTF
H. Peter Anvin304b6052007-09-28 10:50:20 -0700158# define vsnprintf _vsnprintf
159# else
160int vsnprintf(char *, size_t, const char *, va_list);
161# endif
H. Peter Anvinb8af9aa2007-09-17 13:53:14 -0700162#endif
163
H. Peter Anvin2958bcc2017-02-23 19:23:10 -0800164#if !defined(HAVE_STRLCPY) || !HAVE_DECL_STRLCPY
H. Peter Anvineaa68f12009-08-10 15:56:52 -0700165size_t strlcpy(char *, const char *, size_t);
166#endif
167
H. Peter Anvin81b62b92017-12-20 13:33:49 -0800168#if !defined(HAVE_STRCHRNUL) || !HAVE_DECL_STRCHRNUL
169char *strrchrnul(const char *, int);
170#endif
171
H. Peter Anvin6867acc2007-10-10 14:58:45 -0700172#ifndef __cplusplus /* C++ has false, true, bool as keywords */
H. Peter Anvind338b372016-02-18 00:54:30 -0800173# ifdef HAVE_STDBOOL_H
H. Peter Anvin6867acc2007-10-10 14:58:45 -0700174# include <stdbool.h>
H. Peter Anvind338b372016-02-18 00:54:30 -0800175# elif defined(HAVE__BOOL)
Ozkan Sezer63cacad2019-08-09 23:50:20 +0300176 typedef _Bool bool;
H. Peter Anvind338b372016-02-18 00:54:30 -0800177# define false 0
178# define true 1
H. Peter Anvin6867acc2007-10-10 14:58:45 -0700179# else
H. Peter Anvin253a4e72008-06-10 13:00:27 -0700180/* This is sort of dangerous, since casts will behave different than
181 casting to the standard boolean type. Always use !!, not (bool). */
182typedef enum bool { false, true } bool;
H. Peter Anvin6867acc2007-10-10 14:58:45 -0700183# endif
184#endif
185
H. Peter Anvin (Intel)178148c2020-07-06 17:13:02 -0700186/* Create a NULL pointer of the same type as the address of
187 the argument, without actually evaluating said argument. */
188#define nullas(p) (0 ? &(p) : NULL)
189
190/* Convert an offsetted NULL pointer dereference to a size_t offset.
191 Technically non-portable as taking the offset from a NULL pointer
192 is undefined behavior, but... */
193#define null_offset(p) ((size_t)((const char *)&(p) - (const char *)NULL))
194
H. Peter Anvin9656a582008-10-30 10:52:08 -0700195/* Provide a substitute for offsetof() if we don't have one. This
196 variant works on most (but not *all*) systems... */
197#ifndef offsetof
H. Peter Anvin (Intel)178148c2020-07-06 17:13:02 -0700198# define offsetof(t,m) null_offset(((t *)NULL)->m)
H. Peter Anvin9656a582008-10-30 10:52:08 -0700199#endif
200
H. Peter Anvin (Intel)30844a42020-07-06 12:39:14 -0700201/* If typeof is defined as a macro, assume we have typeof even if
202 HAVE_TYPEOF is not declared (e.g. due to not using autoconf.) */
203#ifdef typeof
204# define HAVE_TYPEOF 1
205#endif
206
207/* This is like offsetof(), but takes an object rather than a type. */
H. Peter Anvin (Intel)ce19a522018-12-14 00:27:59 -0800208#ifndef offsetin
H. Peter Anvin (Intel)30844a42020-07-06 12:39:14 -0700209# ifdef HAVE_TYPEOF
210# define offsetin(p,m) offsetof(typeof(p),m)
211# else
H. Peter Anvin (Intel)178148c2020-07-06 17:13:02 -0700212# define offsetin(p,m) null_offset(nullas(p)->m)
H. Peter Anvin (Intel)13486272020-07-06 12:50:12 -0700213# endif
H. Peter Anvin (Intel)ce19a522018-12-14 00:27:59 -0800214#endif
215
H. Peter Anvin9656a582008-10-30 10:52:08 -0700216/* The container_of construct: if p is a pointer to member m of
217 container class c, then return a pointer to the container of which
218 *p is a member. */
219#ifndef container_of
220# define container_of(p, c, m) ((c *)((char *)(p) - offsetof(c,m)))
221#endif
222
H. Peter Anvinc13d31a2007-10-26 18:49:29 -0700223/* Some misguided platforms hide the defs for these */
H. Peter Anvin2958bcc2017-02-23 19:23:10 -0800224#if defined(HAVE_STRCASECMP) && !HAVE_DECL_STRCASECMP
H. Peter Anvinc13d31a2007-10-26 18:49:29 -0700225int strcasecmp(const char *, const char *);
226#endif
227
H. Peter Anvin2958bcc2017-02-23 19:23:10 -0800228#if defined(HAVE_STRICMP) && !HAVE_DECL_STRICMP
H. Peter Anvinc13d31a2007-10-26 18:49:29 -0700229int stricmp(const char *, const char *);
230#endif
231
H. Peter Anvin2958bcc2017-02-23 19:23:10 -0800232#if defined(HAVE_STRNCASECMP) && !HAVE_DECL_STRNCASECMP
H. Peter Anvinc13d31a2007-10-26 18:49:29 -0700233int strncasecmp(const char *, const char *, size_t);
234#endif
235
H. Peter Anvin2958bcc2017-02-23 19:23:10 -0800236#if defined(HAVE_STRNICMP) && !HAVE_DECL_STRNICMP
H. Peter Anvinc13d31a2007-10-26 18:49:29 -0700237int strnicmp(const char *, const char *, size_t);
238#endif
239
H. Peter Anvin2958bcc2017-02-23 19:23:10 -0800240#if defined(HAVE_STRSEP) && !HAVE_DECL_STRSEP
H. Peter Anvinc13d31a2007-10-26 18:49:29 -0700241char *strsep(char **, const char *);
242#endif
243
H. Peter Anvin2958bcc2017-02-23 19:23:10 -0800244#if !HAVE_DECL_STRNLEN
245size_t strnlen(const char *s, size_t maxlen);
246#endif
247
H. Peter Anvin06f72bb2018-12-26 06:22:47 -0800248#ifndef HAVE_MEMPCPY
249static inline void *mempcpy(void *dst, const void *src, size_t n)
250{
H. Peter Anvin38a96f02018-12-26 06:49:18 -0800251 return (char *)memcpy(dst, src, n) + n;
H. Peter Anvin06f72bb2018-12-26 06:22:47 -0800252}
253#endif
254
H. Peter Anvind1fb15c2007-11-13 09:37:59 -0800255/*
H. Peter Anvin0a126062017-09-27 13:34:42 -0700256 * Hack to support external-linkage inline functions
257 */
H. Peter Anvin99d45c82018-02-20 12:34:17 -0800258#ifndef HAVE_STDC_INLINE
259# ifdef __GNUC__
260# ifdef __GNUC_STDC_INLINE__
261# define HAVE_STDC_INLINE
262# else
263# define HAVE_GNU_INLINE
264# endif
265# elif defined(__GNUC_GNU_INLINE__)
266/* Some other compiler implementing only GNU inline semantics? */
267# define HAVE_GNU_INLINE
Reid Klecknere62fca42019-08-06 15:24:48 -0700268# elif defined(_MSC_VER)
269/* In MSVC and clang when it is pretending to be MSVC, inline behaves it does in
270 * C++.
271 */
272# define HAVE_MSVC_INLINE
H. Peter Anvin99d45c82018-02-20 12:34:17 -0800273# elif defined(__STDC_VERSION__)
274# if __STDC_VERSION__ >= 199901L
275# define HAVE_STDC_INLINE
276# endif
H. Peter Anvin0a126062017-09-27 13:34:42 -0700277# endif
278#endif
279
280#ifdef HAVE_STDC_INLINE
281# define extern_inline inline
282#elif defined(HAVE_GNU_INLINE)
283# define extern_inline extern inline
H. Peter Anvin99d45c82018-02-20 12:34:17 -0800284# define inline_prototypes
Reid Klecknere62fca42019-08-06 15:24:48 -0700285#elif defined(HAVE_MSVC_INLINE)
286# define extern_inline inline
H. Peter Anvin0a126062017-09-27 13:34:42 -0700287#else
288# define inline_prototypes
289#endif
290
291/*
H. Peter Anvin51997d32008-06-10 09:35:26 -0700292 * Hints to the compiler that a particular branch of code is more or
293 * less likely to be taken.
294 */
H. Peter Anvin7294d622016-11-15 15:53:38 -0800295#if HAVE___BUILTIN_EXPECT
H. Peter Anvin51997d32008-06-10 09:35:26 -0700296# define likely(x) __builtin_expect(!!(x), 1)
297# define unlikely(x) __builtin_expect(!!(x), 0)
298#else
299# define likely(x) (!!(x))
300# define unlikely(x) (!!(x))
301#endif
302
H. Peter Anvin (Intel)8b6e6bf2019-08-16 00:08:27 -0700303#define safe_alloc never_null malloc_func
304#define safe_alloc_ptr never_null_ptr malloc_func_ptr
H. Peter Anvin8b190832016-11-15 14:01:37 -0800305
H. Peter Anvin (Intel)8b6e6bf2019-08-16 00:08:27 -0700306#define safe_malloc(s) safe_alloc alloc_size_func1(s)
307#define safe_malloc2(s1,s2) safe_alloc alloc_size_func2(s1,s2)
308#define safe_realloc(s) never_null alloc_size_func1(s)
309#define safe_malloc_ptr(s) safe_alloc_ptr alloc_size_func1_ptr(s)
310#define safe_malloc2_ptr(s1,s2) safe_alloc_ptr alloc_size_func2_ptr(s1,s2)
311#define safe_realloc_ptr(s) never_null_ptr alloc_size_func1_ptr(s)
H. Peter Anvin740ec352018-05-30 11:40:42 -0700312
H. Peter Anvin4976cd22016-05-25 03:56:34 -0700313/*
H. Peter Anvin396e6dc2009-07-01 22:01:07 -0700314 * How to tell the compiler that a function doesn't return
315 */
H. Peter Anvinabd28c92016-12-20 02:29:58 -0800316#ifdef HAVE_STDNORETURN_H
317# include <stdnoreturn.h>
318# define no_return noreturn void
H. Peter Anvinc01af092017-04-06 13:48:54 -0700319#elif defined(_MSC_VER)
320# define no_return __declspec(noreturn) void
H. Peter Anvin396e6dc2009-07-01 22:01:07 -0700321#else
H. Peter Anvin (Intel)8b6e6bf2019-08-16 00:08:27 -0700322# define no_return void noreturn_func
H. Peter Anvin6686fc62018-02-22 14:52:50 -0800323#endif
324
325/*
326 * A fatal function is both unlikely and no_return
327 */
H. Peter Anvin (Intel)8b6e6bf2019-08-16 00:08:27 -0700328#define fatal_func no_return unlikely_func
329#define fatal_func_ptr no_return unlikely_func_ptr
H. Peter Anvin6686fc62018-02-22 14:52:50 -0800330
331/*
H. Peter Anvinf0d92fd2016-02-02 16:01:43 -0800332 * How to tell the compiler that a function takes a printf-like string
333 */
H. Peter Anvin (Intel)8b6e6bf2019-08-16 00:08:27 -0700334#define printf_func(fmt, list) format_func3(printf,fmt,list)
335#define printf_func_ptr(fmt, list) format_func3_ptr(printf,fmt,list)
H. Peter Anvin8b190832016-11-15 14:01:37 -0800336
H. Peter Anvincb7da7e2017-11-29 16:05:05 -0800337/* Determine probabilistically if something is a compile-time constant */
H. Peter Anvinb533f542017-11-29 16:48:27 -0800338#ifdef HAVE___BUILTIN_CONSTANT_P
Cyrill Gorcunov7d23d8d2018-12-15 20:21:09 +0300339# if defined(__GNUC__) && (__GNUC__ >= 5)
340# define is_constant(x) __builtin_constant_p((x))
341# else
342# define is_constant(x) false
343# endif
H. Peter Anvincb7da7e2017-11-29 16:05:05 -0800344#else
345# define is_constant(x) false
346#endif
347
H. Peter Anvin (Intel)eb5b3ae2018-12-12 14:34:34 -0800348/*
H. Peter Anvin (Intel)b7f24e72018-12-14 14:21:16 -0800349 * If we can guarantee that a particular expression is constant, use it,
350 * otherwise use a different version.
351 */
352#if defined(__GNUC__) && (__GNUC__ >= 3)
353# define not_pedantic_start \
354 _Pragma("GCC diagnostic push") \
355 _Pragma("GCC diagnostic ignored \"-Wpedantic\"")
356# define not_pedantic_end \
357 _Pragma("GCC diagnostic pop")
358#else
359# define not_pedantic_start
360# define not_pedantic_end
361#endif
362
363#ifdef HAVE___BUILTIN_CHOOSE_EXPR
364# define if_constant(x,y) __builtin_choose_expr(is_constant(x),(x),(y))
365#else
366# define if_constant(x,y) (y)
367#endif
368
369/*
H. Peter Anvin (Intel)eb5b3ae2018-12-12 14:34:34 -0800370 * The autoconf documentation states:
371 *
372 * `va_copy'
373 * The C99 standard provides `va_copy' for copying `va_list'
374 * variables. It may be available in older environments too, though
375 * possibly as `__va_copy' (e.g., `gcc' in strict pre-C99 mode).
376 * These can be tested with `#ifdef'. A fallback to `memcpy (&dst,
377 * &src, sizeof (va_list))' gives maximum portability.
378 */
379#ifndef va_copy
380# ifdef __va_copy
381# define va_copy(dst,src) __va_copy(dst,src)
382# else
383# define va_copy(dst,src) memcpy(&(dst),&(src),sizeof(va_list))
384# endif
385#endif
386
H. Peter Anvin (Intel)5b4de522020-06-01 13:10:46 -0700387/*
388 * If SIZE_MAX is not defined, rely on size_t being unsigned
389 */
390#ifndef SIZE_MAX
391# define SIZE_MAX (((size_t)0) - 1)
392#endif
393
H. Peter Anvin9b4b92b2017-02-20 00:36:53 -0800394/* Watcom doesn't handle switch statements with 64-bit types, hack around it */
H. Peter Anvine29c7bb2017-02-28 23:05:17 -0800395#ifdef __WATCOMC__
H. Peter Anvin9b4b92b2017-02-20 00:36:53 -0800396# define BOGUS_CASE 0x76543210
397
398static inline unsigned int watcom_switch_hack(uint64_t x)
399{
H. Peter Anvine90a89a2017-03-01 00:52:48 -0800400 if (x > (uint64_t)UINT_MAX)
H. Peter Anvin9b4b92b2017-02-20 00:36:53 -0800401 return BOGUS_CASE;
402 else
403 return (unsigned int)x;
404}
405
H. Peter Anvinbe01d492017-02-23 17:25:31 -0800406# define switch(x) switch(sizeof(x) > sizeof(unsigned int) \
407 ? watcom_switch_hack(x) : (unsigned int)(x))
408
409/* This is to make sure BOGUS_CASE doesn't conflict with anything real... */
H. Peter Anvin9b4b92b2017-02-20 00:36:53 -0800410# define default case BOGUS_CASE: default
411#endif
412
H. Peter Anvinfe501952007-10-02 21:53:51 -0700413#endif /* NASM_COMPILER_H */