1 /**************************************************************************
3 * Copyright 2007-2008 Tungsten Graphics, Inc., Cedar Park, Texas.
6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the
8 * "Software"), to deal in the Software without restriction, including
9 * without limitation the rights to use, copy, modify, merge, publish,
10 * distribute, sub license, and/or sell copies of the Software, and to
11 * permit persons to whom the Software is furnished to do so, subject to
12 * the following conditions:
14 * The above copyright notice and this permission notice (including the
15 * next paragraph) shall be included in all copies or substantial portions
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
19 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
20 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
21 * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS BE LIABLE FOR
22 * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
23 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
24 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
26 **************************************************************************/
40 #if defined(_WIN32) && !defined(__WIN32__)
46 /* Avoid 'expression is always true' warning */
47 #pragma warning(disable: 4296)
53 * Alternative stdint.h and stdbool.h headers are supplied in include/c99 for
54 * systems that lack it.
56 #ifndef __STDC_LIMIT_MACROS
57 #define __STDC_LIMIT_MACROS 1
63 #if !defined(__HAIKU__) && !defined(__USE_MISC)
64 typedef unsigned int uint
;
65 typedef unsigned short ushort
;
67 typedef unsigned char ubyte
;
69 typedef unsigned char boolean
;
77 /* Function inlining */
80 # define INLINE inline
81 # elif defined(__GNUC__)
82 # define INLINE __inline__
83 # elif defined(_MSC_VER)
84 # define INLINE __inline
86 # define INLINE __inline
87 # elif defined(__INTEL_COMPILER)
88 # define INLINE inline
89 # elif defined(__WATCOMC__) && (__WATCOMC__ >= 1100)
90 # define INLINE __inline
91 # elif defined(__SUNPRO_C) && defined(__C99FEATURES__)
92 # define INLINE inline
93 # elif (__STDC_VERSION__ >= 199901L) /* C99 */
94 # define INLINE inline
101 /* Function visibility */
103 # if defined(__GNUC__) || (defined(__SUNPRO_C) && (__SUNPRO_C >= 0x590))
104 # define PUBLIC __attribute__((visibility("default")))
111 /* The __FUNCTION__ gcc variable is generally only used for debugging.
112 * If we're not using gcc, define __FUNCTION__ as a cpp symbol here.
115 # if !defined(__GNUC__)
116 # if (__STDC_VERSION__ >= 199901L) /* C99 */ || \
117 (defined(__SUNPRO_C) && defined(__C99FEATURES__))
118 # define __FUNCTION__ __func__
120 # define __FUNCTION__ "<unknown>"
123 # if defined(_MSC_VER) && _MSC_VER < 1300
124 # define __FUNCTION__ "<unknown>"
130 /* This should match linux gcc cdecl semantics everywhere, so that we
131 * just codegen one calling convention on all platforms.
134 #define PIPE_CDECL __cdecl
141 #if defined(__GNUC__)
142 #define PIPE_DEPRECATED __attribute__((__deprecated__))
144 #define PIPE_DEPRECATED
149 /* Macros for data alignment. */
150 #if defined(__GNUC__) || (defined(__SUNPRO_C) && (__SUNPRO_C >= 0x590))
152 /* See http://gcc.gnu.org/onlinedocs/gcc-4.4.2/gcc/Type-Attributes.html */
153 #define PIPE_ALIGN_TYPE(_alignment, _type) _type __attribute__((aligned(_alignment)))
155 /* See http://gcc.gnu.org/onlinedocs/gcc-4.4.2/gcc/Variable-Attributes.html */
156 #define PIPE_ALIGN_VAR(_alignment) __attribute__((aligned(_alignment)))
158 #if (__GNUC__ > 4 || (__GNUC__ == 4 &&__GNUC_MINOR__>1)) && !defined(PIPE_ARCH_X86_64)
159 #define PIPE_ALIGN_STACK __attribute__((force_align_arg_pointer))
161 #define PIPE_ALIGN_STACK
164 #elif defined(_MSC_VER)
166 /* See http://msdn.microsoft.com/en-us/library/83ythb65.aspx */
167 #define PIPE_ALIGN_TYPE(_alignment, _type) __declspec(align(_alignment)) _type
168 #define PIPE_ALIGN_VAR(_alignment) __declspec(align(_alignment))
170 #define PIPE_ALIGN_STACK
174 #define PIPE_ALIGN_TYPE(_alignment, _type) _type
175 #define PIPE_ALIGN_VAR(_alignment)
177 #define PIPE_ALIGN_STACK
181 #error "Unsupported compiler"
185 /* You should use these macros to mark if blocks where the if condition
186 * is either likely to be true, or unlikely to be true.
188 * This will inform human readers of this fact, and will also inform
189 * the compiler, who will in turn inform the CPU.
191 * CPUs often start executing code inside the if or the else blocks
192 * without knowing whether the condition is true or not, and will have
193 * to throw the work away if they find out later they executed the
194 * wrong part of the if.
196 * If these macros are used, the CPU is more likely to correctly predict
197 * the right path, and will avoid speculatively executing the wrong branch,
198 * thus not throwing away work, resulting in better performance.
200 * In light of this, it is also a good idea to mark as "likely" a path
201 * which is not necessarily always more likely, but that will benefit much
202 * more from performance improvements since it is already much faster than
203 * the other path, or viceversa with "unlikely".
206 * if(unlikely(do_we_need_a_software_fallback()))
207 * do_software_fallback();
211 * The macros follow the Linux kernel convention, and more examples can
214 * Note that profile guided optimization can offer better results, but
215 * needs an appropriate coverage suite and does not inform human readers.
218 #define likely(x) __builtin_expect(!!(x), 1)
219 #define unlikely(x) __builtin_expect(!!(x), 0)
221 #define likely(x) !!(x)
222 #define unlikely(x) !!(x)
225 #endif /* P_COMPILER_H */