mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-24 21:25:41 +00:00
Use add32ri8 and friends on fast isel.
This fixes pr22854. The core issue on the bug is that there are multiple instructions that print the same in assembly. In fact, there doesn't seem to be any syntax for specifying that a constant that fits in 8 bits should use a 32 bit immediate. The attached patch changes fast isel to consider i16immSExt8, i32immSExt8, and i64immSExt8. They were disabled because fastisel didn’t know to call the predicate back in the day. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@232223 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
d5dd5dcb9c
commit
89c84b0c83
@ -855,11 +855,11 @@ def X86_COND_E_OR_NE : ImmLeaf<i8, [{
|
||||
return (Imm == X86::COND_E) || (Imm == X86::COND_NE);
|
||||
}]>;
|
||||
|
||||
let FastIselShouldIgnore = 1 in { // FastIsel should ignore all simm8 instrs.
|
||||
def i16immSExt8 : ImmLeaf<i16, [{ return Imm == (int8_t)Imm; }]>;
|
||||
def i32immSExt8 : ImmLeaf<i32, [{ return Imm == (int8_t)Imm; }]>;
|
||||
def i64immSExt8 : ImmLeaf<i64, [{ return Imm == (int8_t)Imm; }]>;
|
||||
}
|
||||
|
||||
def i16immSExt8 : ImmLeaf<i16, [{ return Imm == (int8_t)Imm; }]>;
|
||||
def i32immSExt8 : ImmLeaf<i32, [{ return Imm == (int8_t)Imm; }]>;
|
||||
def i64immSExt8 : ImmLeaf<i64, [{ return Imm == (int8_t)Imm; }]>;
|
||||
|
||||
|
||||
def i64immSExt32 : ImmLeaf<i64, [{ return Imm == (int32_t)Imm; }]>;
|
||||
|
||||
|
10
test/CodeGen/X86/add32ri8.ll
Normal file
10
test/CodeGen/X86/add32ri8.ll
Normal file
@ -0,0 +1,10 @@
|
||||
; RUN: llc -mtriple=x86_64-linux -fast-isel -show-mc-encoding < %s | FileCheck %s
|
||||
|
||||
; pr22854
|
||||
; CHECK: addl $42, %esi # encoding: [0x83,0xc6,0x2a]
|
||||
|
||||
define void @foo(i32 *%s, i32 %x) {
|
||||
%y = add nsw i32 %x, 42
|
||||
store i32 %y, i32* %s, align 4
|
||||
ret void
|
||||
}
|
@ -25,7 +25,7 @@
|
||||
; if they've changed due to a bugfix, change in register allocation, etc.
|
||||
|
||||
; CHECK: [[A]]: Beginning address index: 2
|
||||
; CHECK-NEXT: Length: 190
|
||||
; CHECK-NEXT: Length: 179
|
||||
; CHECK-NEXT: Location description: 11 00
|
||||
; CHECK-NEXT: {{^$}}
|
||||
; CHECK-NEXT: Beginning address index: 3
|
||||
|
Loading…
x
Reference in New Issue
Block a user