mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-27 06:54:30 +00:00
97eb5e9037
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. llvm-svn: 232223
11 lines
269 B
LLVM
11 lines
269 B
LLVM
; 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
|
|
}
|