X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Ftypes.h;h=d91009df453748d6701ee607b177921368a7a60e;hp=95e3f6eeb46c4357b297f308f63f666bb5679757;hb=92bada1a32c7ebd5f5b4438bd85bb003d20bd046;hpb=f3d0b76feb2f27e78832950e54702e81901ddbbc diff --git a/src/types.h b/src/types.h index 95e3f6ee..d91009df 100644 --- a/src/types.h +++ b/src/types.h @@ -33,7 +33,7 @@ typedef __int16 int16; typedef unsigned __int16 uint16_t; 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; @@ -66,4 +66,29 @@ typedef uint64_t Bitboard; #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)