mirror of
https://github.com/RPCS3/llvm.git
synced 2024-11-29 14:40:39 +00:00
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. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@57704 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
0c52644cd8
commit
3d0c4c4657
@ -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);
|
||||
|
9
test/CodeGen/X86/2008-10-17-Asm64bitRConstraint.ll
Normal file
9
test/CodeGen/X86/2008-10-17-Asm64bitRConstraint.ll
Normal file
@ -0,0 +1,9 @@
|
||||
; RUN: llvm-as < %s | llc -march=x86
|
||||
; RUN: llvm-as < %s | llc -march=x86-64
|
||||
|
||||
define void @test(i64 %x) nounwind {
|
||||
entry:
|
||||
tail call void asm sideeffect "ASM: $0", "r,~{dirflag},~{fpsr},~{flags}"(i64 %x) nounwind
|
||||
ret void
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user