mirror of
https://github.com/RPCSX/llvm.git
synced 2024-11-25 04:39:44 +00:00
[X86] Add relaxtion logic for ADC instructions.
Prior to this patch, we would wrongly stick to the variant with imm8 encoding even when the relocation could not fit that size. rdar://problem/23785506 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@255570 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
46508070a4
commit
265bc7dab1
@ -204,6 +204,14 @@ static unsigned getRelaxedOpcodeArith(unsigned Op) {
|
||||
case X86::ADD64ri8: return X86::ADD64ri32;
|
||||
case X86::ADD64mi8: return X86::ADD64mi32;
|
||||
|
||||
// ADC
|
||||
case X86::ADC16ri8: return X86::ADC16ri;
|
||||
case X86::ADC16mi8: return X86::ADC16mi;
|
||||
case X86::ADC32ri8: return X86::ADC32ri;
|
||||
case X86::ADC32mi8: return X86::ADC32mi;
|
||||
case X86::ADC64ri8: return X86::ADC64ri32;
|
||||
case X86::ADC64mi8: return X86::ADC64mi32;
|
||||
|
||||
// SUB
|
||||
case X86::SUB16ri8: return X86::SUB16ri;
|
||||
case X86::SUB16mi8: return X86::SUB16mi;
|
||||
|
@ -123,3 +123,19 @@ bar:
|
||||
.section push,"x"
|
||||
pushw $foo
|
||||
push $foo
|
||||
|
||||
// CHECK: Disassembly of section adc:
|
||||
// CHECK-NEXT: adc:
|
||||
// CHECK-NEXT: 0: 66 81 d3 00 00 adcw $0, %bx
|
||||
// CHECK-NEXT: 5: 66 81 14 25 00 00 00 00 00 00 adcw $0, 0
|
||||
// CHECK-NEXT: f: 81 d3 00 00 00 00 adcl $0, %ebx
|
||||
// CHECK-NEXT: 15: 81 14 25 00 00 00 00 00 00 00 00 adcl $0, 0
|
||||
// CHECK-NEXT: 20: 48 81 d3 00 00 00 00 adcq $0, %rbx
|
||||
// CHECK-NEXT: 27: 48 81 14 25 00 00 00 00 00 00 00 00 adcq $0, 0
|
||||
.section adc,"x"
|
||||
adc $foo, %bx
|
||||
adcw $foo, bar
|
||||
adc $foo, %ebx
|
||||
adcl $foo, bar
|
||||
adc $foo, %rbx
|
||||
adcq $foo, bar
|
||||
|
Loading…
Reference in New Issue
Block a user