blob: 1fa4a13b0126eb1bfed0a47dd07afdfeefdef5ee [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 Anvin3ef4f002016-03-08 12:14:55 -080075#ifdef HAVE_INTTYPES_H
76# include <inttypes.h>
77#else
78# include "nasmint.h"
79#endif
80
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 Anvinb8af9aa2007-09-17 13:53:14 -070084
H. Peter Anvin3ef4f002016-03-08 12:14:55 -080085/* Some versions of MSVC have these only with underscores in front */
H. Peter Anvin304b6052007-09-28 10:50:20 -070086#ifndef HAVE_SNPRINTF
87# ifdef HAVE__SNPRINTF
88# define snprintf _snprintf
89# else
90int snprintf(char *, size_t, const char *, ...);
91# endif
H. Peter Anvinb8af9aa2007-09-17 13:53:14 -070092#endif
93
H. Peter Anvin304b6052007-09-28 10:50:20 -070094#ifndef HAVE_VSNPRINTF
Cyrill Gorcunovb2c34492014-11-26 10:44:19 +030095# ifdef HAVE__VSNPRINTF
H. Peter Anvin304b6052007-09-28 10:50:20 -070096# define vsnprintf _vsnprintf
97# else
98int vsnprintf(char *, size_t, const char *, va_list);
99# endif
H. Peter Anvinb8af9aa2007-09-17 13:53:14 -0700100#endif
101
H. Peter Anvineaa68f12009-08-10 15:56:52 -0700102#if !defined(HAVE_STRLCPY) || !HAVE_DECL_STRLCPY
103size_t strlcpy(char *, const char *, size_t);
104#endif
105
H. Peter Anvin6867acc2007-10-10 14:58:45 -0700106#ifndef __cplusplus /* C++ has false, true, bool as keywords */
H. Peter Anvind338b372016-02-18 00:54:30 -0800107# ifdef HAVE_STDBOOL_H
H. Peter Anvin6867acc2007-10-10 14:58:45 -0700108# include <stdbool.h>
H. Peter Anvind338b372016-02-18 00:54:30 -0800109# elif defined(HAVE__BOOL)
110# typedef _Bool bool
111# define false 0
112# define true 1
H. Peter Anvin6867acc2007-10-10 14:58:45 -0700113# else
H. Peter Anvin253a4e72008-06-10 13:00:27 -0700114/* This is sort of dangerous, since casts will behave different than
115 casting to the standard boolean type. Always use !!, not (bool). */
116typedef enum bool { false, true } bool;
H. Peter Anvin6867acc2007-10-10 14:58:45 -0700117# endif
118#endif
119
H. Peter Anvin9656a582008-10-30 10:52:08 -0700120/* Provide a substitute for offsetof() if we don't have one. This
121 variant works on most (but not *all*) systems... */
122#ifndef offsetof
123# define offsetof(t,m) ((size_t)&(((t *)0)->m))
124#endif
125
126/* The container_of construct: if p is a pointer to member m of
127 container class c, then return a pointer to the container of which
128 *p is a member. */
129#ifndef container_of
130# define container_of(p, c, m) ((c *)((char *)(p) - offsetof(c,m)))
131#endif
132
H. Peter Anvinc13d31a2007-10-26 18:49:29 -0700133/* Some misguided platforms hide the defs for these */
134#if defined(HAVE_STRCASECMP) && !HAVE_DECL_STRCASECMP
135int strcasecmp(const char *, const char *);
136#endif
137
138#if defined(HAVE_STRICMP) && !HAVE_DECL_STRICMP
139int stricmp(const char *, const char *);
140#endif
141
142#if defined(HAVE_STRNCASECMP) && !HAVE_DECL_STRNCASECMP
143int strncasecmp(const char *, const char *, size_t);
144#endif
145
146#if defined(HAVE_STRNICMP) && !HAVE_DECL_STRNICMP
147int strnicmp(const char *, const char *, size_t);
148#endif
149
150#if defined(HAVE_STRSEP) && !HAVE_DECL_STRSEP
151char *strsep(char **, const char *);
152#endif
153
H. Peter Anvind1fb15c2007-11-13 09:37:59 -0800154/*
155 * Define this to 1 for faster performance if this is a littleendian
156 * platform which can do unaligned memory references. It is safe
157 * to leave it defined to 0 even if that is true.
158 */
H. Peter Anvin714ad042008-02-16 15:28:02 -0800159#if defined(__386__) || defined(__i386__) || defined(__x86_64__)
H. Peter Anvind1fb15c2007-11-13 09:37:59 -0800160# define X86_MEMORY 1
H. Peter Anvin2f0f9ea2008-06-08 20:53:29 -0700161# ifndef WORDS_LITTLEENDIAN
162# define WORDS_LITTLEENDIAN 1
163# endif
H. Peter Anvind1fb15c2007-11-13 09:37:59 -0800164#else
165# define X86_MEMORY 0
166#endif
167
H. Peter Anvin51997d32008-06-10 09:35:26 -0700168/*
169 * Hints to the compiler that a particular branch of code is more or
170 * less likely to be taken.
171 */
172#if defined(__GNUC__) && __GNUC__ >= 3
173# define likely(x) __builtin_expect(!!(x), 1)
174# define unlikely(x) __builtin_expect(!!(x), 0)
175#else
176# define likely(x) (!!(x))
177# define unlikely(x) (!!(x))
178#endif
179
H. Peter Anvin396e6dc2009-07-01 22:01:07 -0700180/*
H. Peter Anvin4976cd22016-05-25 03:56:34 -0700181 * Hints about malloc-like functions that never return NULL
182 */
183#if defined(__GNUC__) && __GNUC__ >= 4 /* ? */
184# define never_null __attribute__((returns_nonnull))
185# define safe_alloc never_null __attribute__((malloc))
186# define safe_malloc(s) safe_alloc __attribute__((alloc_size(s)))
187# define safe_malloc2(s1,s2) safe_alloc __attribute__((alloc_size(s1,s2)))
188# define safe_realloc(s) never_null __attribute__((alloc_size(s)))
189#else
190# define never_null
191# define safe_alloc
192# define safe_malloc(s)
193# define safe_malloc2(s1,s2)
194# define safe_realloc(s)
195#endif
196
197/*
H. Peter Anvin396e6dc2009-07-01 22:01:07 -0700198 * How to tell the compiler that a function doesn't return
199 */
200#ifdef __GNUC__
H. Peter Anvin84280bb2009-07-05 19:22:28 -0700201# define no_return void __attribute__((noreturn))
H. Peter Anvin396e6dc2009-07-01 22:01:07 -0700202#else
H. Peter Anvin84280bb2009-07-05 19:22:28 -0700203# define no_return void
H. Peter Anvin396e6dc2009-07-01 22:01:07 -0700204#endif
205
H. Peter Anvinf0d92fd2016-02-02 16:01:43 -0800206/*
207 * How to tell the compiler that a function takes a printf-like string
208 */
209#ifdef __GNUC__
210# define printf_func(fmt, list) __attribute__((format(printf, fmt, list)))
211#else
212# define printf_func(fmt, list)
213#endif
214
H. Peter Anvinfe501952007-10-02 21:53:51 -0700215#endif /* NASM_COMPILER_H */