blob: df19aa581d62739e03579c136b3e313173eefa08 [file] [log] [blame]
H. Peter Anvinc1494ac2007-04-13 19:58:42 +00001/* ----------------------------------------------------------------------- *
H. Peter Anvin9e6747c2009-06-28 17:13:04 -07002 *
H. Peter Anvine8677d62016-01-27 14:29:40 -08003 * Copyright 2007-2016 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 Anvine8677d62016-01-27 14:29:40 -080046#ifdef __DJGPP__
47/* DJGPP has header file problems if __STRICT_ANSI__ is defined */
48# undef __STRICT_ANSI__
49#endif
50
H. Peter Anvinb423c022016-02-18 11:57:53 -080051/* On Microsoft platforms we support multibyte character sets in filenames */
52#define _MBCS 1
53
H. Peter Anvinc40f89e2007-04-13 20:06:41 +000054#ifdef HAVE_CONFIG_H
55# include "config.h"
H. Peter Anvin253a4e72008-06-10 13:00:27 -070056/* 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 */
H. Peter Anvinc1494ac2007-04-13 19:58:42 +000067
H. Peter Anvin687b3632007-10-11 12:50:24 -070068/* 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
74
H. Peter Anvinb8af9aa2007-09-17 13:53:14 -070075/* Some versions of MSVC have these only with underscores in front */
H. Peter Anvin304b6052007-09-28 10:50:20 -070076#include <stddef.h>
77#include <stdarg.h>
H. Peter Anvinfe501952007-10-02 21:53:51 -070078#include <stdio.h>
H. Peter Anvinb8af9aa2007-09-17 13:53:14 -070079
H. Peter Anvin304b6052007-09-28 10:50:20 -070080#ifndef HAVE_SNPRINTF
81# ifdef HAVE__SNPRINTF
82# define snprintf _snprintf
83# else
84int snprintf(char *, size_t, const char *, ...);
85# endif
H. Peter Anvinb8af9aa2007-09-17 13:53:14 -070086#endif
87
H. Peter Anvin304b6052007-09-28 10:50:20 -070088#ifndef HAVE_VSNPRINTF
Cyrill Gorcunovb2c34492014-11-26 10:44:19 +030089# ifdef HAVE__VSNPRINTF
H. Peter Anvin304b6052007-09-28 10:50:20 -070090# define vsnprintf _vsnprintf
91# else
92int vsnprintf(char *, size_t, const char *, va_list);
93# endif
H. Peter Anvinb8af9aa2007-09-17 13:53:14 -070094#endif
95
H. Peter Anvineaa68f12009-08-10 15:56:52 -070096#if !defined(HAVE_STRLCPY) || !HAVE_DECL_STRLCPY
97size_t strlcpy(char *, const char *, size_t);
98#endif
99
H. Peter Anvin6867acc2007-10-10 14:58:45 -0700100#ifndef __cplusplus /* C++ has false, true, bool as keywords */
H. Peter Anvind338b372016-02-18 00:54:30 -0800101# ifdef HAVE_STDBOOL_H
H. Peter Anvin6867acc2007-10-10 14:58:45 -0700102# include <stdbool.h>
H. Peter Anvind338b372016-02-18 00:54:30 -0800103# elif defined(HAVE__BOOL)
104# typedef _Bool bool
105# define false 0
106# define true 1
H. Peter Anvin6867acc2007-10-10 14:58:45 -0700107# else
H. Peter Anvin253a4e72008-06-10 13:00:27 -0700108/* This is sort of dangerous, since casts will behave different than
109 casting to the standard boolean type. Always use !!, not (bool). */
110typedef enum bool { false, true } bool;
H. Peter Anvin6867acc2007-10-10 14:58:45 -0700111# endif
112#endif
113
H. Peter Anvin9656a582008-10-30 10:52:08 -0700114/* Provide a substitute for offsetof() if we don't have one. This
115 variant works on most (but not *all*) systems... */
116#ifndef offsetof
117# define offsetof(t,m) ((size_t)&(((t *)0)->m))
118#endif
119
120/* The container_of construct: if p is a pointer to member m of
121 container class c, then return a pointer to the container of which
122 *p is a member. */
123#ifndef container_of
124# define container_of(p, c, m) ((c *)((char *)(p) - offsetof(c,m)))
125#endif
126
H. Peter Anvinc13d31a2007-10-26 18:49:29 -0700127/* Some misguided platforms hide the defs for these */
128#if defined(HAVE_STRCASECMP) && !HAVE_DECL_STRCASECMP
129int strcasecmp(const char *, const char *);
130#endif
131
132#if defined(HAVE_STRICMP) && !HAVE_DECL_STRICMP
133int stricmp(const char *, const char *);
134#endif
135
136#if defined(HAVE_STRNCASECMP) && !HAVE_DECL_STRNCASECMP
137int strncasecmp(const char *, const char *, size_t);
138#endif
139
140#if defined(HAVE_STRNICMP) && !HAVE_DECL_STRNICMP
141int strnicmp(const char *, const char *, size_t);
142#endif
143
144#if defined(HAVE_STRSEP) && !HAVE_DECL_STRSEP
145char *strsep(char **, const char *);
146#endif
147
H. Peter Anvind1fb15c2007-11-13 09:37:59 -0800148/*
149 * Define this to 1 for faster performance if this is a littleendian
150 * platform which can do unaligned memory references. It is safe
151 * to leave it defined to 0 even if that is true.
152 */
H. Peter Anvin714ad042008-02-16 15:28:02 -0800153#if defined(__386__) || defined(__i386__) || defined(__x86_64__)
H. Peter Anvind1fb15c2007-11-13 09:37:59 -0800154# define X86_MEMORY 1
H. Peter Anvin2f0f9ea2008-06-08 20:53:29 -0700155# ifndef WORDS_LITTLEENDIAN
156# define WORDS_LITTLEENDIAN 1
157# endif
H. Peter Anvind1fb15c2007-11-13 09:37:59 -0800158#else
159# define X86_MEMORY 0
160#endif
161
H. Peter Anvin51997d32008-06-10 09:35:26 -0700162/*
163 * Hints to the compiler that a particular branch of code is more or
164 * less likely to be taken.
165 */
166#if defined(__GNUC__) && __GNUC__ >= 3
167# define likely(x) __builtin_expect(!!(x), 1)
168# define unlikely(x) __builtin_expect(!!(x), 0)
169#else
170# define likely(x) (!!(x))
171# define unlikely(x) (!!(x))
172#endif
173
H. Peter Anvin396e6dc2009-07-01 22:01:07 -0700174/*
175 * How to tell the compiler that a function doesn't return
176 */
177#ifdef __GNUC__
H. Peter Anvin84280bb2009-07-05 19:22:28 -0700178# define no_return void __attribute__((noreturn))
H. Peter Anvin396e6dc2009-07-01 22:01:07 -0700179#else
H. Peter Anvin84280bb2009-07-05 19:22:28 -0700180# define no_return void
H. Peter Anvin396e6dc2009-07-01 22:01:07 -0700181#endif
182
H. Peter Anvinf0d92fd2016-02-02 16:01:43 -0800183/*
184 * How to tell the compiler that a function takes a printf-like string
185 */
186#ifdef __GNUC__
187# define printf_func(fmt, list) __attribute__((format(printf, fmt, list)))
188#else
189# define printf_func(fmt, list)
190#endif
191
H. Peter Anvinfe501952007-10-02 21:53:51 -0700192#endif /* NASM_COMPILER_H */