summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2008-10-17 17:59:52 +0000
committerChris Lattner <sabre@nondot.org>2008-10-17 17:59:52 +0000
commitc7e65f4377f383df28b6b4318354b7285e3039fd (patch)
tree012d9874515be2fd3fd27780747cfebeb8457687 /llvm/lib
parent052092bf9c1a1a32a7a59a7e91467427985fb922 (diff)
downloadbcm5719-llvm-c7e65f4377f383df28b6b4318354b7285e3039fd.tar.gz
bcm5719-llvm-c7e65f4377f383df28b6b4318354b7285e3039fd.zip
Fix a bug where the x86 backend would reject 64-bit r constraints when
in 32-bit mode instead of assigning a register pair. This has nothing to do with PR2356, but I happened to notice it while working on it. llvm-svn: 57704
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Target/X86/X86ISelLowering.cpp2
1 files changed, 1 insertions, 1 deletions
diff --git a/llvm/lib/Target/X86/X86ISelLowering.cpp b/llvm/lib/Target/X86/X86ISelLowering.cpp
index d32a9f052d4..0607797b713 100644
--- a/llvm/lib/Target/X86/X86ISelLowering.cpp
+++ b/llvm/lib/Target/X86/X86ISelLowering.cpp
@@ -7511,7 +7511,7 @@ X86TargetLowering::getRegForInlineAsmConstraint(const std::string &Constraint,
case 'l': // INDEX_REGS
if (VT == MVT::i64 && Subtarget->is64Bit())
return std::make_pair(0U, X86::GR64RegisterClass);
- if (VT == MVT::i32)
+ if (VT == MVT::i32 || VT == MVT::i64)
return std::make_pair(0U, X86::GR32RegisterClass);
else if (VT == MVT::i16)
return std::make_pair(0U, X86::GR16RegisterClass);
OpenPOWER on IntegriCloud