mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-24 03:33:20 +01:00
40810c4d1b
e.g. orl $65536, 8(%rax) => orb $1, 10(%rax) Since narrowing is not always a win, e.g. i32 -> i16 is a loss on x86, dag combiner consults with the target before performing the optimization. llvm-svn: 72507
24 lines
909 B
LLVM
24 lines
909 B
LLVM
; RUN: llvm-as < %s | llc -march=x86-64 | grep orb | count 1
|
|
; RUN: llvm-as < %s | llc -march=x86-64 | grep orb | grep 1
|
|
; RUN: llvm-as < %s | llc -march=x86-64 | grep orl | count 1
|
|
; RUN: llvm-as < %s | llc -march=x86-64 | grep orl | grep 16842752
|
|
|
|
%struct.bf = type { i64, i16, i16, i32 }
|
|
@bfi = common global %struct.bf zeroinitializer, align 16
|
|
|
|
define void @t1() nounwind optsize ssp {
|
|
entry:
|
|
%0 = load i32* bitcast (i16* getelementptr (%struct.bf* @bfi, i32 0, i32 1) to i32*), align 8
|
|
%1 = or i32 %0, 65536
|
|
store i32 %1, i32* bitcast (i16* getelementptr (%struct.bf* @bfi, i32 0, i32 1) to i32*), align 8
|
|
ret void
|
|
}
|
|
|
|
define void @t2() nounwind optsize ssp {
|
|
entry:
|
|
%0 = load i32* bitcast (i16* getelementptr (%struct.bf* @bfi, i32 0, i32 1) to i32*), align 8
|
|
%1 = or i32 %0, 16842752
|
|
store i32 %1, i32* bitcast (i16* getelementptr (%struct.bf* @bfi, i32 0, i32 1) to i32*), align 8
|
|
ret void
|
|
}
|