05de9ff7cd022ec333f14125407f42d1f51927e6
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 **************************************************************************/
41 #if defined(_WIN32) && !defined(__WIN32__)
47 /* Avoid 'expression is always true' warning */
48 #pragma warning(disable: 4296)
54 * Alternative stdint.h and stdbool.h headers are supplied in include/c99 for
55 * systems that lack it.
57 #ifndef __STDC_LIMIT_MACROS
58 #define __STDC_LIMIT_MACROS 1
69 #if !defined(__HAIKU__) && !defined(__USE_MISC)
70 #if !defined(PIPE_OS_ANDROID)
71 typedef unsigned int uint
;
73 typedef unsigned short ushort
;
75 typedef unsigned char ubyte
;
77 typedef unsigned char boolean
;
87 #define va_copy(dest, src) __va_copy((dest), (src))
89 #define va_copy(dest, src) (dest) = (src)
93 /* Function inlining */
96 # define INLINE inline
97 # elif defined(__GNUC__)
98 # define INLINE __inline__
99 # elif defined(_MSC_VER)
100 # define INLINE __inline
101 # elif defined(__ICL)
102 # define INLINE __inline
103 # elif defined(__INTEL_COMPILER)
104 # define INLINE inline
105 # elif defined(__WATCOMC__) && (__WATCOMC__ >= 1100)
106 # define INLINE __inline
107 # elif defined(__SUNPRO_C) && defined(__C99FEATURES__)
108 # define INLINE inline
109 # elif (__STDC_VERSION__ >= 199901L) /* C99 */
110 # define INLINE inline
116 /* Forced function inlining */
117 #ifndef ALWAYS_INLINE
119 # define ALWAYS_INLINE inline __attribute__((always_inline))
120 # elif defined(_MSC_VER)
121 # define ALWAYS_INLINE __forceinline
123 # define ALWAYS_INLINE INLINE
128 * Define the C99 restrict keyword.
131 * - http://cellperformance.beyond3d.com/articles/2006/05/demystifying-the-restrict-keyword.html
134 # if (__STDC_VERSION__ >= 199901L)
136 # elif defined(__SUNPRO_C) && defined(__C99FEATURES__)
138 # elif defined(__GNUC__)
139 # define restrict __restrict__
140 # elif defined(_MSC_VER)
141 # define restrict __restrict
143 # define restrict /* */
148 /* Function visibility */
150 # if defined(__GNUC__) || (defined(__SUNPRO_C) && (__SUNPRO_C >= 0x590))
151 # define PUBLIC __attribute__((visibility("default")))
152 # elif defined(_MSC_VER)
153 # define PUBLIC __declspec(dllexport)
160 /* The __FUNCTION__ gcc variable is generally only used for debugging.
161 * If we're not using gcc, define __FUNCTION__ as a cpp symbol here.
164 # if !defined(__GNUC__)
165 # if (__STDC_VERSION__ >= 199901L) /* C99 */ || \
166 (defined(__SUNPRO_C) && defined(__C99FEATURES__))
167 # define __FUNCTION__ __func__
169 # define __FUNCTION__ "<unknown>"
172 # if defined(_MSC_VER) && _MSC_VER < 1300
173 # define __FUNCTION__ "<unknown>"
177 # if (__STDC_VERSION__ >= 199901L) || \
178 (defined(__SUNPRO_C) && defined(__C99FEATURES__))
179 /* __func__ is part of C99 */
180 # elif defined(_MSC_VER)
181 # if _MSC_VER >= 1300
182 # define __func__ __FUNCTION__
184 # define __func__ "<unknown>"
191 /* This should match linux gcc cdecl semantics everywhere, so that we
192 * just codegen one calling convention on all platforms.
195 #define PIPE_CDECL __cdecl
202 #if defined(__GNUC__)
203 #define PIPE_DEPRECATED __attribute__((__deprecated__))
205 #define PIPE_DEPRECATED
210 /* Macros for data alignment. */
211 #if defined(__GNUC__) || (defined(__SUNPRO_C) && (__SUNPRO_C >= 0x590))
213 /* See http://gcc.gnu.org/onlinedocs/gcc-4.4.2/gcc/Type-Attributes.html */
214 #define PIPE_ALIGN_TYPE(_alignment, _type) _type __attribute__((aligned(_alignment)))
216 /* See http://gcc.gnu.org/onlinedocs/gcc-4.4.2/gcc/Variable-Attributes.html */
217 #define PIPE_ALIGN_VAR(_alignment) __attribute__((aligned(_alignment)))
219 #if (__GNUC__ > 4 || (__GNUC__ == 4 &&__GNUC_MINOR__>1)) && !defined(PIPE_ARCH_X86_64)
220 #define PIPE_ALIGN_STACK __attribute__((force_align_arg_pointer))
222 #define PIPE_ALIGN_STACK
225 #elif defined(_MSC_VER)
227 /* See http://msdn.microsoft.com/en-us/library/83ythb65.aspx */
228 #define PIPE_ALIGN_TYPE(_alignment, _type) __declspec(align(_alignment)) _type
229 #define PIPE_ALIGN_VAR(_alignment) __declspec(align(_alignment))
231 #define PIPE_ALIGN_STACK
235 #define PIPE_ALIGN_TYPE(_alignment, _type) _type
236 #define PIPE_ALIGN_VAR(_alignment)
238 #define PIPE_ALIGN_STACK
242 #error "Unsupported compiler"
247 #if defined(__GNUC__)
249 #define PIPE_READ_WRITE_BARRIER() __asm__("":::"memory")
251 #elif defined(_MSC_VER)
253 void _ReadWriteBarrier(void);
254 #pragma intrinsic(_ReadWriteBarrier)
255 #define PIPE_READ_WRITE_BARRIER() _ReadWriteBarrier()
259 #warning "Unsupported compiler"
260 #define PIPE_READ_WRITE_BARRIER() /* */
265 /* You should use these macros to mark if blocks where the if condition
266 * is either likely to be true, or unlikely to be true.
268 * This will inform human readers of this fact, and will also inform
269 * the compiler, who will in turn inform the CPU.
271 * CPUs often start executing code inside the if or the else blocks
272 * without knowing whether the condition is true or not, and will have
273 * to throw the work away if they find out later they executed the
274 * wrong part of the if.
276 * If these macros are used, the CPU is more likely to correctly predict
277 * the right path, and will avoid speculatively executing the wrong branch,
278 * thus not throwing away work, resulting in better performance.
280 * In light of this, it is also a good idea to mark as "likely" a path
281 * which is not necessarily always more likely, but that will benefit much
282 * more from performance improvements since it is already much faster than
283 * the other path, or viceversa with "unlikely".
286 * if(unlikely(do_we_need_a_software_fallback()))
287 * do_software_fallback();
291 * The macros follow the Linux kernel convention, and more examples can
294 * Note that profile guided optimization can offer better results, but
295 * needs an appropriate coverage suite and does not inform human readers.
298 # if defined(__GNUC__)
299 # define likely(x) __builtin_expect(!!(x), 1)
300 # define unlikely(x) __builtin_expect(!!(x), 0)
302 # define likely(x) (x)
303 # define unlikely(x) (x)
308 #if defined(__cplusplus)
313 #endif /* P_COMPILER_H */