Fix codegen for x86-64 on systems (like ppc or i386) that don't have 64-bit

features autodetected.  This fixes PR1010 and Regression/CodeGen/X86/xmm-r64.ll
on non-x86-64 hosts.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@31879 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chris Lattner 2006-11-20 18:16:05 +00:00
parent 32ba1aa204
commit 3b6f497873

View File

@ -78,10 +78,10 @@ void X86Subtarget::AutoDetectSubtargetFeatures() {
unsigned u[3]; unsigned u[3];
char c[12]; char c[12];
} text; } text;
if (X86::GetCpuIDAndInfo(0, &EAX, text.u+0, text.u+2, text.u+1)) if (X86::GetCpuIDAndInfo(0, &EAX, text.u+0, text.u+2, text.u+1))
return; return;
// FIXME: support for AMD family of processors. // FIXME: support for AMD family of processors.
if (memcmp(text.c, "GenuineIntel", 12) == 0) { if (memcmp(text.c, "GenuineIntel", 12) == 0) {
X86::GetCpuIDAndInfo(0x1, &EAX, &EBX, &ECX, &EDX); X86::GetCpuIDAndInfo(0x1, &EAX, &EBX, &ECX, &EDX);
@ -205,14 +205,23 @@ X86Subtarget::X86Subtarget(const Module &M, const std::string &FS, bool is64Bit)
// If feature string is not empty, parse features string. // If feature string is not empty, parse features string.
std::string CPU = GetCurrentX86CPU(); std::string CPU = GetCurrentX86CPU();
ParseSubtargetFeatures(FS, CPU); ParseSubtargetFeatures(FS, CPU);
} else
// Otherwise, use CPUID to auto-detect feature set. if (Is64Bit && !HasX86_64)
AutoDetectSubtargetFeatures();
if (Is64Bit && !HasX86_64) {
std::cerr << "Warning: Generation of 64-bit code for a 32-bit processor " std::cerr << "Warning: Generation of 64-bit code for a 32-bit processor "
"requested.\n"; "requested.\n";
HasX86_64 = true; if (Is64Bit && X86SSELevel < SSE2)
std::cerr << "Warning: 64-bit processors all have at least SSE2.\n";
} else {
// Otherwise, use CPUID to auto-detect feature set.
AutoDetectSubtargetFeatures();
}
// If requesting codegen for X86-64, make sure that 64-bit and SSE2 features
// are enabled. These are available on all x86-64 CPUs.
if (Is64Bit) {
HasX86_64 = true;
if (X86SSELevel < SSE2)
X86SSELevel = SSE2;
} }
// Set the boolean corresponding to the current target triple, or the default // Set the boolean corresponding to the current target triple, or the default