mirror of
https://github.com/RPCSX/llvm.git
synced 2024-12-02 16:56:50 +00:00
[X86] Remove special handling for 16 bit for A asm constraints.
Our 16 bit support is assembler-only + the terrible hack that is .code16gcc. Simply using 32 bit registers does the right thing for the latter. Fixes PR32681. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@300429 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
8f7c2a67b8
commit
48452ec477
@ -35922,14 +35922,11 @@ X86TargetLowering::getRegForInlineAsmConstraint(const TargetRegisterInfo *TRI,
|
||||
if (Subtarget.is64Bit()) {
|
||||
Res.first = X86::RAX;
|
||||
Res.second = &X86::GR64_ADRegClass;
|
||||
} else if (Subtarget.is32Bit()) {
|
||||
} else {
|
||||
assert((Subtarget.is32Bit() || Subtarget.is16Bit()) &&
|
||||
"Expecting 64, 32 or 16 bit subtarget");
|
||||
Res.first = X86::EAX;
|
||||
Res.second = &X86::GR32_ADRegClass;
|
||||
} else if (Subtarget.is16Bit()) {
|
||||
Res.first = X86::AX;
|
||||
Res.second = &X86::GR16_ADRegClass;
|
||||
} else {
|
||||
llvm_unreachable("Expecting 64, 32 or 16 bit subtarget");
|
||||
}
|
||||
return Res;
|
||||
}
|
||||
|
@ -438,7 +438,6 @@ def LOW32_ADDR_ACCESS_RBP : RegisterClass<"X86", [i32], 32,
|
||||
(add LOW32_ADDR_ACCESS, RBP)>;
|
||||
|
||||
// A class to support the 'A' assembler constraint: [ER]AX then [ER]DX.
|
||||
def GR16_AD : RegisterClass<"X86", [i16], 16, (add AX, DX)>;
|
||||
def GR32_AD : RegisterClass<"X86", [i32], 32, (add EAX, EDX)>;
|
||||
def GR64_AD : RegisterClass<"X86", [i64], 64, (add RAX, RDX)>;
|
||||
|
||||
|
@ -12,9 +12,16 @@ define i32 @main() #0 {
|
||||
; CHECK: .code16
|
||||
; CHECK-LABEL: main
|
||||
|
||||
define i64 @foo(i32 %index) #0 {
|
||||
%asm = tail call i64 asm "rdmsr", "=A,{cx},~{dirflag},~{fpsr},~{flags}"(i32 %index)
|
||||
ret i64 %asm
|
||||
}
|
||||
|
||||
; CHECK-LABEL: foo
|
||||
; CHECK: rdmsr
|
||||
|
||||
attributes #0 = { nounwind }
|
||||
|
||||
!llvm.ident = !{!0}
|
||||
|
||||
!0 = !{!"clang version 3.9.0 (trunk 265439) (llvm/trunk 265567)"}
|
||||
!0 = !{!"clang version 3.9.0 (trunk 265439) (llvm/trunk 265567)"}
|
||||
|
Loading…
Reference in New Issue
Block a user