X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Ftypes.h;h=d91009df453748d6701ee607b177921368a7a60e;hp=a9badca0d1027538d60628cda45d87dc593ce58c;hb=92bada1a32c7ebd5f5b4438bd85bb003d20bd046;hpb=e0c47a6cebbea453a1e74ca8ce1f5f8219b9b3f8 diff --git a/src/types.h b/src/types.h index a9badca0..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; @@ -73,4 +73,22 @@ typedef uint64_t Bitboard; #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)