blob: 25aeea1e8c4b9df1a30cce58fa2dad5ad9511e3b [file] [log] [blame]
H. Peter Anvinc1494ac2007-04-13 19:58:42 +00001/* ----------------------------------------------------------------------- *
H. Peter Anvin9e6747c2009-06-28 17:13:04 -07002 *
H. Peter Anvin (Intel)eb5b3ae2018-12-12 14:34:34 -08003 * Copyright 2007-2018 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.
17 *
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.
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 Anvin397c1692016-10-04 17:01:59 -070059#elif defined(_MSC_VER) && (_MSC_VER >= 1310)
60# include "config/msvc.h"
H. Peter Anvine29c7bb2017-02-28 23:05:17 -080061#elif defined(__WATCOMC__)
H. Peter Anvinf5287232016-10-19 13:23:04 -070062# include "config/watcom.h"
H. Peter Anvin253a4e72008-06-10 13:00:27 -070063#else
H. Peter Anvin276785a2016-10-04 17:13:50 -070064# include "config/unknown.h"
H. Peter Anvin397c1692016-10-04 17:01:59 -070065#endif /* Configuration file */
H. Peter Anvinc1494ac2007-04-13 19:58:42 +000066
H. Peter Anvin687b3632007-10-11 12:50:24 -070067/* This is required to get the standard <inttypes.h> macros when compiling
68 with a C++ compiler. This must be defined *before* <inttypes.h> is
69 included, directly or indirectly. */
70#define __STDC_CONSTANT_MACROS 1
71#define __STDC_LIMIT_MACROS 1
72#define __STDC_FORMAT_MACROS 1
73
H. Peter Anvin3ef4f002016-03-08 12:14:55 -080074#ifdef HAVE_INTTYPES_H
75# include <inttypes.h>
76#else
77# include "nasmint.h"
78#endif
79
H. Peter Anvinabd28c92016-12-20 02:29:58 -080080#include <assert.h>
H. Peter Anvin304b6052007-09-28 10:50:20 -070081#include <stddef.h>
82#include <stdarg.h>
H. Peter Anvinfe501952007-10-02 21:53:51 -070083#include <stdio.h>
H. Peter Anvin (Intel)eb5b3ae2018-12-12 14:34:34 -080084#include <stdlib.h>
H. Peter Anvin2e53f272018-12-26 06:32:37 -080085#include <string.h>
H. Peter Anvin9b4b92b2017-02-20 00:36:53 -080086#include <limits.h>
H. Peter Anvinb8af9aa2007-09-17 13:53:14 -070087
H. Peter Anvin4c9132e2016-10-19 13:13:38 -070088#ifdef HAVE_SYS_TYPES_H
89# include <sys/types.h>
90#endif
H. Peter Anvin573112e2017-04-24 13:28:14 -070091
H. Peter Anvind3e22572017-04-24 12:58:30 -070092#ifdef HAVE_ENDIAN_H
93# include <endian.h>
H. Peter Anvin573112e2017-04-24 13:28:14 -070094#elif defined(HAVE_SYS_ENDIAN_H)
95# include <sys/endian.h>
96#elif defined(HAVE_MACHINE_ENDIAN_H)
97# include <machine/endian.h>
H. Peter Anvind3e22572017-04-24 12:58:30 -070098#endif
99
100/*
H. Peter Anvin53cd7c72017-04-25 12:51:17 -0700101 * If we have BYTE_ORDER defined, or the compiler provides
102 * __BIG_ENDIAN__ or __LITTLE_ENDIAN__, trust it over what autoconf
103 * came up with, especially since autoconf obviously can't figure
104 * things out for a universal compiler.
H. Peter Anvind3e22572017-04-24 12:58:30 -0700105 */
H. Peter Anvin53cd7c72017-04-25 12:51:17 -0700106#if defined(__BIG_ENDIAN__) && !defined(__LITTLE_ENDIAN__)
107# undef WORDS_LITTLEENDIAN
108# undef WORDS_BIGENDIAN
109# define WORDS_BIGENDIAN 1
110#elif defined(__LITTLE_ENDIAN__) && !defined(__BIG_ENDIAN__)
111# undef WORDS_LITTLEENDIAN
112# undef WORDS_BIGENDIAN
113# define WORDS_LITTLEENDIAN 1
114#elif defined(BYTE_ORDER) && defined(LITTLE_ENDIAN) && defined(BIG_ENDIAN)
H. Peter Anvind3e22572017-04-24 12:58:30 -0700115# undef WORDS_LITTLEENDIAN
116# undef WORDS_BIGENDIAN
117# if BYTE_ORDER == LITTLE_ENDIAN
118# define WORDS_LITTLEENDIAN 1
119# elif BYTE_ORDER == BIG_ENDIAN
120# define WORDS_BIGENDIAN 1
121# endif
122#endif
123
124/*
125 * Define this to 1 for faster performance if this is a littleendian
H. Peter Anvin53cd7c72017-04-25 12:51:17 -0700126 * platform *and* it can do arbitrary unaligned memory references. It
127 * is safe to leave it defined to 0 even if that is true.
H. Peter Anvind3e22572017-04-24 12:58:30 -0700128 */
129#if defined(__386__) || defined(__i386__) || defined(__x86_64__) \
130 || defined(_M_IX86) || defined(_M_X64)
131# define X86_MEMORY 1
H. Peter Anvin53cd7c72017-04-25 12:51:17 -0700132# undef WORDS_BIGENDIAN
133# undef WORDS_LITTLEENDIAN
134# define WORDS_LITTLEENDIAN 1
H. Peter Anvind3e22572017-04-24 12:58:30 -0700135#else
136# define X86_MEMORY 0
137#endif
H. Peter Anvin4c9132e2016-10-19 13:13:38 -0700138
H. Peter Anvin3ef4f002016-03-08 12:14:55 -0800139/* Some versions of MSVC have these only with underscores in front */
H. Peter Anvin304b6052007-09-28 10:50:20 -0700140#ifndef HAVE_SNPRINTF
141# ifdef HAVE__SNPRINTF
142# define snprintf _snprintf
143# else
144int snprintf(char *, size_t, const char *, ...);
145# endif
H. Peter Anvinb8af9aa2007-09-17 13:53:14 -0700146#endif
147
H. Peter Anvin304b6052007-09-28 10:50:20 -0700148#ifndef HAVE_VSNPRINTF
Cyrill Gorcunovb2c34492014-11-26 10:44:19 +0300149# ifdef HAVE__VSNPRINTF
H. Peter Anvin304b6052007-09-28 10:50:20 -0700150# define vsnprintf _vsnprintf
151# else
152int vsnprintf(char *, size_t, const char *, va_list);
153# endif
H. Peter Anvinb8af9aa2007-09-17 13:53:14 -0700154#endif
155
H. Peter Anvin2958bcc2017-02-23 19:23:10 -0800156#if !defined(HAVE_STRLCPY) || !HAVE_DECL_STRLCPY
H. Peter Anvineaa68f12009-08-10 15:56:52 -0700157size_t strlcpy(char *, const char *, size_t);
158#endif
159
H. Peter Anvin81b62b92017-12-20 13:33:49 -0800160#if !defined(HAVE_STRCHRNUL) || !HAVE_DECL_STRCHRNUL
161char *strrchrnul(const char *, int);
162#endif
163
H. Peter Anvin6867acc2007-10-10 14:58:45 -0700164#ifndef __cplusplus /* C++ has false, true, bool as keywords */
H. Peter Anvind338b372016-02-18 00:54:30 -0800165# ifdef HAVE_STDBOOL_H
H. Peter Anvin6867acc2007-10-10 14:58:45 -0700166# include <stdbool.h>
H. Peter Anvind338b372016-02-18 00:54:30 -0800167# elif defined(HAVE__BOOL)
168# typedef _Bool bool
169# define false 0
170# define true 1
H. Peter Anvin6867acc2007-10-10 14:58:45 -0700171# else
H. Peter Anvin253a4e72008-06-10 13:00:27 -0700172/* This is sort of dangerous, since casts will behave different than
173 casting to the standard boolean type. Always use !!, not (bool). */
174typedef enum bool { false, true } bool;
H. Peter Anvin6867acc2007-10-10 14:58:45 -0700175# endif
176#endif
177
H. Peter Anvin9656a582008-10-30 10:52:08 -0700178/* Provide a substitute for offsetof() if we don't have one. This
179 variant works on most (but not *all*) systems... */
180#ifndef offsetof
181# define offsetof(t,m) ((size_t)&(((t *)0)->m))
182#endif
183
H. Peter Anvin (Intel)ce19a522018-12-14 00:27:59 -0800184/* This is like offsetof(), but takes an object rather than a type.
185 Ironically enough this is actually guaranteed to be portable,
186 as far as I know... */
187#ifndef offsetin
188# define offsetin(p,m) ((const char *)&((p).m) - (const char *)&(p))
189#endif
190
H. Peter Anvin9656a582008-10-30 10:52:08 -0700191/* The container_of construct: if p is a pointer to member m of
192 container class c, then return a pointer to the container of which
193 *p is a member. */
194#ifndef container_of
195# define container_of(p, c, m) ((c *)((char *)(p) - offsetof(c,m)))
196#endif
197
H. Peter Anvinc13d31a2007-10-26 18:49:29 -0700198/* Some misguided platforms hide the defs for these */
H. Peter Anvin2958bcc2017-02-23 19:23:10 -0800199#if defined(HAVE_STRCASECMP) && !HAVE_DECL_STRCASECMP
H. Peter Anvinc13d31a2007-10-26 18:49:29 -0700200int strcasecmp(const char *, const char *);
201#endif
202
H. Peter Anvin2958bcc2017-02-23 19:23:10 -0800203#if defined(HAVE_STRICMP) && !HAVE_DECL_STRICMP
H. Peter Anvinc13d31a2007-10-26 18:49:29 -0700204int stricmp(const char *, const char *);
205#endif
206
H. Peter Anvin2958bcc2017-02-23 19:23:10 -0800207#if defined(HAVE_STRNCASECMP) && !HAVE_DECL_STRNCASECMP
H. Peter Anvinc13d31a2007-10-26 18:49:29 -0700208int strncasecmp(const char *, const char *, size_t);
209#endif
210
H. Peter Anvin2958bcc2017-02-23 19:23:10 -0800211#if defined(HAVE_STRNICMP) && !HAVE_DECL_STRNICMP
H. Peter Anvinc13d31a2007-10-26 18:49:29 -0700212int strnicmp(const char *, const char *, size_t);
213#endif
214
H. Peter Anvin2958bcc2017-02-23 19:23:10 -0800215#if defined(HAVE_STRSEP) && !HAVE_DECL_STRSEP
H. Peter Anvinc13d31a2007-10-26 18:49:29 -0700216char *strsep(char **, const char *);
217#endif
218
H. Peter Anvin2958bcc2017-02-23 19:23:10 -0800219#if !HAVE_DECL_STRNLEN
220size_t strnlen(const char *s, size_t maxlen);
221#endif
222
H. Peter Anvin06f72bb2018-12-26 06:22:47 -0800223#ifndef HAVE_MEMPCPY
224static inline void *mempcpy(void *dst, const void *src, size_t n)
225{
226 return memcpy(dst, src, n) + n;
227}
228#endif
229
H. Peter Anvind1fb15c2007-11-13 09:37:59 -0800230/*
H. Peter Anvin0a126062017-09-27 13:34:42 -0700231 * Hack to support external-linkage inline functions
232 */
H. Peter Anvin99d45c82018-02-20 12:34:17 -0800233#ifndef HAVE_STDC_INLINE
234# ifdef __GNUC__
235# ifdef __GNUC_STDC_INLINE__
236# define HAVE_STDC_INLINE
237# else
238# define HAVE_GNU_INLINE
239# endif
240# elif defined(__GNUC_GNU_INLINE__)
241/* Some other compiler implementing only GNU inline semantics? */
242# define HAVE_GNU_INLINE
243# elif defined(__STDC_VERSION__)
244# if __STDC_VERSION__ >= 199901L
245# define HAVE_STDC_INLINE
246# endif
H. Peter Anvin0a126062017-09-27 13:34:42 -0700247# endif
248#endif
249
250#ifdef HAVE_STDC_INLINE
251# define extern_inline inline
252#elif defined(HAVE_GNU_INLINE)
253# define extern_inline extern inline
H. Peter Anvin99d45c82018-02-20 12:34:17 -0800254# define inline_prototypes
H. Peter Anvin0a126062017-09-27 13:34:42 -0700255#else
256# define inline_prototypes
257#endif
258
259/*
H. Peter Anvin51997d32008-06-10 09:35:26 -0700260 * Hints to the compiler that a particular branch of code is more or
261 * less likely to be taken.
262 */
H. Peter Anvin7294d622016-11-15 15:53:38 -0800263#if HAVE___BUILTIN_EXPECT
H. Peter Anvin51997d32008-06-10 09:35:26 -0700264# define likely(x) __builtin_expect(!!(x), 1)
265# define unlikely(x) __builtin_expect(!!(x), 0)
266#else
267# define likely(x) (!!(x))
268# define unlikely(x) (!!(x))
269#endif
270
H. Peter Anvin396e6dc2009-07-01 22:01:07 -0700271/*
H. Peter Anvin4976cd22016-05-25 03:56:34 -0700272 * Hints about malloc-like functions that never return NULL
273 */
H. Peter Anvin8b190832016-11-15 14:01:37 -0800274#ifdef HAVE_FUNC_ATTRIBUTE_RETURNS_NONNULL
H. Peter Anvin4976cd22016-05-25 03:56:34 -0700275# define never_null __attribute__((returns_nonnull))
H. Peter Anvin8b190832016-11-15 14:01:37 -0800276#else
277# define never_null
278#endif
279
280#ifdef HAVE_FUNC_ATTRIBUTE_MALLOC
H. Peter Anvin4976cd22016-05-25 03:56:34 -0700281# define safe_alloc never_null __attribute__((malloc))
H. Peter Anvin8b190832016-11-15 14:01:37 -0800282#else
H. Peter Anvin740ec352018-05-30 11:40:42 -0700283# define safe_alloc never_null
H. Peter Anvin8b190832016-11-15 14:01:37 -0800284#endif
285
286#ifdef HAVE_FUNC_ATTRIBUTE_ALLOC_SIZE
H. Peter Anvin03a51872017-11-29 16:36:14 -0800287# define safe_malloc(s) safe_alloc __attribute__((alloc_size(s)))
288# define safe_malloc2(s1,s2) safe_alloc __attribute__((alloc_size(s1,s2)))
289# define safe_realloc(s) never_null __attribute__((alloc_size(s)))
H. Peter Anvin8b190832016-11-15 14:01:37 -0800290#else
H. Peter Anvin9b733a52016-10-14 15:01:06 -0700291# define safe_malloc(s) safe_alloc
H. Peter Anvin44e3a112016-10-14 15:05:28 -0700292# define safe_malloc2(s1,s2) safe_alloc
H. Peter Anvin9b733a52016-10-14 15:01:06 -0700293# define safe_realloc(s) never_null
H. Peter Anvin4976cd22016-05-25 03:56:34 -0700294#endif
295
H. Peter Anvin740ec352018-05-30 11:40:42 -0700296#ifdef HAVE_FUNC_ATTRIBUTE_SENTINEL
297# define end_with_null __attribute__((sentinel))
298#else
299# define end_with_null
300#endif
301
H. Peter Anvin4976cd22016-05-25 03:56:34 -0700302/*
H. Peter Anvin396e6dc2009-07-01 22:01:07 -0700303 * How to tell the compiler that a function doesn't return
304 */
H. Peter Anvinabd28c92016-12-20 02:29:58 -0800305#ifdef HAVE_STDNORETURN_H
306# include <stdnoreturn.h>
307# define no_return noreturn void
308#elif defined(HAVE_FUNC_ATTRIBUTE_NORETURN)
H. Peter Anvin84280bb2009-07-05 19:22:28 -0700309# define no_return void __attribute__((noreturn))
H. Peter Anvinc01af092017-04-06 13:48:54 -0700310#elif defined(_MSC_VER)
311# define no_return __declspec(noreturn) void
H. Peter Anvin396e6dc2009-07-01 22:01:07 -0700312#else
H. Peter Anvin84280bb2009-07-05 19:22:28 -0700313# define no_return void
H. Peter Anvin396e6dc2009-07-01 22:01:07 -0700314#endif
315
H. Peter Anvinf0d92fd2016-02-02 16:01:43 -0800316/*
H. Peter Anvin6686fc62018-02-22 14:52:50 -0800317 * How to tell the compiler that a function is unlikely to be executed.
318 * This differs from unlikely() in that it is applied to a function call,
319 * not a boolean condition.
320 */
Cyrill Gorcunovfff27ab2018-02-24 15:11:32 +0300321#ifdef HAVE_FUNC_ATTRIBUTE_COLD
H. Peter Anvin6686fc62018-02-22 14:52:50 -0800322# define unlikely_func __attribute__((cold))
323#else
324# define unlikely_func
325#endif
326
327/*
328 * A fatal function is both unlikely and no_return
329 */
330#define fatal_func no_return unlikely_func
331
332/*
H. Peter Anvinf0d92fd2016-02-02 16:01:43 -0800333 * How to tell the compiler that a function takes a printf-like string
334 */
H. Peter Anvin8b190832016-11-15 14:01:37 -0800335#ifdef HAVE_FUNC_ATTRIBUTE_FORMAT
H. Peter Anvinf0d92fd2016-02-02 16:01:43 -0800336# define printf_func(fmt, list) __attribute__((format(printf, fmt, list)))
337#else
338# define printf_func(fmt, list)
339#endif
340
H. Peter Anvin8b190832016-11-15 14:01:37 -0800341/*
342 * How to tell the compiler that a function is pure arithmetic
343 */
344#ifdef HAVE_FUNC_ATTRIBUTE_CONST
345# define const_func __attribute__((const))
346#else
347# define const_func
348#endif
349
350/*
351 * This function has no side effects, but depends on its arguments,
352 * memory pointed to by its arguments, or global variables.
353 * NOTE: functions that return a value by modifying memory pointed to
354 * by a pointer argument are *NOT* considered pure.
355 */
356#ifdef HAVE_FUNC_ATTRIBUTE_PURE
357# define pure_func __attribute__((pure))
358#else
359# define pure_func
360#endif
361
H. Peter Anvincb7da7e2017-11-29 16:05:05 -0800362/* Determine probabilistically if something is a compile-time constant */
H. Peter Anvinb533f542017-11-29 16:48:27 -0800363#ifdef HAVE___BUILTIN_CONSTANT_P
Cyrill Gorcunov7d23d8d2018-12-15 20:21:09 +0300364# if defined(__GNUC__) && (__GNUC__ >= 5)
365# define is_constant(x) __builtin_constant_p((x))
366# else
367# define is_constant(x) false
368# endif
H. Peter Anvincb7da7e2017-11-29 16:05:05 -0800369#else
370# define is_constant(x) false
371#endif
372
H. Peter Anvin (Intel)eb5b3ae2018-12-12 14:34:34 -0800373/*
H. Peter Anvin (Intel)b7f24e72018-12-14 14:21:16 -0800374 * If we can guarantee that a particular expression is constant, use it,
375 * otherwise use a different version.
376 */
377#if defined(__GNUC__) && (__GNUC__ >= 3)
378# define not_pedantic_start \
379 _Pragma("GCC diagnostic push") \
380 _Pragma("GCC diagnostic ignored \"-Wpedantic\"")
381# define not_pedantic_end \
382 _Pragma("GCC diagnostic pop")
383#else
384# define not_pedantic_start
385# define not_pedantic_end
386#endif
387
388#ifdef HAVE___BUILTIN_CHOOSE_EXPR
389# define if_constant(x,y) __builtin_choose_expr(is_constant(x),(x),(y))
390#else
391# define if_constant(x,y) (y)
392#endif
393
394/*
H. Peter Anvin (Intel)eb5b3ae2018-12-12 14:34:34 -0800395 * The autoconf documentation states:
396 *
397 * `va_copy'
398 * The C99 standard provides `va_copy' for copying `va_list'
399 * variables. It may be available in older environments too, though
400 * possibly as `__va_copy' (e.g., `gcc' in strict pre-C99 mode).
401 * These can be tested with `#ifdef'. A fallback to `memcpy (&dst,
402 * &src, sizeof (va_list))' gives maximum portability.
403 */
404#ifndef va_copy
405# ifdef __va_copy
406# define va_copy(dst,src) __va_copy(dst,src)
407# else
408# define va_copy(dst,src) memcpy(&(dst),&(src),sizeof(va_list))
409# endif
410#endif
411
H. Peter Anvin9b4b92b2017-02-20 00:36:53 -0800412/* Watcom doesn't handle switch statements with 64-bit types, hack around it */
H. Peter Anvine29c7bb2017-02-28 23:05:17 -0800413#ifdef __WATCOMC__
H. Peter Anvin9b4b92b2017-02-20 00:36:53 -0800414# define BOGUS_CASE 0x76543210
415
416static inline unsigned int watcom_switch_hack(uint64_t x)
417{
H. Peter Anvine90a89a2017-03-01 00:52:48 -0800418 if (x > (uint64_t)UINT_MAX)
H. Peter Anvin9b4b92b2017-02-20 00:36:53 -0800419 return BOGUS_CASE;
420 else
421 return (unsigned int)x;
422}
423
H. Peter Anvinbe01d492017-02-23 17:25:31 -0800424# define switch(x) switch(sizeof(x) > sizeof(unsigned int) \
425 ? watcom_switch_hack(x) : (unsigned int)(x))
426
427/* This is to make sure BOGUS_CASE doesn't conflict with anything real... */
H. Peter Anvin9b4b92b2017-02-20 00:36:53 -0800428# define default case BOGUS_CASE: default
429#endif
430
H. Peter Anvinfe501952007-10-02 21:53:51 -0700431#endif /* NASM_COMPILER_H */