X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Ftypes.h;h=d91009df453748d6701ee607b177921368a7a60e;hp=70e47079112833b0a3bdf2dce775df81ae1db6d2;hb=92bada1a32c7ebd5f5b4438bd85bb003d20bd046;hpb=36437f14e8cbac4c6b883248cccc9e707e957c68 diff --git a/src/types.h b/src/types.h index 70e47079..d91009df 100644 --- a/src/types.h +++ b/src/types.h @@ -31,9 +31,9 @@ typedef __int8 int8_t; typedef unsigned __int8 uint8_t; typedef __int16 int16; typedef unsigned __int16 uint16_t; -typedef __int32 int32; +typedef __int32 int32_t; typedef unsigned __int32 uint32_t; -typedef __int64 int64; +typedef __int64 int64_t; typedef unsigned __int64 uint64_t; typedef __int16 int16_t; @@ -62,8 +62,33 @@ typedef uint64_t Bitboard; #define IS_64BIT #endif -#if defined(IS_64BIT) && !defined(_WIN64) && (defined(__GNUC__) || defined(__INTEL_COMPILER)) +#if defined(IS_64BIT) && (defined(__GNUC__) || defined(__INTEL_COMPILER)) #define USE_BSFQ #endif +// Cache line alignment specification +#if defined(_MSC_VER) || defined(__INTEL_COMPILER) +#define CACHE_LINE_ALIGNMENT __declspec(align(64)) +#else +#define CACHE_LINE_ALIGNMENT __attribute__ ((aligned(64))) +#endif + +// Define a __cpuid() function for gcc compilers, for Intel and MSVC +// is already available as an intrinsic. +#if defined(__INTEL_COMPILER) +#include +#elif defined(_MSC_VER) +#include +#elif defined(__GNUC__) +inline void __cpuid(unsigned int op, + unsigned int *eax, unsigned int *ebx, + unsigned int *ecx, unsigned int *edx) +{ + *eax = op; + *ecx = 0; + __asm__("cpuid" : "=a" (*eax), "=b" (*ebx), "=c" (*ecx), "=d" (*edx) + : "0" (*eax), "2" (*ecx)); +} +#endif + #endif // !defined(TYPES_H_INCLUDED)