forked from OSchip/llvm-project
[X86][builtins] Sync getX86CpuIDAndInfoEx with llvm's Host.cpp again.
We now use __cpuidex intrinsics intead of inline asm on 32-bit Windows. We already used it on 64-bit. llvm-svn: 308420
This commit is contained in:
parent
4ea855ebe5
commit
b77279083c
|
@ -190,8 +190,8 @@ static bool getX86CpuIDAndInfo(unsigned value, unsigned *rEAX, unsigned *rEBX,
|
||||||
static bool getX86CpuIDAndInfoEx(unsigned value, unsigned subleaf,
|
static bool getX86CpuIDAndInfoEx(unsigned value, unsigned subleaf,
|
||||||
unsigned *rEAX, unsigned *rEBX, unsigned *rECX,
|
unsigned *rEAX, unsigned *rEBX, unsigned *rECX,
|
||||||
unsigned *rEDX) {
|
unsigned *rEDX) {
|
||||||
#if defined(__x86_64__) || defined(_M_X64)
|
|
||||||
#if defined(__GNUC__) || defined(__clang__)
|
#if defined(__GNUC__) || defined(__clang__)
|
||||||
|
#if defined(__x86_64__)
|
||||||
// gcc doesn't know cpuid would clobber ebx/rbx. Preserve it manually.
|
// gcc doesn't know cpuid would clobber ebx/rbx. Preserve it manually.
|
||||||
// FIXME: should we save this for Clang?
|
// FIXME: should we save this for Clang?
|
||||||
__asm__("movq\t%%rbx, %%rsi\n\t"
|
__asm__("movq\t%%rbx, %%rsi\n\t"
|
||||||
|
@ -200,6 +200,16 @@ static bool getX86CpuIDAndInfoEx(unsigned value, unsigned subleaf,
|
||||||
: "=a"(*rEAX), "=S"(*rEBX), "=c"(*rECX), "=d"(*rEDX)
|
: "=a"(*rEAX), "=S"(*rEBX), "=c"(*rECX), "=d"(*rEDX)
|
||||||
: "a"(value), "c"(subleaf));
|
: "a"(value), "c"(subleaf));
|
||||||
return false;
|
return false;
|
||||||
|
#elif defined(__i386__)
|
||||||
|
__asm__("movl\t%%ebx, %%esi\n\t"
|
||||||
|
"cpuid\n\t"
|
||||||
|
"xchgl\t%%ebx, %%esi\n\t"
|
||||||
|
: "=a"(*rEAX), "=S"(*rEBX), "=c"(*rECX), "=d"(*rEDX)
|
||||||
|
: "a"(value), "c"(subleaf));
|
||||||
|
return false;
|
||||||
|
#else
|
||||||
|
return true;
|
||||||
|
#endif
|
||||||
#elif defined(_MSC_VER)
|
#elif defined(_MSC_VER)
|
||||||
int registers[4];
|
int registers[4];
|
||||||
__cpuidex(registers, value, subleaf);
|
__cpuidex(registers, value, subleaf);
|
||||||
|
@ -211,35 +221,6 @@ static bool getX86CpuIDAndInfoEx(unsigned value, unsigned subleaf,
|
||||||
#else
|
#else
|
||||||
return true;
|
return true;
|
||||||
#endif
|
#endif
|
||||||
#elif defined(__i386__) || defined(_M_IX86)
|
|
||||||
#if defined(__GNUC__) || defined(__clang__)
|
|
||||||
__asm__("movl\t%%ebx, %%esi\n\t"
|
|
||||||
"cpuid\n\t"
|
|
||||||
"xchgl\t%%ebx, %%esi\n\t"
|
|
||||||
: "=a"(*rEAX), "=S"(*rEBX), "=c"(*rECX), "=d"(*rEDX)
|
|
||||||
: "a"(value), "c"(subleaf));
|
|
||||||
return false;
|
|
||||||
#elif defined(_MSC_VER)
|
|
||||||
__asm {
|
|
||||||
mov eax,value
|
|
||||||
mov ecx,subleaf
|
|
||||||
cpuid
|
|
||||||
mov esi,rEAX
|
|
||||||
mov dword ptr [esi],eax
|
|
||||||
mov esi,rEBX
|
|
||||||
mov dword ptr [esi],ebx
|
|
||||||
mov esi,rECX
|
|
||||||
mov dword ptr [esi],ecx
|
|
||||||
mov esi,rEDX
|
|
||||||
mov dword ptr [esi],edx
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
#else
|
|
||||||
return true;
|
|
||||||
#endif
|
|
||||||
#else
|
|
||||||
return true;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read control register 0 (XCR0). Used to detect features such as AVX.
|
// Read control register 0 (XCR0). Used to detect features such as AVX.
|
||||||
|
|
Loading…
Reference in New Issue