Using __cpuid intrinsic on x86 and x64 windows

This commit is contained in:
Ianos Gnatiuc 2006-09-24 15:27:44 +00:00
parent abc9111f96
commit 7ee7d90171

View File

@ -31,6 +31,7 @@
#if defined(__WIN32__) #if defined(__WIN32__)
#include <windows.h> #include <windows.h>
#include <intrin.h>
#elif defined(__GNUC__) #elif defined(__GNUC__)
#include <sys/utsname.h> #include <sys/utsname.h>
#endif #endif
@ -49,23 +50,14 @@
// ------------------------------------------------------------------ // ------------------------------------------------------------------
#if defined(_M_X64)
inline static bool HaveCPUID()
{
return false;
}
#else
inline static bool HaveCPUID() inline static bool HaveCPUID()
{ {
// TO_PORT_TAG: CPUID // TO_PORT_TAG: CPUID
#if defined(_MSC_VER) #if defined(_MSC_VER)
__try __try
{ {
__asm int CPUInfo[4];
{ __cpuid(CPUInfo, 0);
xor eax, eax
cpuid
}
} }
__except(EXCEPTION_EXECUTE_HANDLER) __except(EXCEPTION_EXECUTE_HANDLER)
{ {
@ -79,7 +71,6 @@ inline static bool HaveCPUID()
return false; return false;
#endif #endif
} }
#endif
// ------------------------------------------------------------------ // ------------------------------------------------------------------
@ -333,12 +324,6 @@ static void cpuname(int family, int model, const char *v_name, char *m_name)
// ------------------------------------------------------------------ // ------------------------------------------------------------------
#if defined(_M_X64)
char *gcpuid(char *_cpuname)
{
return "";
}
#else
char *gcpuid(char *_cpuname) char *gcpuid(char *_cpuname)
{ {
#if defined(__GNUC__) && defined(__i386__) || defined(_MSC_VER) #if defined(__GNUC__) && defined(__i386__) || defined(_MSC_VER)
@ -369,33 +354,22 @@ char *gcpuid(char *_cpuname)
#endif #endif
#if defined(_MSC_VER) #if defined(_MSC_VER)
#undef and // and is defined as &&, this is conflicted with assembler instruction "and"
__asm int CPUInfo[4];
{
// get the vendor string // get the vendor string
xor eax, eax __cpuid(CPUInfo, 0);
cpuid scpuid.dw.dw0 = CPUInfo[1];
// mov scpuid.cpu_high, eax scpuid.dw.dw1 = CPUInfo[3];
mov scpuid.dw.dw0, ebx scpuid.dw.dw2 = CPUInfo[2];
mov scpuid.dw.dw1, edx
mov scpuid.dw.dw2, ecx
// get the CPU family, model, stepping, features bits // get the CPU family, model, stepping, features bits
mov eax, 1 __cpuid(CPUInfo, 1);
cpuid scpuid.stepping = CPUInfo[0] & 0x0F;
// mov scpuid.features, edx scpuid.model = (CPUInfo[0] >> 4) & 0x0F;
mov bx, ax scpuid.family = (CPUInfo[0] >> 8) & 0x0F;
and ax, 0x0F0F // 3855 // 0x0F0F
mov scpuid.stepping, al
mov scpuid.family, ah
shr bl, 4
mov scpuid.model,bl
}
#define and && cpuname(scpuid.family, scpuid.model, scpuid.vendor, _cpuname);
cpuname( scpuid.family, scpuid.model, scpuid.vendor, _cpuname);
#elif defined(__GNUC__) && defined(__i386__) #elif defined(__GNUC__) && defined(__i386__)
@ -553,7 +527,6 @@ char *gcpuid(char *_cpuname)
return _cpuname; return _cpuname;
} }
#endif
// ------------------------------------------------------------------ // ------------------------------------------------------------------
@ -667,6 +640,9 @@ char* ggetosstring(void) {
break; break;
#ifdef PROCESSOR_ARCHITECTURE_AMD64 #ifdef PROCESSOR_ARCHITECTURE_AMD64
case PROCESSOR_ARCHITECTURE_AMD64: case PROCESSOR_ARCHITECTURE_AMD64:
if (HaveCPUID())
gcpuid(processor);
else
sprintf(processor, "AMD64-%d", si.wProcessorLevel); sprintf(processor, "AMD64-%d", si.wProcessorLevel);
break; break;
#endif #endif