X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=include%2Fcompiler.h;h=0734ed494274558a0656925220d7e4861da7231e;hb=b278c4095b59c40ff512c5433b735b000e547554;hp=e602cce2e9b99fc5f86b6523972ec909bf127fa1;hpb=88f9d60b62829ea2a948b9c20fc8a3df94b512bd;p=u-boot diff --git a/include/compiler.h b/include/compiler.h index e602cce2e9..0734ed4942 100644 --- a/include/compiler.h +++ b/include/compiler.h @@ -25,8 +25,6 @@ #include #include -extern int errno; - #if !defined(__WIN32__) && !defined(__MINGW32__) # include #endif @@ -46,15 +44,15 @@ extern int errno; #ifdef __linux__ # include # include -#elif defined(__MACH__) +#elif defined(__MACH__) || defined(__FreeBSD__) # include typedef unsigned long ulong; -typedef unsigned int uint; #endif typedef uint8_t __u8; typedef uint16_t __u16; typedef uint32_t __u32; +typedef unsigned int uint; #define uswap_16(x) \ ((((x) & 0xff00) >> 8) | \ @@ -113,16 +111,27 @@ typedef uint32_t __u32; #include #include -/* Types for `void *' pointers. */ -#if __WORDSIZE == 64 -typedef unsigned long int uintptr_t; +#if __SIZEOF_LONG__ == 8 +# define __WORDSIZE 64 +#elif __SIZEOF_LONG__ == 4 +# define __WORDSIZE 32 #else -typedef unsigned int uintptr_t; +/* + * Assume 32-bit for now - only newer toolchains support this feature and + * this is only required for sandbox support at present. + */ +#define __WORDSIZE 32 #endif -#endif +/* Type for `void *' pointers. */ +typedef unsigned long int uintptr_t; + +#endif /* USE_HOSTCC */ /* compiler options */ #define uninitialized_var(x) x = x +#define likely(x) __builtin_expect(!!(x), 1) +#define unlikely(x) __builtin_expect(!!(x), 0) + #endif