mirror of
https://github.com/RPCSX/llvm.git
synced 2025-04-11 04:30:52 +00:00
Ensuring that both bits are set, and not just a combination of one or the other.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@178674 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
63c32a7a9f
commit
b31b099a37
@ -152,7 +152,8 @@ std::string sys::getHostCPUName() {
|
|||||||
// If CPUID indicates support for XSAVE, XRESTORE and AVX, and XGETBV
|
// If CPUID indicates support for XSAVE, XRESTORE and AVX, and XGETBV
|
||||||
// indicates that the AVX registers will be saved and restored on context
|
// indicates that the AVX registers will be saved and restored on context
|
||||||
// switch, then we have full AVX support.
|
// switch, then we have full AVX support.
|
||||||
bool HasAVX = (ECX & ((1 << 28) | (1 << 27))) != 0 && OSHasAVXSupport();
|
const unsigned AVXBits = (1 << 27) | (1 << 28);
|
||||||
|
bool HasAVX = ((ECX & AVXBits) == AVXBits) && OSHasAVXSupport();
|
||||||
GetX86CpuIDAndInfo(0x80000001, &EAX, &EBX, &ECX, &EDX);
|
GetX86CpuIDAndInfo(0x80000001, &EAX, &EBX, &ECX, &EDX);
|
||||||
bool Em64T = (EDX >> 29) & 0x1;
|
bool Em64T = (EDX >> 29) & 0x1;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user