mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
Remove llvm-upgrade and update tests.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@48103 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
90b347dc90
commit
76806b6a43
@ -4,6 +4,7 @@
|
||||
; RUN: llvm-as < %s | llc -march=alpha | grep gprel32
|
||||
; RUN: llvm-as < %s | llc -march=alpha | grep ldl
|
||||
; RUN: llvm-as < %s | llc -march=alpha | grep rodata
|
||||
; END.
|
||||
|
||||
target datalayout = "e-p:64:64"
|
||||
target triple = "alphaev67-unknown-linux-gnu"
|
||||
|
@ -1,8 +1,8 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as > %t.bc
|
||||
; RUN: llvm-as < %s > %t.bc
|
||||
; RUN: echo | llvm-as > %t.tmp.bc
|
||||
; RUN: llvm-link %t.tmp.bc %t.bc
|
||||
|
||||
%X = constant int 5
|
||||
%Y = internal global [2 x int*] [ int* %X, int * %X]
|
||||
@X = constant i32 5 ; <i32*> [#uses=2]
|
||||
@Y = internal global [2 x i32*] [ i32* @X, i32* @X ] ; <[2 x i32*]*> [#uses=0]
|
||||
|
||||
|
||||
|
@ -1,9 +1,10 @@
|
||||
; This fails linking when it is linked with an empty file as the first object file
|
||||
|
||||
; RUN: llvm-as > %t1.bc < /dev/null
|
||||
; RUN: llvm-upgrade < %s | llvm-as > %t2.bc
|
||||
; RUN: llvm-as < %s > %t2.bc
|
||||
; RUN: llvm-link %t1.bc %t2.bc
|
||||
|
||||
%work = global int (int, int)* %zip
|
||||
@work = global i32 (i32, i32)* @zip ; <i32 (i32, i32)**> [#uses=0]
|
||||
|
||||
declare i32 @zip(i32, i32)
|
||||
|
||||
declare int %zip(int, int)
|
||||
|
@ -1,9 +1,9 @@
|
||||
; This fails linking when it is linked with an empty file as the first object file
|
||||
|
||||
; RUN: llvm-as > %t.LinkTest.bc < /dev/null
|
||||
; RUN: llvm-upgrade < %s | llvm-as > %t.bc
|
||||
; RUN: llvm-as < %s > %t.bc
|
||||
; RUN: llvm-link %t.LinkTest.bc %t.bc
|
||||
|
||||
%work = global int 4
|
||||
%test = global int* getelementptr( int* %work, long 1)
|
||||
@work = global i32 4 ; <i32*> [#uses=1]
|
||||
@test = global i32* getelementptr (i32* @work, i64 1) ; <i32**> [#uses=0]
|
||||
|
||||
|
@ -1,19 +1,17 @@
|
||||
; This one fails because the LLVM runtime is allowing two null pointers of
|
||||
; the same type to be created!
|
||||
|
||||
; RUN: echo {%T = type int} | llvm-upgrade | llvm-as > %t.2.bc
|
||||
; RUN: llvm-upgrade < %s | llvm-as -f > %t.1.bc
|
||||
; RUN: echo {%T = type i32} | llvm-as > %t.2.bc
|
||||
; RUN: llvm-as < %s -f > %t.1.bc
|
||||
; RUN: llvm-link %t.1.bc %t.2.bc
|
||||
|
||||
%T = type opaque
|
||||
|
||||
declare %T* %create()
|
||||
declare %T* @create()
|
||||
|
||||
implementation
|
||||
|
||||
void %test() {
|
||||
%X = call %T* %create()
|
||||
%v = seteq %T* %X, null
|
||||
define void @test() {
|
||||
%X = call %T* @create( ) ; <%T*> [#uses=1]
|
||||
%v = icmp eq %T* %X, null ; <i1> [#uses=0]
|
||||
ret void
|
||||
}
|
||||
|
||||
|
@ -2,9 +2,9 @@
|
||||
; the same type to be created!
|
||||
|
||||
; RUN: echo {%S = type \{ %T*\} %T = type opaque} | llvm-as > %t.2.bc
|
||||
; RUN: llvm-upgrade < %s | llvm-as > %t.1.bc
|
||||
; RUN: llvm-as < %s > %t.1.bc
|
||||
; RUN: llvm-link %t.1.bc %t.2.bc
|
||||
|
||||
%S = type { %T* }
|
||||
%T = type int
|
||||
%S = type { i32* }
|
||||
%T = type i32
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
; RUN: echo {%T = type opaque} | llvm-upgrade | llvm-as > %t.2.bc
|
||||
; RUN: llvm-upgrade < %s | llvm-as > %t.1.bc
|
||||
; RUN: echo {%T = type opaque} | llvm-as > %t.2.bc
|
||||
; RUN: llvm-as < %s > %t.1.bc
|
||||
; RUN: llvm-link %t.1.bc %t.2.bc
|
||||
|
||||
%T = type opaque
|
||||
%a = constant { %T* } { %T* null }
|
||||
@a = constant { %T* } zeroinitializer ; <{ %T* }*> [#uses=0]
|
||||
|
||||
|
@ -1,8 +1,7 @@
|
||||
; RUN: echo {%T = type int} | llvm-upgrade | llvm-as > %t.1.bc
|
||||
; RUN: llvm-upgrade < %s | llvm-as > %t.2.bc
|
||||
; RUN: echo {%T = type i32} | llvm-as > %t.1.bc
|
||||
; RUN: llvm-as < %s > %t.2.bc
|
||||
; RUN: llvm-link %t.1.bc %t.2.bc
|
||||
|
||||
%T = type opaque
|
||||
|
||||
%X = constant {%T*} {%T* null }
|
||||
@X = constant { %T* } zeroinitializer ; <{ %T* }*> [#uses=0]
|
||||
|
||||
|
@ -1,7 +1,8 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as > %t.out1.bc
|
||||
; RUN: echo {%S = type \{ int, int* \} } | llvm-upgrade | llvm-as > %t.out2.bc
|
||||
; RUN: llvm-as < %s > %t.out1.bc
|
||||
; RUN: echo {%S = type \{ i32, i32* \} } | llvm-as > %t.out2.bc
|
||||
; RUN: llvm-link %t.out1.bc %t.out2.bc
|
||||
|
||||
%S = type { i32, %T* }
|
||||
%T = type opaque
|
||||
%S = type { int, %T* }
|
||||
|
||||
;%X = global { int, %T* } { int 5, %T* null }
|
||||
|
@ -1,10 +1,10 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as > %t.out1.bc
|
||||
; RUN: echo {%S = external global \{ int, opaque* \} declare void %F(opaque*)}\
|
||||
; RUN: | llvm-upgrade | llvm-as > %t.out2.bc
|
||||
; RUN: llvm-as < %s > %t.out1.bc
|
||||
; RUN: echo {@S = external global \{ i32, opaque* \} declare void @F(opaque*)}\
|
||||
; RUN: | llvm-as > %t.out2.bc
|
||||
; RUN: llvm-link %t.out1.bc %t.out2.bc | llvm-dis | not grep opaque
|
||||
|
||||
; After linking this testcase, there should be no opaque types left. The two
|
||||
; S's should cause the opaque type to be resolved to 'int'.
|
||||
%S = global { int, int* } { int 5, int* null }
|
||||
@S = global { i32, i32* } { i32 5, i32* null } ; <{ i32, i32* }*> [#uses=0]
|
||||
|
||||
declare void %F(int*)
|
||||
declare void @F(i32*)
|
||||
|
@ -1,8 +1,9 @@
|
||||
; It's a bad idea to go recursively traipsing through types without a safety
|
||||
; net.
|
||||
|
||||
; RUN: llvm-upgrade < %s | llvm-as > %t.out1.bc
|
||||
; RUN: echo "%S = type { %S*, int* }" | llvm-upgrade | llvm-as > %t.out2.bc
|
||||
; RUN: llvm-as < %s > %t.out1.bc
|
||||
; RUN: echo "%S = type { %S*, i32* }" | llvm-as > %t.out2.bc
|
||||
; RUN: llvm-link %t.out1.bc %t.out2.bc
|
||||
|
||||
%S = type { %S*, opaque* }
|
||||
|
||||
|
@ -1,12 +1,12 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as > %t.out1.bc
|
||||
; RUN: echo "%S = type int" | llvm-upgrade | llvm-as > %t.out2.bc
|
||||
; RUN: llvm-as < %s > %t.out1.bc
|
||||
; RUN: echo "%S = type i32" | llvm-as > %t.out2.bc
|
||||
; RUN: llvm-link %t.out2.bc %t.out1.bc
|
||||
|
||||
%S = type opaque
|
||||
|
||||
void %foo(int* %V) {
|
||||
define void @foo(i32* %V) {
|
||||
ret void
|
||||
}
|
||||
|
||||
declare void %foo(%S*)
|
||||
declare void @foo.upgrd.1(%S*)
|
||||
|
||||
|
@ -1,17 +1,18 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as > %t.out1.bc
|
||||
; RUN: echo "%S = type int" | llvm-upgrade | llvm-as > %t.out2.bc
|
||||
; RUN: llvm-as < %s > %t.out1.bc
|
||||
; RUN: echo "%S = type i32" | llvm-as > %t.out2.bc
|
||||
; RUN: llvm-link %t.out2.bc %t.out1.bc
|
||||
|
||||
%S = type opaque
|
||||
|
||||
void %foo(int* %V) {
|
||||
define void @foo(i32* %V) {
|
||||
ret void
|
||||
}
|
||||
|
||||
declare void %foo(%S*)
|
||||
declare void @foo.upgrd.1(%S*)
|
||||
|
||||
void %other() {
|
||||
call void %foo(%S* null) ; Add a use of the unresolved proto
|
||||
call void %foo(int* null) ; Add a use of the resolved function
|
||||
define void @other() {
|
||||
call void @foo.upgrd.1( %S* null )
|
||||
call void @foo( i32* null )
|
||||
ret void
|
||||
}
|
||||
|
||||
|
@ -1,15 +1,15 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as > %t.out1.bc
|
||||
; RUN: echo "%S = type int" | llvm-upgrade | llvm-as > %t.out2.bc
|
||||
; RUN: llvm-as < %s > %t.out1.bc
|
||||
; RUN: echo "%S = type i32" | llvm-as > %t.out2.bc
|
||||
; RUN: llvm-link %t.out2.bc %t.out1.bc
|
||||
|
||||
%S = type opaque
|
||||
|
||||
; GLobal using the resolved function prototype
|
||||
global void(%S*)* %foo
|
||||
global void (%S*)* @foo ; <void (%S*)**>:0 [#uses=0]
|
||||
|
||||
void %foo(int* %V) {
|
||||
define void @foo.upgrd.1(i32* %V) {
|
||||
ret void
|
||||
}
|
||||
|
||||
declare void %foo(%S*)
|
||||
declare void @foo(%S*)
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as > %t.out1.bc
|
||||
; RUN: llvm-as < %s > %t.out1.bc
|
||||
; RUN: echo { %S = type \[8 x i32\] external global %S } | llvm-as > %t.out2.bc
|
||||
; RUN: llvm-link %t.out1.bc %t.out2.bc | llvm-dis | grep %S | grep \{
|
||||
|
||||
%S = type { int }
|
||||
%S = type { i32 }
|
||||
|
||||
|
||||
|
@ -1,8 +1,8 @@
|
||||
; The linker should merge link-once globals into strong external globals,
|
||||
; just like it does for weak symbols!
|
||||
|
||||
; RUN: echo "%X = global int 7" | llvm-upgrade | llvm-as > %t.2.bc
|
||||
; RUN: llvm-upgrade < %s | llvm-as > %t.1.bc
|
||||
; RUN: echo "@X = global i32 7" | llvm-as > %t.2.bc
|
||||
; RUN: llvm-as < %s > %t.1.bc
|
||||
; RUN: llvm-link %t.1.bc %t.2.bc
|
||||
|
||||
%X = linkonce global int 7
|
||||
@X = linkonce global i32 7
|
||||
|
@ -3,6 +3,7 @@
|
||||
; Test that -indvars can reduce variable stride IVs. If it can reduce variable
|
||||
; stride iv's, it will make %iv. and %m.0.0 isomorphic to each other without
|
||||
; cycles, allowing the tmp.21 subtraction to be eliminated.
|
||||
; END.
|
||||
|
||||
define void @vnum_test8(i32* %data) {
|
||||
entry:
|
||||
|
@ -6,6 +6,8 @@
|
||||
;
|
||||
; RUN: llvm-as < %s | opt -instcombine
|
||||
;
|
||||
; END.
|
||||
|
||||
@.LC0 = internal global [21 x i8] c"hbMakeCodeLengths(1)\00" ; <[21 x i8]*> [#uses=1]
|
||||
@.LC1 = internal global [21 x i8] c"hbMakeCodeLengths(2)\00" ; <[21 x i8]*> [#uses=1]
|
||||
|
||||
|
@ -11,7 +11,7 @@
|
||||
;
|
||||
; Extra code:
|
||||
; RUN: llvm-as < %s | opt -instcombine
|
||||
;
|
||||
; END.
|
||||
|
||||
target datalayout = "e-p:32:32"
|
||||
@silly = external constant i32 ; <i32*> [#uses=1]
|
||||
|
@ -11,7 +11,7 @@
|
||||
;
|
||||
; RUN: llvm-as < %s -o - | opt -instcombine | llvm-dis | \
|
||||
; RUN: notcast .*int
|
||||
|
||||
; END.
|
||||
define i1 @lt_signed_to_large_unsigned(i8 %SB) {
|
||||
%Y = sext i8 %SB to i32 ; <i32> [#uses=1]
|
||||
%C = icmp ult i32 %Y, 1024 ; <i1> [#uses=1]
|
||||
|
@ -1,4 +1,5 @@
|
||||
; RUN: llvm-as < %s | opt -instcombine -disable-output
|
||||
; END.
|
||||
%struct.DecRefPicMarking_s = type { i32, i32, i32, i32, i32, %struct.DecRefPicMarking_s* }
|
||||
%struct.datapartition = type { %typedef.Bitstream*, %typedef.DecodingEnvironment, i32 (%struct.syntaxelement*, %struct.img_par*, %struct.inp_par*, %struct.datapartition*)* }
|
||||
%struct.img_par = type { i32, i32, i32, i32, i32*, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, [16 x [16 x i16]], [6 x [32 x i32]], [16 x [16 x i32]], [4 x [12 x [4 x [4 x i32]]]], [16 x i32], i32**, i32*, i32***, i32**, i32, i32, i32, i32, %typedef.Slice*, %struct.macroblock*, i32, i32, i32, i32, i32, i32, i32**, %struct.DecRefPicMarking_s*, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, [3 x i32], i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32***, i32***, i32****, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, %struct.timeb, %struct.timeb, i32, i32, i32, i32, i32, i32, i32, i32 }
|
||||
|
@ -1,4 +1,5 @@
|
||||
; RUN: llvm-as < %s | opt -instcombine -disable-output
|
||||
; END.
|
||||
|
||||
define void @test() {
|
||||
bb38.i:
|
||||
|
@ -1,4 +1,5 @@
|
||||
; RUN: llvm-as < %s | opt -instcombine -disable-output
|
||||
; END.
|
||||
%struct.gs_matrix = type { float, i32, float, i32, float, i32, float, i32, float, i32, float, i32 }
|
||||
%struct.gx_bitmap = type { i8*, i32, i32, i32 }
|
||||
%struct.gx_device = type { i32, %struct.gx_device_procs*, i8*, i32, i32, float, float, i32, i16, i32, i32 }
|
||||
|
@ -1,5 +1,6 @@
|
||||
; PR905
|
||||
; RUN: llvm-as < %s | opt -instcombine -disable-output
|
||||
; END.
|
||||
|
||||
%RPYTHON_EXCEPTION = type { %RPYTHON_EXCEPTION_VTABLE* }
|
||||
%RPYTHON_EXCEPTION_VTABLE = type { %RPYTHON_EXCEPTION_VTABLE*, i32, i32, %RPyOpaque_RuntimeTypeInfo*, %arraytype_Char*, %functiontype_12* }
|
||||
|
@ -1,5 +1,6 @@
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: grep {icmp sgt}
|
||||
; END.
|
||||
target datalayout = "e-p:32:32"
|
||||
target triple = "i686-pc-linux-gnu"
|
||||
%struct.point = type { i32, i32 }
|
||||
|
@ -1,4 +1,5 @@
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep select
|
||||
; END.
|
||||
|
||||
target datalayout = "e-p:32:32"
|
||||
target triple = "i686-pc-linux-gnu"
|
||||
|
@ -1,5 +1,6 @@
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: grep -v {icmp ult i32}
|
||||
; END.
|
||||
|
||||
target datalayout = "e-p:32:32"
|
||||
target triple = "i686-pc-linux-gnu"
|
||||
|
@ -2,6 +2,7 @@
|
||||
; RUN: grep icmp | count 1
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: grep {icmp ugt} | count 1
|
||||
; END.
|
||||
|
||||
target datalayout = "e-p:32:32"
|
||||
target triple = "i686-pc-linux-gnu"
|
||||
|
@ -1,6 +1,7 @@
|
||||
; For PR1065. This causes an assertion in instcombine if a select with two cmp
|
||||
; operands is encountered.
|
||||
; RUN: llvm-as < %s | opt -instcombine -disable-output
|
||||
; END.
|
||||
|
||||
target datalayout = "e-p:32:32"
|
||||
target triple = "i686-pc-linux-gnu"
|
||||
|
@ -1,6 +1,5 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | \
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: grep select | not grep {i32\\*}
|
||||
; END.
|
||||
|
||||
; This testcase corresponds to PR362, which notices that this horrible code
|
||||
; is generated by the C++ front-end and LLVM optimizers, which has lots of
|
||||
@ -9,28 +8,27 @@
|
||||
; Instcombine should propagate the load through the select instructions to
|
||||
; allow elimination of the extra stuff by the mem2reg pass.
|
||||
|
||||
implementation ; Functions:
|
||||
|
||||
void %_Z5test1RiS_(int* %x, int* %y) {
|
||||
define void @_Z5test1RiS_(i32* %x, i32* %y) {
|
||||
entry:
|
||||
%tmp.1.i = load int* %y ; <int> [#uses=1]
|
||||
%tmp.3.i = load int* %x ; <int> [#uses=1]
|
||||
%tmp.4.i = setlt int %tmp.1.i, %tmp.3.i ; <bool> [#uses=1]
|
||||
%retval.i = select bool %tmp.4.i, int* %y, int* %x ; <int*> [#uses=1]
|
||||
%tmp.4 = load int* %retval.i ; <int> [#uses=1]
|
||||
store int %tmp.4, int* %x
|
||||
%tmp.1.i = load i32* %y ; <i32> [#uses=1]
|
||||
%tmp.3.i = load i32* %x ; <i32> [#uses=1]
|
||||
%tmp.4.i = icmp slt i32 %tmp.1.i, %tmp.3.i ; <i1> [#uses=1]
|
||||
%retval.i = select i1 %tmp.4.i, i32* %y, i32* %x ; <i32*> [#uses=1]
|
||||
%tmp.4 = load i32* %retval.i ; <i32> [#uses=1]
|
||||
store i32 %tmp.4, i32* %x
|
||||
ret void
|
||||
}
|
||||
|
||||
void %_Z5test2RiS_(int* %x, int* %y) {
|
||||
define void @_Z5test2RiS_(i32* %x, i32* %y) {
|
||||
entry:
|
||||
%tmp.0 = alloca int ; <int*> [#uses=2]
|
||||
%tmp.2 = load int* %x ; <int> [#uses=2]
|
||||
store int %tmp.2, int* %tmp.0
|
||||
%tmp.3.i = load int* %y ; <int> [#uses=1]
|
||||
%tmp.4.i = setlt int %tmp.2, %tmp.3.i ; <bool> [#uses=1]
|
||||
%retval.i = select bool %tmp.4.i, int* %y, int* %tmp.0 ; <int*> [#uses=1]
|
||||
%tmp.6 = load int* %retval.i ; <int> [#uses=1]
|
||||
store int %tmp.6, int* %y
|
||||
%tmp.0 = alloca i32 ; <i32*> [#uses=2]
|
||||
%tmp.2 = load i32* %x ; <i32> [#uses=2]
|
||||
store i32 %tmp.2, i32* %tmp.0
|
||||
%tmp.3.i = load i32* %y ; <i32> [#uses=1]
|
||||
%tmp.4.i = icmp slt i32 %tmp.2, %tmp.3.i ; <i1> [#uses=1]
|
||||
%retval.i = select i1 %tmp.4.i, i32* %y, i32* %tmp.0 ; <i32*> [#uses=1]
|
||||
%tmp.6 = load i32* %retval.i ; <i32> [#uses=1]
|
||||
store i32 %tmp.6, i32* %y
|
||||
ret void
|
||||
}
|
||||
|
||||
|
@ -1,9 +1,10 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine -gcse -instcombine | \
|
||||
; RUN: llvm-as < %s | opt -instcombine -gcse -instcombine | \
|
||||
; RUN: llvm-dis | not grep getelementptr
|
||||
|
||||
bool %test(int* %A) {
|
||||
%B = getelementptr int* %A, int 1
|
||||
%C = getelementptr int* %A, uint 1
|
||||
%V = seteq int* %B, %C
|
||||
ret bool %V
|
||||
define i1 @test(i32* %A) {
|
||||
%B = getelementptr i32* %A, i32 1 ; <i32*> [#uses=1]
|
||||
%C = getelementptr i32* %A, i64 1 ; <i32*> [#uses=1]
|
||||
%V = icmp eq i32* %B, %C ; <i1> [#uses=1]
|
||||
ret i1 %V
|
||||
}
|
||||
|
||||
|
@ -1,9 +1,9 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | notcast
|
||||
target endian = little
|
||||
target pointersize = 32
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | notcast
|
||||
target datalayout = "e-p:32:32"
|
||||
|
||||
int *%test(int *%P) {
|
||||
%V = cast int* %P to int
|
||||
%P2 = cast int %V to int*
|
||||
ret int* %P2
|
||||
define i32* @test(i32* %P) {
|
||||
%V = ptrtoint i32* %P to i32 ; <i32> [#uses=1]
|
||||
%P2 = inttoptr i32 %V to i32* ; <i32*> [#uses=1]
|
||||
ret i32* %P2
|
||||
}
|
||||
|
||||
|
@ -1,15 +1,15 @@
|
||||
; This is the sequence of stuff that the Java front-end expands for a single
|
||||
; <= comparison. Check to make sure we turn it into a <= (only)
|
||||
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | \
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: grep -v {icmp sle} | not grep #uses
|
||||
|
||||
bool %le(int %A, int %B) {
|
||||
%c1 = setgt int %A, %B;
|
||||
%tmp = select bool %c1, int 1, int 0;
|
||||
%c2 = setlt int %A, %B;
|
||||
%result = select bool %c2, int -1, int %tmp;
|
||||
%c3 = setle int %result, 0;
|
||||
ret bool %c3;
|
||||
define i1 @le(i32 %A, i32 %B) {
|
||||
%c1 = icmp sgt i32 %A, %B ; <i1> [#uses=1]
|
||||
%tmp = select i1 %c1, i32 1, i32 0 ; <i32> [#uses=1]
|
||||
%c2 = icmp slt i32 %A, %B ; <i1> [#uses=1]
|
||||
%result = select i1 %c2, i32 -1, i32 %tmp ; <i32> [#uses=1]
|
||||
%c3 = icmp sle i32 %result, 0 ; <i1> [#uses=1]
|
||||
ret i1 %c3
|
||||
}
|
||||
|
||||
|
@ -1,251 +1,270 @@
|
||||
; This test makes sure that add instructions are properly eliminated.
|
||||
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | \
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: grep -v OK | not grep add
|
||||
; END.
|
||||
|
||||
implementation
|
||||
|
||||
int %test1(int %A) {
|
||||
%B = add int %A, 0
|
||||
ret int %B
|
||||
define i32 @test1(i32 %A) {
|
||||
%B = add i32 %A, 0 ; <i32> [#uses=1]
|
||||
ret i32 %B
|
||||
}
|
||||
|
||||
int %test2(int %A) {
|
||||
%B = add int %A, 5
|
||||
%C = add int %B, -5
|
||||
ret int %C
|
||||
define i32 @test2(i32 %A) {
|
||||
%B = add i32 %A, 5 ; <i32> [#uses=1]
|
||||
%C = add i32 %B, -5 ; <i32> [#uses=1]
|
||||
ret i32 %C
|
||||
}
|
||||
|
||||
int %test3(int %A) {
|
||||
%B = add int %A, 5
|
||||
%C = sub int %B, 5 ;; This should get converted to an add
|
||||
ret int %C
|
||||
define i32 @test3(i32 %A) {
|
||||
%B = add i32 %A, 5 ; <i32> [#uses=1]
|
||||
;; This should get converted to an add
|
||||
%C = sub i32 %B, 5 ; <i32> [#uses=1]
|
||||
ret i32 %C
|
||||
}
|
||||
|
||||
int %test4(int %A, int %B) {
|
||||
%C = sub int 0, %A
|
||||
%D = add int %B, %C ; D = B + -A = B - A
|
||||
ret int %D
|
||||
define i32 @test4(i32 %A, i32 %B) {
|
||||
%C = sub i32 0, %A ; <i32> [#uses=1]
|
||||
; D = B + -A = B - A
|
||||
%D = add i32 %B, %C ; <i32> [#uses=1]
|
||||
ret i32 %D
|
||||
}
|
||||
|
||||
int %test5(int %A, int %B) {
|
||||
%C = sub int 0, %A
|
||||
%D = add int %C, %B ; D = -A + B = B - A
|
||||
ret int %D
|
||||
define i32 @test5(i32 %A, i32 %B) {
|
||||
%C = sub i32 0, %A ; <i32> [#uses=1]
|
||||
; D = -A + B = B - A
|
||||
%D = add i32 %C, %B ; <i32> [#uses=1]
|
||||
ret i32 %D
|
||||
}
|
||||
|
||||
int %test6(int %A) {
|
||||
%B = mul int 7, %A
|
||||
%C = add int %B, %A ; C = 7*A+A == 8*A == A << 3
|
||||
ret int %C
|
||||
define i32 @test6(i32 %A) {
|
||||
%B = mul i32 7, %A ; <i32> [#uses=1]
|
||||
; C = 7*A+A == 8*A == A << 3
|
||||
%C = add i32 %B, %A ; <i32> [#uses=1]
|
||||
ret i32 %C
|
||||
}
|
||||
|
||||
int %test7(int %A) {
|
||||
%B = mul int 7, %A
|
||||
%C = add int %A, %B ; C = A+7*A == 8*A == A << 3
|
||||
ret int %C
|
||||
define i32 @test7(i32 %A) {
|
||||
%B = mul i32 7, %A ; <i32> [#uses=1]
|
||||
; C = A+7*A == 8*A == A << 3
|
||||
%C = add i32 %A, %B ; <i32> [#uses=1]
|
||||
ret i32 %C
|
||||
}
|
||||
|
||||
; (A & C1)+(B & C2) -> (A & C1)|(B & C2) iff C1&C2 == 0
|
||||
int %test8(int %A, int %B) {
|
||||
%A1 = and int %A, 7
|
||||
%B1 = and int %B, 128
|
||||
%C = add int %A1, %B1
|
||||
ret int %C
|
||||
define i32 @test8(i32 %A, i32 %B) {
|
||||
%A1 = and i32 %A, 7 ; <i32> [#uses=1]
|
||||
%B1 = and i32 %B, 128 ; <i32> [#uses=1]
|
||||
%C = add i32 %A1, %B1 ; <i32> [#uses=1]
|
||||
ret i32 %C
|
||||
}
|
||||
|
||||
int %test9(int %A) {
|
||||
%B = shl int %A, ubyte 4
|
||||
%C = add int %B, %B ; === shl int %A, 5
|
||||
ret int %C
|
||||
define i32 @test9(i32 %A) {
|
||||
%B = shl i32 %A, 4 ; <i32> [#uses=2]
|
||||
; === shl int %A, 5
|
||||
%C = add i32 %B, %B ; <i32> [#uses=1]
|
||||
ret i32 %C
|
||||
}
|
||||
|
||||
bool %test10(ubyte %A, ubyte %b) {
|
||||
%B = add ubyte %A, %b
|
||||
%c = setne ubyte %B, 0 ; === A != -b
|
||||
ret bool %c
|
||||
define i1 @test10(i8 %A, i8 %b) {
|
||||
%B = add i8 %A, %b ; <i8> [#uses=1]
|
||||
; === A != -b
|
||||
%c = icmp ne i8 %B, 0 ; <i1> [#uses=1]
|
||||
ret i1 %c
|
||||
}
|
||||
|
||||
bool %test11(ubyte %A) {
|
||||
%B = add ubyte %A, 255
|
||||
%c = setne ubyte %B, 0 ; === A != 1
|
||||
ret bool %c
|
||||
define i1 @test11(i8 %A) {
|
||||
%B = add i8 %A, -1 ; <i8> [#uses=1]
|
||||
; === A != 1
|
||||
%c = icmp ne i8 %B, 0 ; <i1> [#uses=1]
|
||||
ret i1 %c
|
||||
}
|
||||
|
||||
int %test12(int %A, int %B) {
|
||||
%C_OK = add int %B, %A ; Should be transformed into shl A, 1
|
||||
define i32 @test12(i32 %A, i32 %B) {
|
||||
; Should be transformed into shl A, 1
|
||||
%C_OK = add i32 %B, %A ; <i32> [#uses=1]
|
||||
br label %X
|
||||
X:
|
||||
%D = add int %C_OK, %A
|
||||
ret int %D
|
||||
|
||||
X: ; preds = %0
|
||||
%D = add i32 %C_OK, %A ; <i32> [#uses=1]
|
||||
ret i32 %D
|
||||
}
|
||||
|
||||
int %test13(int %A, int %B, int %C) {
|
||||
%D_OK = add int %A, %B
|
||||
%E_OK = add int %D_OK, %C
|
||||
%F = add int %E_OK, %A ;; shl A, 1
|
||||
ret int %F
|
||||
define i32 @test13(i32 %A, i32 %B, i32 %C) {
|
||||
%D_OK = add i32 %A, %B ; <i32> [#uses=1]
|
||||
%E_OK = add i32 %D_OK, %C ; <i32> [#uses=1]
|
||||
;; shl A, 1
|
||||
%F = add i32 %E_OK, %A ; <i32> [#uses=1]
|
||||
ret i32 %F
|
||||
}
|
||||
|
||||
uint %test14(uint %offset, uint %difference) {
|
||||
%tmp.2 = and uint %difference, 3
|
||||
%tmp.3_OK = add uint %tmp.2, %offset
|
||||
%tmp.5.mask = and uint %difference, 4294967292
|
||||
%tmp.8 = add uint %tmp.3_OK, %tmp.5.mask ; == add %offset, %difference
|
||||
ret uint %tmp.8
|
||||
define i32 @test14(i32 %offset, i32 %difference) {
|
||||
%tmp.2 = and i32 %difference, 3 ; <i32> [#uses=1]
|
||||
%tmp.3_OK = add i32 %tmp.2, %offset ; <i32> [#uses=1]
|
||||
%tmp.5.mask = and i32 %difference, -4 ; <i32> [#uses=1]
|
||||
; == add %offset, %difference
|
||||
%tmp.8 = add i32 %tmp.3_OK, %tmp.5.mask ; <i32> [#uses=1]
|
||||
ret i32 %tmp.8
|
||||
}
|
||||
|
||||
ubyte %test15(ubyte %A) {
|
||||
%B = add ubyte %A, 192 ; Does not effect result
|
||||
%C = and ubyte %B, 16 ; Only one bit set
|
||||
ret ubyte %C
|
||||
define i8 @test15(i8 %A) {
|
||||
; Does not effect result
|
||||
%B = add i8 %A, -64 ; <i8> [#uses=1]
|
||||
; Only one bit set
|
||||
%C = and i8 %B, 16 ; <i8> [#uses=1]
|
||||
ret i8 %C
|
||||
}
|
||||
|
||||
ubyte %test16(ubyte %A) {
|
||||
%B = add ubyte %A, 16 ; Turn this into a XOR
|
||||
%C = and ubyte %B, 16 ; Only one bit set
|
||||
ret ubyte %C
|
||||
define i8 @test16(i8 %A) {
|
||||
; Turn this into a XOR
|
||||
%B = add i8 %A, 16 ; <i8> [#uses=1]
|
||||
; Only one bit set
|
||||
%C = and i8 %B, 16 ; <i8> [#uses=1]
|
||||
ret i8 %C
|
||||
}
|
||||
|
||||
int %test17(int %A) {
|
||||
%B = xor int %A, -1
|
||||
%C = add int %B, 1 ; == sub int 0, %A
|
||||
ret int %C
|
||||
define i32 @test17(i32 %A) {
|
||||
%B = xor i32 %A, -1 ; <i32> [#uses=1]
|
||||
; == sub int 0, %A
|
||||
%C = add i32 %B, 1 ; <i32> [#uses=1]
|
||||
ret i32 %C
|
||||
}
|
||||
|
||||
ubyte %test18(ubyte %A) {
|
||||
%B = xor ubyte %A, 255
|
||||
%C = add ubyte %B, 17 ; == sub ubyte 16, %A
|
||||
ret ubyte %C
|
||||
define i8 @test18(i8 %A) {
|
||||
%B = xor i8 %A, -1 ; <i8> [#uses=1]
|
||||
; == sub ubyte 16, %A
|
||||
%C = add i8 %B, 17 ; <i8> [#uses=1]
|
||||
ret i8 %C
|
||||
}
|
||||
|
||||
int %test19(bool %C) {
|
||||
%A = select bool %C, int 1000, int 10
|
||||
%V = add int %A, 123
|
||||
ret int %V
|
||||
define i32 @test19(i1 %C) {
|
||||
%A = select i1 %C, i32 1000, i32 10 ; <i32> [#uses=1]
|
||||
%V = add i32 %A, 123 ; <i32> [#uses=1]
|
||||
ret i32 %V
|
||||
}
|
||||
|
||||
int %test20(int %x) {
|
||||
%tmp.2 = xor int %x, -2147483648
|
||||
define i32 @test20(i32 %x) {
|
||||
%tmp.2 = xor i32 %x, -2147483648 ; <i32> [#uses=1]
|
||||
;; Add of sign bit -> xor of sign bit.
|
||||
%tmp.4 = add int %tmp.2, -2147483648
|
||||
ret int %tmp.4
|
||||
%tmp.4 = add i32 %tmp.2, -2147483648 ; <i32> [#uses=1]
|
||||
ret i32 %tmp.4
|
||||
}
|
||||
|
||||
bool %test21(uint %x) {
|
||||
%t = add uint %x, 4
|
||||
%y = seteq uint %t, 123
|
||||
ret bool %y
|
||||
define i1 @test21(i32 %x) {
|
||||
%t = add i32 %x, 4 ; <i32> [#uses=1]
|
||||
%y = icmp eq i32 %t, 123 ; <i1> [#uses=1]
|
||||
ret i1 %y
|
||||
}
|
||||
|
||||
int %test22(uint %V) {
|
||||
%V2 = add uint %V, 10
|
||||
switch uint %V2, label %Default [
|
||||
uint 20, label %Lab1
|
||||
uint 30, label %Lab2
|
||||
define i32 @test22(i32 %V) {
|
||||
%V2 = add i32 %V, 10 ; <i32> [#uses=1]
|
||||
switch i32 %V2, label %Default [
|
||||
i32 20, label %Lab1
|
||||
i32 30, label %Lab2
|
||||
]
|
||||
Default:
|
||||
ret int 123
|
||||
Lab1:
|
||||
ret int 12312
|
||||
Lab2:
|
||||
ret int 1231231
|
||||
|
||||
Default: ; preds = %0
|
||||
ret i32 123
|
||||
|
||||
Lab1: ; preds = %0
|
||||
ret i32 12312
|
||||
|
||||
Lab2: ; preds = %0
|
||||
ret i32 1231231
|
||||
}
|
||||
|
||||
int %test23(bool %C, int %a) {
|
||||
define i32 @test23(i1 %C, i32 %a) {
|
||||
entry:
|
||||
br bool %C, label %endif, label %else
|
||||
br i1 %C, label %endif, label %else
|
||||
|
||||
else:
|
||||
else: ; preds = %entry
|
||||
br label %endif
|
||||
|
||||
endif:
|
||||
%b.0 = phi int [ 0, %entry ], [ 1, %else ]
|
||||
%tmp.4 = add int %b.0, 1
|
||||
ret int %tmp.4
|
||||
endif: ; preds = %else, %entry
|
||||
%b.0 = phi i32 [ 0, %entry ], [ 1, %else ] ; <i32> [#uses=1]
|
||||
%tmp.4 = add i32 %b.0, 1 ; <i32> [#uses=1]
|
||||
ret i32 %tmp.4
|
||||
}
|
||||
|
||||
int %test24(int %A) {
|
||||
%B = add int %A, 1
|
||||
%C = shl int %B, ubyte 1
|
||||
%D = sub int %C, 2
|
||||
ret int %D ;; A << 1
|
||||
define i32 @test24(i32 %A) {
|
||||
%B = add i32 %A, 1 ; <i32> [#uses=1]
|
||||
%C = shl i32 %B, 1 ; <i32> [#uses=1]
|
||||
%D = sub i32 %C, 2 ; <i32> [#uses=1]
|
||||
ret i32 %D
|
||||
}
|
||||
|
||||
long %test25(long %Y) {
|
||||
%tmp.4 = shl long %Y, ubyte 2
|
||||
%tmp.12 = shl long %Y, ubyte 2
|
||||
%tmp.8 = add long %tmp.4, %tmp.12 ;; Y << 3
|
||||
ret long %tmp.8
|
||||
define i64 @test25(i64 %Y) {
|
||||
%tmp.4 = shl i64 %Y, 2 ; <i64> [#uses=1]
|
||||
%tmp.12 = shl i64 %Y, 2 ; <i64> [#uses=1]
|
||||
%tmp.8 = add i64 %tmp.4, %tmp.12 ; <i64> [#uses=1]
|
||||
ret i64 %tmp.8
|
||||
}
|
||||
|
||||
int %test26(int %A, int %B) {
|
||||
%C = add int %A, %B
|
||||
%D = sub int %C, %B
|
||||
ret int %D
|
||||
define i32 @test26(i32 %A, i32 %B) {
|
||||
%C = add i32 %A, %B ; <i32> [#uses=1]
|
||||
%D = sub i32 %C, %B ; <i32> [#uses=1]
|
||||
ret i32 %D
|
||||
}
|
||||
|
||||
int %test27(bool %C, int %X, int %Y) {
|
||||
%A = add int %X, %Y
|
||||
%B = add int %Y, 123
|
||||
%C = select bool %C, int %A, int %B ;; Fold add through select.
|
||||
%D = sub int %C, %Y
|
||||
ret int %D
|
||||
define i32 @test27(i1 %C, i32 %X, i32 %Y) {
|
||||
%A = add i32 %X, %Y ; <i32> [#uses=1]
|
||||
%B = add i32 %Y, 123 ; <i32> [#uses=1]
|
||||
;; Fold add through select.
|
||||
%C.upgrd.1 = select i1 %C, i32 %A, i32 %B ; <i32> [#uses=1]
|
||||
%D = sub i32 %C.upgrd.1, %Y ; <i32> [#uses=1]
|
||||
ret i32 %D
|
||||
}
|
||||
|
||||
int %test28(int %X) {
|
||||
%Y = add int %X, 1234
|
||||
%Z = sub int 42, %Y
|
||||
ret int %Z
|
||||
define i32 @test28(i32 %X) {
|
||||
%Y = add i32 %X, 1234 ; <i32> [#uses=1]
|
||||
%Z = sub i32 42, %Y ; <i32> [#uses=1]
|
||||
ret i32 %Z
|
||||
}
|
||||
|
||||
uint %test29(uint %X, uint %x) {
|
||||
%tmp.2 = sub uint %X, %x
|
||||
%tmp.2.mask = and uint %tmp.2, 63 ; <uint> [#uses=1]
|
||||
%tmp.6 = add uint %tmp.2.mask, %x ; <uint> [#uses=1]
|
||||
%tmp.7 = and uint %tmp.6, 63 ; <uint> [#uses=1]
|
||||
%tmp.9 = and uint %tmp.2, 4294967232 ; <uint> [#uses=1]
|
||||
%tmp.10 = or uint %tmp.7, %tmp.9 ; <uint> [#uses=1]
|
||||
ret uint %tmp.10
|
||||
define i32 @test29(i32 %X, i32 %x) {
|
||||
%tmp.2 = sub i32 %X, %x ; <i32> [#uses=2]
|
||||
%tmp.2.mask = and i32 %tmp.2, 63 ; <i32> [#uses=1]
|
||||
%tmp.6 = add i32 %tmp.2.mask, %x ; <i32> [#uses=1]
|
||||
%tmp.7 = and i32 %tmp.6, 63 ; <i32> [#uses=1]
|
||||
%tmp.9 = and i32 %tmp.2, -64 ; <i32> [#uses=1]
|
||||
%tmp.10 = or i32 %tmp.7, %tmp.9 ; <i32> [#uses=1]
|
||||
ret i32 %tmp.10
|
||||
}
|
||||
|
||||
long %test30(long %x) {
|
||||
%tmp.2 = xor long %x, -9223372036854775808
|
||||
define i64 @test30(i64 %x) {
|
||||
%tmp.2 = xor i64 %x, -9223372036854775808 ; <i64> [#uses=1]
|
||||
;; Add of sign bit -> xor of sign bit.
|
||||
%tmp.4 = add long %tmp.2, -9223372036854775808
|
||||
ret long %tmp.4
|
||||
%tmp.4 = add i64 %tmp.2, -9223372036854775808 ; <i64> [#uses=1]
|
||||
ret i64 %tmp.4
|
||||
}
|
||||
|
||||
int %test31(int %A) {
|
||||
%B = add int %A, 4
|
||||
%C = mul int %B, 5
|
||||
%D = sub int %C, 20
|
||||
ret int %D
|
||||
define i32 @test31(i32 %A) {
|
||||
%B = add i32 %A, 4 ; <i32> [#uses=1]
|
||||
%C = mul i32 %B, 5 ; <i32> [#uses=1]
|
||||
%D = sub i32 %C, 20 ; <i32> [#uses=1]
|
||||
ret i32 %D
|
||||
}
|
||||
|
||||
int %test32(int %A) {
|
||||
%B = add int %A, 4
|
||||
%C = shl int %B, ubyte 2
|
||||
%D = sub int %C, 16
|
||||
ret int %D
|
||||
define i32 @test32(i32 %A) {
|
||||
%B = add i32 %A, 4 ; <i32> [#uses=1]
|
||||
%C = shl i32 %B, 2 ; <i32> [#uses=1]
|
||||
%D = sub i32 %C, 16 ; <i32> [#uses=1]
|
||||
ret i32 %D
|
||||
}
|
||||
|
||||
ubyte %test33(ubyte %A) { ;; OR A, 1
|
||||
%B = and ubyte %A, 254
|
||||
%C = add ubyte %B, 1
|
||||
ret ubyte %C
|
||||
define i8 @test33(i8 %A) {
|
||||
%B = and i8 %A, -2 ; <i8> [#uses=1]
|
||||
%C = add i8 %B, 1 ; <i8> [#uses=1]
|
||||
ret i8 %C
|
||||
}
|
||||
|
||||
ubyte %test34(ubyte %A) {
|
||||
%B = add ubyte %A, 64 ;; dead
|
||||
%C = and ubyte %B, 12
|
||||
ret ubyte %C
|
||||
define i8 @test34(i8 %A) {
|
||||
%B = add i8 %A, 64 ; <i8> [#uses=1]
|
||||
%C = and i8 %B, 12 ; <i8> [#uses=1]
|
||||
ret i8 %C
|
||||
}
|
||||
|
||||
int %test35(int %a) { ;; -> -1
|
||||
%tmpnot = xor int %a, -1
|
||||
%tmp2 = add int %tmpnot, %a
|
||||
ret int %tmp2
|
||||
define i32 @test35(i32 %a) {
|
||||
%tmpnot = xor i32 %a, -1 ; <i32> [#uses=1]
|
||||
%tmp2 = add i32 %tmpnot, %a ; <i32> [#uses=1]
|
||||
ret i32 %tmp2
|
||||
}
|
||||
|
||||
|
@ -1,29 +1,31 @@
|
||||
; Zero byte allocas should be deleted.
|
||||
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | \
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: not grep alloca
|
||||
; END.
|
||||
|
||||
declare void %use(...)
|
||||
void %test() {
|
||||
%X = alloca [0 x int]
|
||||
call void(...)* %use([0 x int] *%X)
|
||||
%Y = alloca int, uint 0
|
||||
call void(...)* %use(int* %Y)
|
||||
%Z = alloca {}
|
||||
call void(...)* %use({}* %Z)
|
||||
declare void @use(...)
|
||||
|
||||
define void @test() {
|
||||
%X = alloca [0 x i32] ; <[0 x i32]*> [#uses=1]
|
||||
call void (...)* @use( [0 x i32]* %X )
|
||||
%Y = alloca i32, i32 0 ; <i32*> [#uses=1]
|
||||
call void (...)* @use( i32* %Y )
|
||||
%Z = alloca { } ; <{ }*> [#uses=1]
|
||||
call void (...)* @use( { }* %Z )
|
||||
ret void
|
||||
}
|
||||
|
||||
void %test2() {
|
||||
%A = alloca int ;; dead.
|
||||
store int 123, int* %A
|
||||
define void @test2() {
|
||||
%A = alloca i32 ; <i32*> [#uses=1]
|
||||
store i32 123, i32* %A
|
||||
ret void
|
||||
}
|
||||
|
||||
void %test3() {
|
||||
%A = alloca {int} ;; dead.
|
||||
%B = getelementptr {int}* %A, int 0, uint 0
|
||||
store int 123, int* %B
|
||||
define void @test3() {
|
||||
%A = alloca { i32 } ; <{ i32 }*> [#uses=1]
|
||||
%B = getelementptr { i32 }* %A, i32 0, i32 0 ; <i32*> [#uses=1]
|
||||
store i32 123, i32* %B
|
||||
ret void
|
||||
}
|
||||
|
||||
|
@ -1,11 +1,11 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | \
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: grep and | count 1
|
||||
|
||||
; Should be optimized to one and.
|
||||
bool %test1(uint %a, uint %b) {
|
||||
%tmp1 = and uint %a, 65280
|
||||
%tmp3 = and uint %b, 65280
|
||||
%tmp = setne uint %tmp1, %tmp3
|
||||
ret bool %tmp
|
||||
define i1 @test1(i32 %a, i32 %b) {
|
||||
%tmp1 = and i32 %a, 65280 ; <i32> [#uses=1]
|
||||
%tmp3 = and i32 %b, 65280 ; <i32> [#uses=1]
|
||||
%tmp = icmp ne i32 %tmp1, %tmp3 ; <i1> [#uses=1]
|
||||
ret i1 %tmp
|
||||
}
|
||||
|
||||
|
@ -9,48 +9,53 @@
|
||||
;
|
||||
; Which corresponds to test1.
|
||||
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | \
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: not grep {or }
|
||||
; END.
|
||||
|
||||
int %test1(int %X, int %Y) {
|
||||
%A = and int %X, 7
|
||||
%B = and int %Y, 8
|
||||
%C = or int %A, %B
|
||||
%D = and int %C, 7 ;; This cannot include any bits from %Y!
|
||||
ret int %D
|
||||
define i32 @test1(i32 %X, i32 %Y) {
|
||||
%A = and i32 %X, 7 ; <i32> [#uses=1]
|
||||
%B = and i32 %Y, 8 ; <i32> [#uses=1]
|
||||
%C = or i32 %A, %B ; <i32> [#uses=1]
|
||||
;; This cannot include any bits from %Y!
|
||||
%D = and i32 %C, 7 ; <i32> [#uses=1]
|
||||
ret i32 %D
|
||||
}
|
||||
|
||||
int %test2(int %X, ubyte %Y) {
|
||||
%B = cast ubyte %Y to int
|
||||
%C = or int %X, %B
|
||||
%D = and int %C, 65536 ;; This cannot include any bits from %Y!
|
||||
ret int %D
|
||||
define i32 @test2(i32 %X, i8 %Y) {
|
||||
%B = zext i8 %Y to i32 ; <i32> [#uses=1]
|
||||
%C = or i32 %X, %B ; <i32> [#uses=1]
|
||||
;; This cannot include any bits from %Y!
|
||||
%D = and i32 %C, 65536 ; <i32> [#uses=1]
|
||||
ret i32 %D
|
||||
}
|
||||
|
||||
int %test3(int %X, int %Y) {
|
||||
%B = shl int %Y, ubyte 1
|
||||
%C = or int %X, %B
|
||||
%D = and int %C, 1 ;; This cannot include any bits from %Y!
|
||||
ret int %D
|
||||
define i32 @test3(i32 %X, i32 %Y) {
|
||||
%B = shl i32 %Y, 1 ; <i32> [#uses=1]
|
||||
%C = or i32 %X, %B ; <i32> [#uses=1]
|
||||
;; This cannot include any bits from %Y!
|
||||
%D = and i32 %C, 1 ; <i32> [#uses=1]
|
||||
ret i32 %D
|
||||
}
|
||||
|
||||
uint %test4(uint %X, uint %Y) {
|
||||
%B = shr uint %Y, ubyte 31
|
||||
%C = or uint %X, %B
|
||||
%D = and uint %C, 2 ;; This cannot include any bits from %Y!
|
||||
ret uint %D
|
||||
define i32 @test4(i32 %X, i32 %Y) {
|
||||
%B = lshr i32 %Y, 31 ; <i32> [#uses=1]
|
||||
%C = or i32 %X, %B ; <i32> [#uses=1]
|
||||
;; This cannot include any bits from %Y!
|
||||
%D = and i32 %C, 2 ; <i32> [#uses=1]
|
||||
ret i32 %D
|
||||
}
|
||||
|
||||
int %or_test1(int %X, int %Y) {
|
||||
%A = and int %X, 1
|
||||
%B = or int %A, 1 ;; This cannot include any bits from X!
|
||||
ret int %B
|
||||
define i32 @or_test1(i32 %X, i32 %Y) {
|
||||
%A = and i32 %X, 1 ; <i32> [#uses=1]
|
||||
;; This cannot include any bits from X!
|
||||
%B = or i32 %A, 1 ; <i32> [#uses=1]
|
||||
ret i32 %B
|
||||
}
|
||||
|
||||
ubyte %or_test2(ubyte %X, ubyte %Y) {
|
||||
%A = shl ubyte %X, ubyte 7
|
||||
%B = or ubyte %A, 128 ;; This cannot include any bits from X!
|
||||
ret ubyte %B
|
||||
define i8 @or_test2(i8 %X, i8 %Y) {
|
||||
%A = shl i8 %X, 7 ; <i8> [#uses=1]
|
||||
;; This cannot include any bits from X!
|
||||
%B = or i8 %A, -128 ; <i8> [#uses=1]
|
||||
ret i8 %B
|
||||
}
|
||||
|
||||
|
@ -1,229 +1,255 @@
|
||||
; This test makes sure that these instructions are properly eliminated.
|
||||
;
|
||||
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | not grep and
|
||||
; END.
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | not grep and
|
||||
|
||||
implementation
|
||||
|
||||
int %test1(int %A) {
|
||||
%B = and int %A, 0 ; zero result
|
||||
ret int %B
|
||||
define i32 @test1(i32 %A) {
|
||||
; zero result
|
||||
%B = and i32 %A, 0 ; <i32> [#uses=1]
|
||||
ret i32 %B
|
||||
}
|
||||
|
||||
int %test2(int %A) {
|
||||
%B = and int %A, -1 ; noop
|
||||
ret int %B
|
||||
define i32 @test2(i32 %A) {
|
||||
; noop
|
||||
%B = and i32 %A, -1 ; <i32> [#uses=1]
|
||||
ret i32 %B
|
||||
}
|
||||
|
||||
bool %test3(bool %A) {
|
||||
%B = and bool %A, false ; always = false
|
||||
ret bool %B
|
||||
define i1 @test3(i1 %A) {
|
||||
; always = false
|
||||
%B = and i1 %A, false ; <i1> [#uses=1]
|
||||
ret i1 %B
|
||||
}
|
||||
|
||||
bool %test4(bool %A) {
|
||||
%B = and bool %A, true ; noop
|
||||
ret bool %B
|
||||
define i1 @test4(i1 %A) {
|
||||
; noop
|
||||
%B = and i1 %A, true ; <i1> [#uses=1]
|
||||
ret i1 %B
|
||||
}
|
||||
|
||||
int %test5(int %A) {
|
||||
%B = and int %A, %A
|
||||
ret int %B
|
||||
define i32 @test5(i32 %A) {
|
||||
%B = and i32 %A, %A ; <i32> [#uses=1]
|
||||
ret i32 %B
|
||||
}
|
||||
|
||||
bool %test6(bool %A) {
|
||||
%B = and bool %A, %A
|
||||
ret bool %B
|
||||
define i1 @test6(i1 %A) {
|
||||
%B = and i1 %A, %A ; <i1> [#uses=1]
|
||||
ret i1 %B
|
||||
}
|
||||
|
||||
int %test7(int %A) { ; A & ~A == 0
|
||||
%NotA = xor int %A, -1
|
||||
%B = and int %A, %NotA
|
||||
ret int %B
|
||||
; A & ~A == 0
|
||||
define i32 @test7(i32 %A) {
|
||||
%NotA = xor i32 %A, -1 ; <i32> [#uses=1]
|
||||
%B = and i32 %A, %NotA ; <i32> [#uses=1]
|
||||
ret i32 %B
|
||||
}
|
||||
|
||||
ubyte %test8(ubyte %A) { ; AND associates
|
||||
%B = and ubyte %A, 3
|
||||
%C = and ubyte %B, 4
|
||||
ret ubyte %C
|
||||
; AND associates
|
||||
define i8 @test8(i8 %A) {
|
||||
%B = and i8 %A, 3 ; <i8> [#uses=1]
|
||||
%C = and i8 %B, 4 ; <i8> [#uses=1]
|
||||
ret i8 %C
|
||||
}
|
||||
|
||||
bool %test9(int %A) {
|
||||
%B = and int %A, -2147483648 ; Test of sign bit, convert to setle %A, 0
|
||||
%C = setne int %B, 0
|
||||
ret bool %C
|
||||
define i1 @test9(i32 %A) {
|
||||
; Test of sign bit, convert to setle %A, 0
|
||||
%B = and i32 %A, -2147483648 ; <i32> [#uses=1]
|
||||
%C = icmp ne i32 %B, 0 ; <i1> [#uses=1]
|
||||
ret i1 %C
|
||||
}
|
||||
|
||||
bool %test9(uint %A) {
|
||||
%B = and uint %A, 2147483648 ; Test of sign bit, convert to setle %A, 0
|
||||
%C = setne uint %B, 0
|
||||
ret bool %C
|
||||
define i1 @test9a(i32 %A) {
|
||||
; Test of sign bit, convert to setle %A, 0
|
||||
%B = and i32 %A, -2147483648 ; <i32> [#uses=1]
|
||||
%C = icmp ne i32 %B, 0 ; <i1> [#uses=1]
|
||||
ret i1 %C
|
||||
}
|
||||
|
||||
uint %test10(uint %A) {
|
||||
%B = and uint %A, 12
|
||||
%C = xor uint %B, 15
|
||||
%D = and uint %C, 1 ; (X ^ C1) & C2 --> (X & C2) ^ (C1&C2)
|
||||
ret uint %D
|
||||
define i32 @test10(i32 %A) {
|
||||
%B = and i32 %A, 12 ; <i32> [#uses=1]
|
||||
%C = xor i32 %B, 15 ; <i32> [#uses=1]
|
||||
; (X ^ C1) & C2 --> (X & C2) ^ (C1&C2)
|
||||
%D = and i32 %C, 1 ; <i32> [#uses=1]
|
||||
ret i32 %D
|
||||
}
|
||||
|
||||
uint %test11(uint %A, uint* %P) {
|
||||
%B = or uint %A, 3
|
||||
%C = xor uint %B, 12
|
||||
store uint %C, uint* %P ; additional use of C
|
||||
%D = and uint %C, 3 ; %C = and uint %B, 3 --> 3
|
||||
ret uint %D
|
||||
define i32 @test11(i32 %A, i32* %P) {
|
||||
%B = or i32 %A, 3 ; <i32> [#uses=1]
|
||||
%C = xor i32 %B, 12 ; <i32> [#uses=2]
|
||||
; additional use of C
|
||||
store i32 %C, i32* %P
|
||||
; %C = and uint %B, 3 --> 3
|
||||
%D = and i32 %C, 3 ; <i32> [#uses=1]
|
||||
ret i32 %D
|
||||
}
|
||||
|
||||
bool %test12(uint %A, uint %B) {
|
||||
%C1 = setlt uint %A, %B
|
||||
%C2 = setle uint %A, %B
|
||||
%D = and bool %C1, %C2 ; (A < B) & (A <= B) === (A < B)
|
||||
ret bool %D
|
||||
define i1 @test12(i32 %A, i32 %B) {
|
||||
%C1 = icmp ult i32 %A, %B ; <i1> [#uses=1]
|
||||
%C2 = icmp ule i32 %A, %B ; <i1> [#uses=1]
|
||||
; (A < B) & (A <= B) === (A < B)
|
||||
%D = and i1 %C1, %C2 ; <i1> [#uses=1]
|
||||
ret i1 %D
|
||||
}
|
||||
|
||||
bool %test13(uint %A, uint %B) {
|
||||
%C1 = setlt uint %A, %B
|
||||
%C2 = setgt uint %A, %B
|
||||
%D = and bool %C1, %C2 ; (A < B) & (A > B) === false
|
||||
ret bool %D
|
||||
define i1 @test13(i32 %A, i32 %B) {
|
||||
%C1 = icmp ult i32 %A, %B ; <i1> [#uses=1]
|
||||
%C2 = icmp ugt i32 %A, %B ; <i1> [#uses=1]
|
||||
; (A < B) & (A > B) === false
|
||||
%D = and i1 %C1, %C2 ; <i1> [#uses=1]
|
||||
ret i1 %D
|
||||
}
|
||||
|
||||
bool %test14(ubyte %A) {
|
||||
%B = and ubyte %A, 128
|
||||
%C = setne ubyte %B, 0
|
||||
ret bool %C
|
||||
define i1 @test14(i8 %A) {
|
||||
%B = and i8 %A, -128 ; <i8> [#uses=1]
|
||||
%C = icmp ne i8 %B, 0 ; <i1> [#uses=1]
|
||||
ret i1 %C
|
||||
}
|
||||
|
||||
ubyte %test15(ubyte %A) {
|
||||
%B = shr ubyte %A, ubyte 7
|
||||
%C = and ubyte %B, 2 ; Always equals zero
|
||||
ret ubyte %C
|
||||
define i8 @test15(i8 %A) {
|
||||
%B = lshr i8 %A, 7 ; <i8> [#uses=1]
|
||||
; Always equals zero
|
||||
%C = and i8 %B, 2 ; <i8> [#uses=1]
|
||||
ret i8 %C
|
||||
}
|
||||
|
||||
ubyte %test16(ubyte %A) {
|
||||
%B = shl ubyte %A, ubyte 2
|
||||
%C = and ubyte %B, 3
|
||||
ret ubyte %C
|
||||
define i8 @test16(i8 %A) {
|
||||
%B = shl i8 %A, 2 ; <i8> [#uses=1]
|
||||
%C = and i8 %B, 3 ; <i8> [#uses=1]
|
||||
ret i8 %C
|
||||
}
|
||||
|
||||
sbyte %test17(sbyte %X, sbyte %Y) { ;; ~(~X & Y) --> (X | ~Y)
|
||||
%B = xor sbyte %X, -1
|
||||
%C = and sbyte %B, %Y
|
||||
%D = xor sbyte %C, -1
|
||||
ret sbyte %D
|
||||
;; ~(~X & Y) --> (X | ~Y)
|
||||
define i8 @test17(i8 %X, i8 %Y) {
|
||||
%B = xor i8 %X, -1 ; <i8> [#uses=1]
|
||||
%C = and i8 %B, %Y ; <i8> [#uses=1]
|
||||
%D = xor i8 %C, -1 ; <i8> [#uses=1]
|
||||
ret i8 %D
|
||||
}
|
||||
|
||||
bool %test18(int %A) {
|
||||
%B = and int %A, -128
|
||||
%C = setne int %B, 0 ;; C >= 128
|
||||
ret bool %C
|
||||
define i1 @test18(i32 %A) {
|
||||
%B = and i32 %A, -128 ; <i32> [#uses=1]
|
||||
;; C >= 128
|
||||
%C = icmp ne i32 %B, 0 ; <i1> [#uses=1]
|
||||
ret i1 %C
|
||||
}
|
||||
|
||||
bool %test18a(ubyte %A) {
|
||||
%B = and ubyte %A, 254
|
||||
%C = seteq ubyte %B, 0
|
||||
ret bool %C
|
||||
define i1 @test18a(i8 %A) {
|
||||
%B = and i8 %A, -2 ; <i8> [#uses=1]
|
||||
%C = icmp eq i8 %B, 0 ; <i1> [#uses=1]
|
||||
ret i1 %C
|
||||
}
|
||||
|
||||
int %test19(int %A) {
|
||||
%B = shl int %A, ubyte 3
|
||||
%C = and int %B, -2 ;; Clearing a zero bit
|
||||
ret int %C
|
||||
define i32 @test19(i32 %A) {
|
||||
%B = shl i32 %A, 3 ; <i32> [#uses=1]
|
||||
;; Clearing a zero bit
|
||||
%C = and i32 %B, -2 ; <i32> [#uses=1]
|
||||
ret i32 %C
|
||||
}
|
||||
|
||||
ubyte %test20(ubyte %A) {
|
||||
%C = shr ubyte %A, ubyte 7
|
||||
%D = and ubyte %C, 1 ;; Unneeded
|
||||
ret ubyte %D
|
||||
define i8 @test20(i8 %A) {
|
||||
%C = lshr i8 %A, 7 ; <i8> [#uses=1]
|
||||
;; Unneeded
|
||||
%D = and i8 %C, 1 ; <i8> [#uses=1]
|
||||
ret i8 %D
|
||||
}
|
||||
|
||||
bool %test22(int %A) {
|
||||
%B = seteq int %A, 1
|
||||
%C = setge int %A, 3
|
||||
%D = and bool %B, %C ;; False
|
||||
ret bool %D
|
||||
define i1 @test22(i32 %A) {
|
||||
%B = icmp eq i32 %A, 1 ; <i1> [#uses=1]
|
||||
%C = icmp sge i32 %A, 3 ; <i1> [#uses=1]
|
||||
;; false
|
||||
%D = and i1 %B, %C ; <i1> [#uses=1]
|
||||
ret i1 %D
|
||||
}
|
||||
|
||||
bool %test23(int %A) {
|
||||
%B = setgt int %A, 1
|
||||
%C = setle int %A, 2
|
||||
%D = and bool %B, %C ;; A == 2
|
||||
ret bool %D
|
||||
define i1 @test23(i32 %A) {
|
||||
%B = icmp sgt i32 %A, 1 ; <i1> [#uses=1]
|
||||
%C = icmp sle i32 %A, 2 ; <i1> [#uses=1]
|
||||
;; A == 2
|
||||
%D = and i1 %B, %C ; <i1> [#uses=1]
|
||||
ret i1 %D
|
||||
}
|
||||
|
||||
bool %test24(int %A) {
|
||||
%B = setgt int %A, 1
|
||||
%C = setne int %A, 2
|
||||
%D = and bool %B, %C ;; A > 2
|
||||
ret bool %D
|
||||
define i1 @test24(i32 %A) {
|
||||
%B = icmp sgt i32 %A, 1 ; <i1> [#uses=1]
|
||||
%C = icmp ne i32 %A, 2 ; <i1> [#uses=1]
|
||||
;; A > 2
|
||||
%D = and i1 %B, %C ; <i1> [#uses=1]
|
||||
ret i1 %D
|
||||
}
|
||||
|
||||
bool %test25(int %A) {
|
||||
%B = setge int %A, 50
|
||||
%C = setlt int %A, 100
|
||||
%D = and bool %B, %C ;; (A-50) <u 50
|
||||
ret bool %D
|
||||
define i1 @test25(i32 %A) {
|
||||
%B = icmp sge i32 %A, 50 ; <i1> [#uses=1]
|
||||
%C = icmp slt i32 %A, 100 ; <i1> [#uses=1]
|
||||
;; (A-50) <u 50
|
||||
%D = and i1 %B, %C ; <i1> [#uses=1]
|
||||
ret i1 %D
|
||||
}
|
||||
|
||||
bool %test26(int %A) {
|
||||
%B = setne int %A, 50
|
||||
%C = setne int %A, 51
|
||||
%D = and bool %B, %C ;; (A-50) > 1
|
||||
ret bool %D
|
||||
define i1 @test26(i32 %A) {
|
||||
%B = icmp ne i32 %A, 50 ; <i1> [#uses=1]
|
||||
%C = icmp ne i32 %A, 51 ; <i1> [#uses=1]
|
||||
;; (A-50) > 1
|
||||
%D = and i1 %B, %C ; <i1> [#uses=1]
|
||||
ret i1 %D
|
||||
}
|
||||
|
||||
ubyte %test27(ubyte %A) {
|
||||
%B = and ubyte %A, 4
|
||||
%C = sub ubyte %B, 16
|
||||
%D = and ubyte %C, 240 ;; 0xF0
|
||||
%E = add ubyte %D, 16
|
||||
ret ubyte %E
|
||||
define i8 @test27(i8 %A) {
|
||||
%B = and i8 %A, 4 ; <i8> [#uses=1]
|
||||
%C = sub i8 %B, 16 ; <i8> [#uses=1]
|
||||
;; 0xF0
|
||||
%D = and i8 %C, -16 ; <i8> [#uses=1]
|
||||
%E = add i8 %D, 16 ; <i8> [#uses=1]
|
||||
ret i8 %E
|
||||
}
|
||||
|
||||
int %test28(int %X) { ;; This is juse a zero extending shr.
|
||||
%Y = shr int %X, ubyte 24 ;; Sign extend
|
||||
%Z = and int %Y, 255 ;; Mask out sign bits
|
||||
ret int %Z
|
||||
;; This is juse a zero extending shr.
|
||||
define i32 @test28(i32 %X) {
|
||||
;; Sign extend
|
||||
%Y = ashr i32 %X, 24 ; <i32> [#uses=1]
|
||||
;; Mask out sign bits
|
||||
%Z = and i32 %Y, 255 ; <i32> [#uses=1]
|
||||
ret i32 %Z
|
||||
}
|
||||
|
||||
int %test29(ubyte %X) {
|
||||
%Y = cast ubyte %X to int
|
||||
%Z = and int %Y, 255 ;; Zero extend makes this unneeded.
|
||||
ret int %Z
|
||||
define i32 @test29(i8 %X) {
|
||||
%Y = zext i8 %X to i32 ; <i32> [#uses=1]
|
||||
;; Zero extend makes this unneeded.
|
||||
%Z = and i32 %Y, 255 ; <i32> [#uses=1]
|
||||
ret i32 %Z
|
||||
}
|
||||
|
||||
int %test30(bool %X) {
|
||||
%Y = cast bool %X to int
|
||||
%Z = and int %Y, 1
|
||||
ret int %Z
|
||||
define i32 @test30(i1 %X) {
|
||||
%Y = zext i1 %X to i32 ; <i32> [#uses=1]
|
||||
%Z = and i32 %Y, 1 ; <i32> [#uses=1]
|
||||
ret i32 %Z
|
||||
}
|
||||
|
||||
uint %test31(bool %X) {
|
||||
%Y = cast bool %X to uint
|
||||
%Z = shl uint %Y, ubyte 4
|
||||
%A = and uint %Z, 16
|
||||
ret uint %A
|
||||
define i32 @test31(i1 %X) {
|
||||
%Y = zext i1 %X to i32 ; <i32> [#uses=1]
|
||||
%Z = shl i32 %Y, 4 ; <i32> [#uses=1]
|
||||
%A = and i32 %Z, 16 ; <i32> [#uses=1]
|
||||
ret i32 %A
|
||||
}
|
||||
|
||||
uint %test32(uint %In) {
|
||||
%Y = and uint %In, 16
|
||||
%Z = shr uint %Y, ubyte 2
|
||||
%A = and uint %Z, 1
|
||||
ret uint %A
|
||||
define i32 @test32(i32 %In) {
|
||||
%Y = and i32 %In, 16 ; <i32> [#uses=1]
|
||||
%Z = lshr i32 %Y, 2 ; <i32> [#uses=1]
|
||||
%A = and i32 %Z, 1 ; <i32> [#uses=1]
|
||||
ret i32 %A
|
||||
}
|
||||
|
||||
uint %test33(uint %b) { ;; Code corresponding to one-bit bitfield ^1.
|
||||
%tmp.4.mask = and uint %b, 1
|
||||
%tmp.10 = xor uint %tmp.4.mask, 1
|
||||
%tmp.12 = and uint %b, 4294967294
|
||||
%tmp.13 = or uint %tmp.12, %tmp.10
|
||||
ret uint %tmp.13
|
||||
;; Code corresponding to one-bit bitfield ^1.
|
||||
define i32 @test33(i32 %b) {
|
||||
%tmp.4.mask = and i32 %b, 1 ; <i32> [#uses=1]
|
||||
%tmp.10 = xor i32 %tmp.4.mask, 1 ; <i32> [#uses=1]
|
||||
%tmp.12 = and i32 %b, -2 ; <i32> [#uses=1]
|
||||
%tmp.13 = or i32 %tmp.12, %tmp.10 ; <i32> [#uses=1]
|
||||
ret i32 %tmp.13
|
||||
}
|
||||
|
||||
int %test34(int %A, int %B) {
|
||||
%tmp.2 = or int %B, %A
|
||||
%tmp.4 = and int %tmp.2, %B
|
||||
ret int %tmp.4
|
||||
define i32 @test34(i32 %A, i32 %B) {
|
||||
%tmp.2 = or i32 %B, %A ; <i32> [#uses=1]
|
||||
%tmp.4 = and i32 %tmp.2, %B ; <i32> [#uses=1]
|
||||
ret i32 %tmp.4
|
||||
}
|
||||
|
||||
|
@ -1,26 +1,26 @@
|
||||
; This file contains various testcases that require tracking whether bits are
|
||||
; set or cleared by various instructions.
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine -instcombine | llvm-dis |\
|
||||
; RUN: llvm-as < %s | opt -instcombine -instcombine | llvm-dis |\
|
||||
; RUN: not grep %ELIM
|
||||
|
||||
; Reduce down to a single XOR
|
||||
int %test3(int %B) {
|
||||
%ELIMinc = and int %B, 1
|
||||
%tmp.5 = xor int %ELIMinc, 1
|
||||
%ELIM7 = and int %B, -2
|
||||
%tmp.8 = or int %tmp.5, %ELIM7
|
||||
ret int %tmp.8
|
||||
define i32 @test3(i32 %B) {
|
||||
%ELIMinc = and i32 %B, 1 ; <i32> [#uses=1]
|
||||
%tmp.5 = xor i32 %ELIMinc, 1 ; <i32> [#uses=1]
|
||||
%ELIM7 = and i32 %B, -2 ; <i32> [#uses=1]
|
||||
%tmp.8 = or i32 %tmp.5, %ELIM7 ; <i32> [#uses=1]
|
||||
ret i32 %tmp.8
|
||||
}
|
||||
|
||||
; Finally, a bigger case where we chain things together. This corresponds to
|
||||
; incrementing a single-bit bitfield, which should become just an xor.
|
||||
int %test4(int %B) {
|
||||
%ELIM3 = shl int %B, ubyte 31
|
||||
%ELIM4 = shr int %ELIM3, ubyte 31
|
||||
%inc = add int %ELIM4, 1
|
||||
%ELIM5 = and int %inc, 1
|
||||
%ELIM7 = and int %B, -2
|
||||
%tmp.8 = or int %ELIM5, %ELIM7
|
||||
ret int %tmp.8
|
||||
define i32 @test4(i32 %B) {
|
||||
%ELIM3 = shl i32 %B, 31 ; <i32> [#uses=1]
|
||||
%ELIM4 = ashr i32 %ELIM3, 31 ; <i32> [#uses=1]
|
||||
%inc = add i32 %ELIM4, 1 ; <i32> [#uses=1]
|
||||
%ELIM5 = and i32 %inc, 1 ; <i32> [#uses=1]
|
||||
%ELIM7 = and i32 %B, -2 ; <i32> [#uses=1]
|
||||
%tmp.8 = or i32 %ELIM5, %ELIM7 ; <i32> [#uses=1]
|
||||
ret i32 %tmp.8
|
||||
}
|
||||
|
||||
|
@ -1,29 +1,30 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine -simplifycfg | llvm-dis |\
|
||||
; RUN: llvm-as < %s | opt -instcombine -simplifycfg | llvm-dis |\
|
||||
; RUN: not grep {call void %abort}
|
||||
|
||||
%b_rec.0 = external global int
|
||||
@b_rec.0 = external global i32 ; <i32*> [#uses=2]
|
||||
|
||||
void %_Z12h000007_testv(uint *%P) {
|
||||
define void @_Z12h000007_testv(i32* %P) {
|
||||
entry:
|
||||
%tmp.2 = load int* %b_rec.0 ; <int> [#uses=1]
|
||||
%tmp.9 = or int %tmp.2, -989855744 ; <int> [#uses=2]
|
||||
%tmp.16 = and int %tmp.9, -805306369 ; <int> [#uses=2]
|
||||
%tmp.17 = and int %tmp.9, -973078529 ; <int> [#uses=1]
|
||||
store int %tmp.17, int* %b_rec.0
|
||||
%tmp.17.shrunk = cast int %tmp.16 to uint ; <uint> [#uses=1]
|
||||
%tmp.22 = and uint %tmp.17.shrunk, 3221225472 ; <uint> [#uses=1]
|
||||
%tmp.23 = seteq uint %tmp.22, 3221225472 ; <bool> [#uses=1]
|
||||
br bool %tmp.23, label %endif.0, label %then.0
|
||||
%tmp.2 = load i32* @b_rec.0 ; <i32> [#uses=1]
|
||||
%tmp.9 = or i32 %tmp.2, -989855744 ; <i32> [#uses=2]
|
||||
%tmp.16 = and i32 %tmp.9, -805306369 ; <i32> [#uses=2]
|
||||
%tmp.17 = and i32 %tmp.9, -973078529 ; <i32> [#uses=1]
|
||||
store i32 %tmp.17, i32* @b_rec.0
|
||||
%tmp.17.shrunk = bitcast i32 %tmp.16 to i32 ; <i32> [#uses=1]
|
||||
%tmp.22 = and i32 %tmp.17.shrunk, -1073741824 ; <i32> [#uses=1]
|
||||
%tmp.23 = icmp eq i32 %tmp.22, -1073741824 ; <i1> [#uses=1]
|
||||
br i1 %tmp.23, label %endif.0, label %then.0
|
||||
|
||||
then.0: ; preds = %entry
|
||||
tail call void %abort( )
|
||||
tail call void @abort( )
|
||||
unreachable
|
||||
|
||||
endif.0: ; preds = %entry
|
||||
%tmp.17.shrunk2 = cast int %tmp.16 to uint ; <uint> [#uses=1]
|
||||
%tmp.27.mask = and uint %tmp.17.shrunk2, 100663295 ; <uint> [#uses=1]
|
||||
store uint %tmp.27.mask, uint* %P
|
||||
%tmp.17.shrunk2 = bitcast i32 %tmp.16 to i32 ; <i32> [#uses=1]
|
||||
%tmp.27.mask = and i32 %tmp.17.shrunk2, 100663295 ; <i32> [#uses=1]
|
||||
store i32 %tmp.27.mask, i32* %P
|
||||
ret void
|
||||
}
|
||||
|
||||
declare void %abort()
|
||||
declare void @abort()
|
||||
|
||||
|
@ -1,28 +1,29 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | \
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: grep ret | count 3
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | \
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: not grep call.*bswap
|
||||
|
||||
bool %test1(ushort %tmp2) {
|
||||
%tmp10 = call ushort %llvm.bswap.i16( ushort %tmp2 )
|
||||
%tmp = seteq ushort %tmp10, 1
|
||||
ret bool %tmp
|
||||
define i1 @test1(i16 %tmp2) {
|
||||
%tmp10 = call i16 @llvm.bswap.i16( i16 %tmp2 ) ; <i16> [#uses=1]
|
||||
%tmp = icmp eq i16 %tmp10, 1 ; <i1> [#uses=1]
|
||||
ret i1 %tmp
|
||||
}
|
||||
|
||||
bool %test2(uint %tmp) {
|
||||
%tmp34 = tail call uint %llvm.bswap.i32( uint %tmp )
|
||||
%tmp = seteq uint %tmp34, 1
|
||||
ret bool %tmp
|
||||
define i1 @test2(i32 %tmp) {
|
||||
%tmp34 = tail call i32 @llvm.bswap.i32( i32 %tmp ) ; <i32> [#uses=1]
|
||||
%tmp.upgrd.1 = icmp eq i32 %tmp34, 1 ; <i1> [#uses=1]
|
||||
ret i1 %tmp.upgrd.1
|
||||
}
|
||||
|
||||
declare uint %llvm.bswap.i32(uint)
|
||||
declare i32 @llvm.bswap.i32(i32)
|
||||
|
||||
bool %test3(ulong %tmp) {
|
||||
%tmp34 = tail call ulong %llvm.bswap.i64( ulong %tmp )
|
||||
%tmp = seteq ulong %tmp34, 1
|
||||
ret bool %tmp
|
||||
define i1 @test3(i64 %tmp) {
|
||||
%tmp34 = tail call i64 @llvm.bswap.i64( i64 %tmp ) ; <i64> [#uses=1]
|
||||
%tmp.upgrd.2 = icmp eq i64 %tmp34, 1 ; <i1> [#uses=1]
|
||||
ret i1 %tmp.upgrd.2
|
||||
}
|
||||
|
||||
declare ulong %llvm.bswap.i64(ulong)
|
||||
declare i64 @llvm.bswap.i64(i64)
|
||||
|
||||
declare i16 @llvm.bswap.i16(i16)
|
||||
|
||||
declare ushort %llvm.bswap.i16(ushort)
|
||||
|
@ -1,62 +1,57 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | \
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: grep {call.*llvm.bswap} | count 5
|
||||
; END.
|
||||
|
||||
uint %test1(uint %i) {
|
||||
%tmp1 = shr uint %i, ubyte 24 ; <uint> [#uses=1]
|
||||
%tmp3 = shr uint %i, ubyte 8 ; <uint> [#uses=1]
|
||||
%tmp4 = and uint %tmp3, 65280 ; <uint> [#uses=1]
|
||||
%tmp5 = or uint %tmp1, %tmp4 ; <uint> [#uses=1]
|
||||
%tmp7 = shl uint %i, ubyte 8 ; <uint> [#uses=1]
|
||||
%tmp8 = and uint %tmp7, 16711680 ; <uint> [#uses=1]
|
||||
%tmp9 = or uint %tmp5, %tmp8 ; <uint> [#uses=1]
|
||||
%tmp11 = shl uint %i, ubyte 24 ; <uint> [#uses=1]
|
||||
%tmp12 = or uint %tmp9, %tmp11 ; <uint> [#uses=1]
|
||||
ret uint %tmp12
|
||||
define i32 @test1(i32 %i) {
|
||||
%tmp1 = lshr i32 %i, 24 ; <i32> [#uses=1]
|
||||
%tmp3 = lshr i32 %i, 8 ; <i32> [#uses=1]
|
||||
%tmp4 = and i32 %tmp3, 65280 ; <i32> [#uses=1]
|
||||
%tmp5 = or i32 %tmp1, %tmp4 ; <i32> [#uses=1]
|
||||
%tmp7 = shl i32 %i, 8 ; <i32> [#uses=1]
|
||||
%tmp8 = and i32 %tmp7, 16711680 ; <i32> [#uses=1]
|
||||
%tmp9 = or i32 %tmp5, %tmp8 ; <i32> [#uses=1]
|
||||
%tmp11 = shl i32 %i, 24 ; <i32> [#uses=1]
|
||||
%tmp12 = or i32 %tmp9, %tmp11 ; <i32> [#uses=1]
|
||||
ret i32 %tmp12
|
||||
}
|
||||
|
||||
uint %test2(uint %arg) {
|
||||
%tmp2 = shl uint %arg, ubyte 24 ; <uint> [#uses=1]
|
||||
%tmp4 = shl uint %arg, ubyte 8 ; <uint> [#uses=1]
|
||||
%tmp5 = and uint %tmp4, 16711680 ; <uint> [#uses=1]
|
||||
%tmp6 = or uint %tmp2, %tmp5 ; <uint> [#uses=1]
|
||||
%tmp8 = shr uint %arg, ubyte 8 ; <uint> [#uses=1]
|
||||
%tmp9 = and uint %tmp8, 65280 ; <uint> [#uses=1]
|
||||
%tmp10 = or uint %tmp6, %tmp9 ; <uint> [#uses=1]
|
||||
%tmp12 = shr uint %arg, ubyte 24 ; <uint> [#uses=1]
|
||||
%tmp14 = or uint %tmp10, %tmp12 ; <uint> [#uses=1]
|
||||
ret uint %tmp14
|
||||
define i32 @test2(i32 %arg) {
|
||||
%tmp2 = shl i32 %arg, 24 ; <i32> [#uses=1]
|
||||
%tmp4 = shl i32 %arg, 8 ; <i32> [#uses=1]
|
||||
%tmp5 = and i32 %tmp4, 16711680 ; <i32> [#uses=1]
|
||||
%tmp6 = or i32 %tmp2, %tmp5 ; <i32> [#uses=1]
|
||||
%tmp8 = lshr i32 %arg, 8 ; <i32> [#uses=1]
|
||||
%tmp9 = and i32 %tmp8, 65280 ; <i32> [#uses=1]
|
||||
%tmp10 = or i32 %tmp6, %tmp9 ; <i32> [#uses=1]
|
||||
%tmp12 = lshr i32 %arg, 24 ; <i32> [#uses=1]
|
||||
%tmp14 = or i32 %tmp10, %tmp12 ; <i32> [#uses=1]
|
||||
ret i32 %tmp14
|
||||
}
|
||||
|
||||
ushort %test3(ushort %s) {
|
||||
%tmp2 = shr ushort %s, ubyte 8
|
||||
%tmp4 = shl ushort %s, ubyte 8
|
||||
%tmp5 = or ushort %tmp2, %tmp4
|
||||
ret ushort %tmp5
|
||||
define i16 @test3(i16 %s) {
|
||||
%tmp2 = lshr i16 %s, 8 ; <i16> [#uses=1]
|
||||
%tmp4 = shl i16 %s, 8 ; <i16> [#uses=1]
|
||||
%tmp5 = or i16 %tmp2, %tmp4 ; <i16> [#uses=1]
|
||||
ret i16 %tmp5
|
||||
}
|
||||
|
||||
ushort %test4(ushort %s) {
|
||||
%tmp2 = shr ushort %s, ubyte 8
|
||||
%tmp4 = shl ushort %s, ubyte 8
|
||||
%tmp5 = or ushort %tmp4, %tmp2
|
||||
ret ushort %tmp5
|
||||
define i16 @test4(i16 %s) {
|
||||
%tmp2 = lshr i16 %s, 8 ; <i16> [#uses=1]
|
||||
%tmp4 = shl i16 %s, 8 ; <i16> [#uses=1]
|
||||
%tmp5 = or i16 %tmp4, %tmp2 ; <i16> [#uses=1]
|
||||
ret i16 %tmp5
|
||||
}
|
||||
|
||||
; unsigned short test5(unsigned short a) {
|
||||
; return ((a & 0xff00) >> 8 | (a & 0x00ff) << 8);
|
||||
;}
|
||||
ushort %test5(ushort %a) {
|
||||
%tmp = zext ushort %a to int
|
||||
%tmp1 = and int %tmp, 65280
|
||||
%tmp2 = ashr int %tmp1, ubyte 8
|
||||
%tmp2 = trunc int %tmp2 to short
|
||||
%tmp4 = and int %tmp, 255
|
||||
%tmp5 = shl int %tmp4, ubyte 8
|
||||
%tmp5 = trunc int %tmp5 to short
|
||||
%tmp = or short %tmp2, %tmp5
|
||||
%tmp6 = bitcast short %tmp to ushort
|
||||
%tmp6 = zext ushort %tmp6 to int
|
||||
%retval = trunc int %tmp6 to ushort
|
||||
ret ushort %retval
|
||||
define i16 @test5(i16 %a) {
|
||||
%tmp = zext i16 %a to i32 ; <i32> [#uses=2]
|
||||
%tmp1 = and i32 %tmp, 65280 ; <i32> [#uses=1]
|
||||
%tmp2 = ashr i32 %tmp1, 8 ; <i32> [#uses=1]
|
||||
%tmp2.upgrd.1 = trunc i32 %tmp2 to i16 ; <i16> [#uses=1]
|
||||
%tmp4 = and i32 %tmp, 255 ; <i32> [#uses=1]
|
||||
%tmp5 = shl i32 %tmp4, 8 ; <i32> [#uses=1]
|
||||
%tmp5.upgrd.2 = trunc i32 %tmp5 to i16 ; <i16> [#uses=1]
|
||||
%tmp.upgrd.3 = or i16 %tmp2.upgrd.1, %tmp5.upgrd.2 ; <i16> [#uses=1]
|
||||
%tmp6 = bitcast i16 %tmp.upgrd.3 to i16 ; <i16> [#uses=1]
|
||||
%tmp6.upgrd.4 = zext i16 %tmp6 to i32 ; <i32> [#uses=1]
|
||||
%retval = trunc i32 %tmp6.upgrd.4 to i16 ; <i16> [#uses=1]
|
||||
ret i16 %retval
|
||||
}
|
||||
|
||||
|
@ -1,16 +1,14 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | \
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: grep call | not grep bitcast
|
||||
|
||||
target endian = little
|
||||
target pointersize = 32
|
||||
target datalayout = "e-p:32:32"
|
||||
target triple = "i686-pc-linux-gnu"
|
||||
|
||||
implementation ; Functions:
|
||||
|
||||
int %main() {
|
||||
define i32 @main() {
|
||||
entry:
|
||||
%tmp = call int cast (sbyte* (int*)* %ctime to int (int*)*)( int* null )
|
||||
ret int %tmp
|
||||
%tmp = call i32 bitcast (i8* (i32*)* @ctime to i32 (i32*)*)( i32* null ) ; <i32> [#uses=1]
|
||||
ret i32 %tmp
|
||||
}
|
||||
|
||||
declare sbyte* %ctime(int*)
|
||||
declare i8* @ctime(i32*)
|
||||
|
||||
|
@ -1,17 +1,19 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis
|
||||
|
||||
declare void %llvm.memmove.i32(sbyte*, sbyte*, uint, uint)
|
||||
declare void %llvm.memcpy.i32(sbyte*, sbyte*, uint, uint)
|
||||
declare void %llvm.memset.i32(sbyte*, ubyte, uint, uint)
|
||||
@X = global i8 0 ; <i8*> [#uses=3]
|
||||
@Y = global i8 12 ; <i8*> [#uses=2]
|
||||
|
||||
%X = global sbyte 0
|
||||
%Y = global sbyte 12
|
||||
declare void @llvm.memmove.i32(i8*, i8*, i32, i32)
|
||||
|
||||
void %zero_byte_test() {
|
||||
declare void @llvm.memcpy.i32(i8*, i8*, i32, i32)
|
||||
|
||||
declare void @llvm.memset.i32(i8*, i8, i32, i32)
|
||||
|
||||
define void @zero_byte_test() {
|
||||
; These process zero bytes, so they are a noop.
|
||||
call void %llvm.memmove.i32(sbyte* %X, sbyte* %Y, uint 0, uint 100)
|
||||
call void %llvm.memcpy.i32(sbyte* %X, sbyte* %Y, uint 0, uint 100)
|
||||
call void %llvm.memset.i32(sbyte* %X, ubyte 123, uint 0, uint 100)
|
||||
call void @llvm.memmove.i32( i8* @X, i8* @Y, i32 0, i32 100 )
|
||||
call void @llvm.memcpy.i32( i8* @X, i8* @Y, i32 0, i32 100 )
|
||||
call void @llvm.memset.i32( i8* @X, i8 123, i32 0, i32 100 )
|
||||
ret void
|
||||
}
|
||||
|
||||
|
@ -1,28 +1,36 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | \
|
||||
; RUN: not grep {setne\|setle\|setge}
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: not grep {icmp ne\|icmp ule\|icmp uge}
|
||||
|
||||
int %test1(uint %X, uint %Y) {
|
||||
%C = setne uint %X, %Y
|
||||
br bool %C, label %T, label %F
|
||||
T:
|
||||
ret int 12
|
||||
F:
|
||||
ret int 123
|
||||
define i32 @test1(i32 %X, i32 %Y) {
|
||||
%C = icmp ne i32 %X, %Y ; <i1> [#uses=1]
|
||||
br i1 %C, label %T, label %F
|
||||
|
||||
T: ; preds = %0
|
||||
ret i32 12
|
||||
|
||||
F: ; preds = %0
|
||||
ret i32 123
|
||||
}
|
||||
|
||||
int %test2(uint %X, uint %Y) {
|
||||
%C = setle uint %X, %Y
|
||||
br bool %C, label %T, label %F
|
||||
T:
|
||||
ret int 12
|
||||
F:
|
||||
ret int 123
|
||||
define i32 @test2(i32 %X, i32 %Y) {
|
||||
%C = icmp ule i32 %X, %Y ; <i1> [#uses=1]
|
||||
br i1 %C, label %T, label %F
|
||||
|
||||
T: ; preds = %0
|
||||
ret i32 12
|
||||
|
||||
F: ; preds = %0
|
||||
ret i32 123
|
||||
}
|
||||
int %test3(uint %X, uint %Y) {
|
||||
%C = setge uint %X, %Y
|
||||
br bool %C, label %T, label %F
|
||||
T:
|
||||
ret int 12
|
||||
F:
|
||||
ret int 123
|
||||
|
||||
define i32 @test3(i32 %X, i32 %Y) {
|
||||
%C = icmp uge i32 %X, %Y ; <i1> [#uses=1]
|
||||
br i1 %C, label %T, label %F
|
||||
|
||||
T: ; preds = %0
|
||||
ret i32 12
|
||||
|
||||
F: ; preds = %0
|
||||
ret i32 123
|
||||
}
|
||||
|
||||
|
@ -1,16 +1,17 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | \
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: not grep bitcast
|
||||
|
||||
bool %test1(uint %val) {
|
||||
%t1 = bitcast uint %val to int
|
||||
%t2 = and int %t1, 1
|
||||
%t3 = trunc int %t2 to bool
|
||||
ret bool %t3
|
||||
define i1 @test1(i32 %val) {
|
||||
%t1 = bitcast i32 %val to i32 ; <i32> [#uses=1]
|
||||
%t2 = and i32 %t1, 1 ; <i32> [#uses=1]
|
||||
%t3 = trunc i32 %t2 to i1 ; <i1> [#uses=1]
|
||||
ret i1 %t3
|
||||
}
|
||||
|
||||
short %test1(uint %val) {
|
||||
%t1 = bitcast uint %val to int
|
||||
%t2 = and int %t1, 1
|
||||
%t3 = trunc int %t2 to short
|
||||
ret short %t3
|
||||
define i16 @test1.upgrd.1(i32 %val) {
|
||||
%t1 = bitcast i32 %val to i32 ; <i32> [#uses=1]
|
||||
%t2 = and i32 %t1, 1 ; <i32> [#uses=1]
|
||||
%t3 = trunc i32 %t2 to i16 ; <i16> [#uses=1]
|
||||
ret i16 %t3
|
||||
}
|
||||
|
||||
|
@ -1,9 +1,9 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | \
|
||||
; RUN: not grep ubyte
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: not grep i8
|
||||
|
||||
int %test1(uint %X) {
|
||||
%Y = cast uint %X to ubyte ;; Turn into an AND
|
||||
%Z = cast ubyte %Y to int
|
||||
ret int %Z
|
||||
define i32 @test1(i32 %X) {
|
||||
%Y = trunc i32 %X to i8 ; <i8> [#uses=1]
|
||||
%Z = zext i8 %Y to i32 ; <i32> [#uses=1]
|
||||
ret i32 %Z
|
||||
}
|
||||
|
||||
|
@ -1,23 +1,20 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine -globaldce | llvm-dis | \
|
||||
; RUN: llvm-as < %s | opt -instcombine -globaldce | llvm-dis | \
|
||||
; RUN: not grep Array
|
||||
|
||||
; Pulling the cast out of the load allows us to eliminate the load, and then
|
||||
; the whole array.
|
||||
|
||||
%unop = type {int }
|
||||
%op = type { float }
|
||||
%unop = type { i32 }
|
||||
@Array = internal constant [1 x %op* (%op*)*] [ %op* (%op*)* @foo ] ; <[1 x %op* (%op*)*]*> [#uses=1]
|
||||
|
||||
%Array = internal constant [1 x %op* (%op*)*] [ %op* (%op*)* %foo ]
|
||||
|
||||
implementation
|
||||
|
||||
%op* %foo(%op* %X) {
|
||||
define %op* @foo(%op* %X) {
|
||||
ret %op* %X
|
||||
}
|
||||
|
||||
%unop* %caller(%op* %O) {
|
||||
%tmp = load %unop* (%op*)** cast ([1 x %op* (%op*)*]* %Array to %unop* (%op*)**)
|
||||
%tmp.2 = call %unop* (%op*)* %tmp(%op* %O)
|
||||
define %unop* @caller(%op* %O) {
|
||||
%tmp = load %unop* (%op*)** bitcast ([1 x %op* (%op*)*]* @Array to %unop* (%op*)**); <%unop* (%op*)*> [#uses=1]
|
||||
%tmp.2 = call %unop* %tmp( %op* %O ) ; <%unop*> [#uses=1]
|
||||
ret %unop* %tmp.2
|
||||
}
|
||||
|
||||
|
@ -1,13 +1,15 @@
|
||||
; test that casted mallocs get converted to malloc of the right type
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | \
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: not grep bitcast
|
||||
|
||||
; The target datalayout is important for this test case. We have to tell
|
||||
; instcombine that the ABI alignment for a long is 4-bytes, not 8, otherwise
|
||||
; it won't do the transform.
|
||||
target datalayout = "e-i64:32:64"
|
||||
int* %test(uint %size) {
|
||||
%X = malloc long, uint %size
|
||||
%ret = bitcast long* %X to int*
|
||||
ret int* %ret
|
||||
|
||||
define i32* @test(i32 %size) {
|
||||
%X = malloc i64, i32 %size ; <i64*> [#uses=1]
|
||||
%ret = bitcast i64* %X to i32* ; <i32*> [#uses=1]
|
||||
ret i32* %ret
|
||||
}
|
||||
|
||||
|
@ -1,10 +1,11 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine -mem2reg | llvm-dis | \
|
||||
; RUN: llvm-as < %s | opt -instcombine -mem2reg | llvm-dis | \
|
||||
; RUN: not grep load
|
||||
|
||||
int %test1(uint* %P) {
|
||||
%A = alloca uint
|
||||
store uint 123, uint* %A
|
||||
%Q = cast uint* %A to int* ; Cast the result of the load not the source
|
||||
%V = load int* %Q
|
||||
ret int %V
|
||||
define i32 @test1(i32* %P) {
|
||||
%A = alloca i32 ; <i32*> [#uses=2]
|
||||
store i32 123, i32* %A
|
||||
; Cast the result of the load not the source
|
||||
%Q = bitcast i32* %A to i32* ; <i32*> [#uses=1]
|
||||
%V = load i32* %Q ; <i32> [#uses=1]
|
||||
ret i32 %V
|
||||
}
|
||||
|
@ -1,49 +1,51 @@
|
||||
; This tests for various complex cast elimination cases instcombine should
|
||||
; handle.
|
||||
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | notcast
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | notcast
|
||||
|
||||
bool %test1(int %X) {
|
||||
%A = cast int %X to uint
|
||||
%c = setne uint %A, 12 ; Convert to setne int %X, 12
|
||||
ret bool %c
|
||||
define i1 @test1(i32 %X) {
|
||||
%A = bitcast i32 %X to i32 ; <i32> [#uses=1]
|
||||
; Convert to setne int %X, 12
|
||||
%c = icmp ne i32 %A, 12 ; <i1> [#uses=1]
|
||||
ret i1 %c
|
||||
}
|
||||
|
||||
bool %test2(int %X, int %Y) {
|
||||
%A = cast int %X to uint
|
||||
%B = cast int %Y to uint
|
||||
%c = setne uint %A, %B ; Convert to setne int %X, %Y
|
||||
ret bool %c
|
||||
define i1 @test2(i32 %X, i32 %Y) {
|
||||
%A = bitcast i32 %X to i32 ; <i32> [#uses=1]
|
||||
%B = bitcast i32 %Y to i32 ; <i32> [#uses=1]
|
||||
; Convert to setne int %X, %Y
|
||||
%c = icmp ne i32 %A, %B ; <i1> [#uses=1]
|
||||
ret i1 %c
|
||||
}
|
||||
|
||||
int %test4(int %A) {
|
||||
%B = cast int %A to uint
|
||||
%C = shl uint %B, ubyte 2
|
||||
%D = cast uint %C to int
|
||||
ret int %D
|
||||
define i32 @test4(i32 %A) {
|
||||
%B = bitcast i32 %A to i32 ; <i32> [#uses=1]
|
||||
%C = shl i32 %B, 2 ; <i32> [#uses=1]
|
||||
%D = bitcast i32 %C to i32 ; <i32> [#uses=1]
|
||||
ret i32 %D
|
||||
}
|
||||
|
||||
short %test5(short %A) {
|
||||
%B = cast short %A to uint
|
||||
%C = and uint %B, 15
|
||||
%D = cast uint %C to short
|
||||
ret short %D
|
||||
define i16 @test5(i16 %A) {
|
||||
%B = sext i16 %A to i32 ; <i32> [#uses=1]
|
||||
%C = and i32 %B, 15 ; <i32> [#uses=1]
|
||||
%D = trunc i32 %C to i16 ; <i16> [#uses=1]
|
||||
ret i16 %D
|
||||
}
|
||||
|
||||
bool %test6(bool %A) {
|
||||
%B = cast bool %A to int
|
||||
%C = setne int %B, 0
|
||||
ret bool %C
|
||||
define i1 @test6(i1 %A) {
|
||||
%B = zext i1 %A to i32 ; <i32> [#uses=1]
|
||||
%C = icmp ne i32 %B, 0 ; <i1> [#uses=1]
|
||||
ret i1 %C
|
||||
}
|
||||
|
||||
bool %test6a(bool %A) {
|
||||
%B = cast bool %A to int
|
||||
%C = setne int %B, -1 ; Always true!
|
||||
ret bool %C
|
||||
define i1 @test6a(i1 %A) {
|
||||
%B = zext i1 %A to i32 ; <i32> [#uses=1]
|
||||
%C = icmp ne i32 %B, -1 ; <i1> [#uses=1]
|
||||
ret i1 %C
|
||||
}
|
||||
|
||||
bool %test7(sbyte* %A) {
|
||||
%B = cast sbyte* %A to int*
|
||||
%C = seteq int* %B, null
|
||||
ret bool %C
|
||||
define i1 @test7(i8* %A) {
|
||||
%B = bitcast i8* %A to i32* ; <i32*> [#uses=1]
|
||||
%C = icmp eq i32* %B, null ; <i1> [#uses=1]
|
||||
ret i1 %C
|
||||
}
|
||||
|
@ -1,20 +1,19 @@
|
||||
; Tests to make sure elimination of casts is working correctly
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | notcast
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | notcast
|
||||
|
||||
target pointersize = 32
|
||||
target datalayout = "p:32:32"
|
||||
|
||||
implementation
|
||||
|
||||
sbyte* %test1(sbyte* %t) {
|
||||
%tmpc = cast sbyte* %t to uint
|
||||
%tmpa = add uint %tmpc, 32
|
||||
%tv = cast uint %tmpa to sbyte*
|
||||
ret sbyte* %tv
|
||||
define i8* @test1(i8* %t) {
|
||||
%tmpc = ptrtoint i8* %t to i32 ; <i32> [#uses=1]
|
||||
%tmpa = add i32 %tmpc, 32 ; <i32> [#uses=1]
|
||||
%tv = inttoptr i32 %tmpa to i8* ; <i8*> [#uses=1]
|
||||
ret i8* %tv
|
||||
}
|
||||
|
||||
bool %test2(sbyte* %a, sbyte* %b) {
|
||||
%tmpa = cast sbyte* %a to uint
|
||||
%tmpb = cast sbyte* %b to uint
|
||||
%r = seteq uint %tmpa, %tmpb
|
||||
ret bool %r
|
||||
define i1 @test2(i8* %a, i8* %b) {
|
||||
%tmpa = ptrtoint i8* %a to i32 ; <i32> [#uses=1]
|
||||
%tmpb = ptrtoint i8* %b to i32 ; <i32> [#uses=1]
|
||||
%r = icmp eq i32 %tmpa, %tmpb ; <i1> [#uses=1]
|
||||
ret i1 %r
|
||||
}
|
||||
|
||||
|
@ -1,14 +1,15 @@
|
||||
; Test some floating point casting cases
|
||||
; RUN: llvm-upgrade %s -o - | llvm-as | opt -instcombine | llvm-dis | notcast
|
||||
; RUN: llvm-upgrade %s -o - | llvm-as | opt -instcombine | llvm-dis | \
|
||||
; RUN: llvm-as %s -o - | opt -instcombine | llvm-dis | notcast
|
||||
; RUN: llvm-as %s -o - | opt -instcombine | llvm-dis | \
|
||||
; RUN: egrep {ret i8 \(-1\)\|\(255\)}
|
||||
|
||||
sbyte %test1() {
|
||||
%x = fptoui float 255.0 to sbyte
|
||||
ret sbyte %x
|
||||
define i8 @test1() {
|
||||
%x = fptoui float 2.550000e+02 to i8 ; <i8> [#uses=1]
|
||||
ret i8 %x
|
||||
}
|
||||
|
||||
ubyte %test2() {
|
||||
%x = fptosi float -1.0 to ubyte
|
||||
ret ubyte %x
|
||||
define i8 @test2() {
|
||||
%x = fptosi float -1.000000e+00 to i8 ; <i8> [#uses=1]
|
||||
ret i8 %x
|
||||
}
|
||||
|
||||
|
@ -1,34 +1,31 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | \
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: not grep getelementptr
|
||||
; END.
|
||||
|
||||
bool %test1(short* %P, int %I, int %J) {
|
||||
%X = getelementptr short* %P, int %I
|
||||
%Y = getelementptr short* %P, int %J
|
||||
|
||||
%C = setlt short* %X, %Y
|
||||
ret bool %C
|
||||
define i1 @test1(i16* %P, i32 %I, i32 %J) {
|
||||
%X = getelementptr i16* %P, i32 %I ; <i16*> [#uses=1]
|
||||
%Y = getelementptr i16* %P, i32 %J ; <i16*> [#uses=1]
|
||||
%C = icmp ult i16* %X, %Y ; <i1> [#uses=1]
|
||||
ret i1 %C
|
||||
}
|
||||
|
||||
bool %test2(short* %P, int %I) {
|
||||
%X = getelementptr short* %P, int %I
|
||||
|
||||
%C = setlt short* %X, %P
|
||||
ret bool %C
|
||||
define i1 @test2(i16* %P, i32 %I) {
|
||||
%X = getelementptr i16* %P, i32 %I ; <i16*> [#uses=1]
|
||||
%C = icmp ult i16* %X, %P ; <i1> [#uses=1]
|
||||
ret i1 %C
|
||||
}
|
||||
|
||||
int %test3(int* %P, int %A, int %B) {
|
||||
%tmp.4 = getelementptr int* %P, int %A ; <int*> [#uses=1]
|
||||
%tmp.9 = getelementptr int* %P, int %B ; <int*> [#uses=1]
|
||||
%tmp.10 = seteq int* %tmp.4, %tmp.9 ; <bool> [#uses=1]
|
||||
%tmp.11 = cast bool %tmp.10 to int ; <int> [#uses=1]
|
||||
ret int %tmp.11
|
||||
define i32 @test3(i32* %P, i32 %A, i32 %B) {
|
||||
%tmp.4 = getelementptr i32* %P, i32 %A ; <i32*> [#uses=1]
|
||||
%tmp.9 = getelementptr i32* %P, i32 %B ; <i32*> [#uses=1]
|
||||
%tmp.10 = icmp eq i32* %tmp.4, %tmp.9 ; <i1> [#uses=1]
|
||||
%tmp.11 = zext i1 %tmp.10 to i32 ; <i32> [#uses=1]
|
||||
ret i32 %tmp.11
|
||||
}
|
||||
|
||||
int %test4(int* %P, int %A, int %B) {
|
||||
%tmp.4 = getelementptr int* %P, int %A ; <int*> [#uses=1]
|
||||
%tmp.6 = seteq int* %tmp.4, %P ; <bool> [#uses=1]
|
||||
%tmp.7 = cast bool %tmp.6 to int ; <int> [#uses=1]
|
||||
ret int %tmp.7
|
||||
define i32 @test4(i32* %P, i32 %A, i32 %B) {
|
||||
%tmp.4 = getelementptr i32* %P, i32 %A ; <i32*> [#uses=1]
|
||||
%tmp.6 = icmp eq i32* %tmp.4, %P ; <i1> [#uses=1]
|
||||
%tmp.7 = zext i1 %tmp.6 to i32 ; <i32> [#uses=1]
|
||||
ret i32 %tmp.7
|
||||
}
|
||||
|
||||
|
@ -1,11 +1,11 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | \
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: notcast {} {getelementptr.*}
|
||||
|
||||
%G = external global [3 x sbyte]
|
||||
@G = external global [3 x i8] ; <[3 x i8]*> [#uses=1]
|
||||
|
||||
implementation
|
||||
|
||||
ubyte *%foo(uint %Idx) {
|
||||
%tmp = getelementptr ubyte* cast ([3 x sbyte]* %G to ubyte*), uint %Idx
|
||||
ret ubyte* %tmp
|
||||
define i8* @foo(i32 %Idx) {
|
||||
%gep.upgrd.1 = zext i32 %Idx to i64 ; <i64> [#uses=1]
|
||||
%tmp = getelementptr i8* getelementptr ([3 x i8]* @G, i32 0, i32 0), i64 %gep.upgrd.1 ; <i8*> [#uses=1]
|
||||
ret i8* %tmp
|
||||
}
|
||||
|
||||
|
@ -1,14 +1,15 @@
|
||||
; Test folding of constantexpr geps into normal geps.
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine -gcse -instcombine | \
|
||||
; RUN: llvm-as < %s | opt -instcombine -gcse -instcombine | \
|
||||
; RUN: llvm-dis | not grep getelementptr
|
||||
|
||||
%Array = external global [40 x int]
|
||||
@Array = external global [40 x i32] ; <[40 x i32]*> [#uses=2]
|
||||
|
||||
int %test(long %X) {
|
||||
%A = getelementptr int* getelementptr ([40 x int]* %Array, long 0, long 0), long %X
|
||||
%B = getelementptr [40 x int]* %Array, long 0, long %X
|
||||
%a = cast int* %A to int
|
||||
%b = cast int* %B to int
|
||||
%c = sub int %a, %b
|
||||
ret int %c
|
||||
define i32 @test(i64 %X) {
|
||||
%A = getelementptr i32* getelementptr ([40 x i32]* @Array, i64 0, i64 0), i64 %X ; <i32*> [#uses=1]
|
||||
%B = getelementptr [40 x i32]* @Array, i64 0, i64 %X ; <i32*> [#uses=1]
|
||||
%a = ptrtoint i32* %A to i32 ; <i32> [#uses=1]
|
||||
%b = ptrtoint i32* %B to i32 ; <i32> [#uses=1]
|
||||
%c = sub i32 %a, %b ; <i32> [#uses=1]
|
||||
ret i32 %c
|
||||
}
|
||||
|
||||
|
@ -1,10 +1,9 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | grep trunc
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep trunc
|
||||
|
||||
target endian = little
|
||||
target pointersize = 32
|
||||
target datalayout = "e-p:32:32"
|
||||
|
||||
int* %test(int* %X, long %Idx) {
|
||||
; Should insert a cast to int on this target
|
||||
%R = getelementptr int* %X, long %Idx
|
||||
ret int* %R
|
||||
define i32* @test(i32* %X, i64 %Idx) {
|
||||
%R = getelementptr i32* %X, i64 %Idx ; <i32*> [#uses=1]
|
||||
ret i32* %R
|
||||
}
|
||||
|
||||
|
@ -1,17 +1,17 @@
|
||||
; RUN: llvm-upgrade < %s | llvm-as | opt -instcombine | llvm-dis | \
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: %prcontext div 1 | grep then:
|
||||
|
||||
;; This tests that the div is hoisted into the then block.
|
||||
|
||||
int %foo(bool %C, int %A, int %B) {
|
||||
define i32 @foo(i1 %C, i32 %A, i32 %B) {
|
||||
entry:
|
||||
br bool %C, label %then, label %endif
|
||||
br i1 %C, label %then, label %endif
|
||||
|
||||
then:
|
||||
then: ; preds = %entry
|
||||
br label %endif
|
||||
|
||||
endif:
|
||||
%X = phi int [%A, %then], [15, %entry]
|
||||
%Y = div int %X, 42
|
||||
ret int %Y
|
||||
endif: ; preds = %then, %entry
|
||||
%X = phi i32 [ %A, %then ], [ 15, %entry ] ; <i32> [#uses=1]
|
||||
%Y = sdiv i32 %X, 42 ; <i32> [#uses=1]
|
||||
ret i32 %Y
|
||||
}
|
||||
|
||||
|
@ -1,6 +1,7 @@
|
||||
; This test makes sure that these instructions are properly eliminated.
|
||||
;
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | not grep icmp
|
||||
; END.
|
||||
|
||||
@X = external global i32 ; <i32*> [#uses=2]
|
||||
|
||||
|
@ -3,6 +3,7 @@
|
||||
; been when a setcc is used with two casts.
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: not grep {br bool false}
|
||||
; END.
|
||||
|
||||
define i32 @bug(i8 %inbuff) {
|
||||
entry:
|
||||
|
@ -4,7 +4,7 @@
|
||||
;
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: grep -v {icmp eq} | grep -v {icmp ne} | not grep icmp
|
||||
|
||||
; END.
|
||||
|
||||
define i1 @test1(i32 %A) {
|
||||
; setne %A, 0
|
||||
|
@ -1,6 +1,7 @@
|
||||
; This test makes sure that these instructions are properly eliminated.
|
||||
;
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | not grep sh
|
||||
; END.
|
||||
|
||||
define i32 @test1(i32 %A) {
|
||||
%B = shl i32 %A, 0 ; <i32> [#uses=1]
|
||||
|
@ -1,5 +1,6 @@
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: not grep {(and\|xor\|add\|shl\|shr)}
|
||||
; END.
|
||||
|
||||
define i32 @test1(i32 %x) {
|
||||
%tmp.1 = and i32 %x, 65535 ; <i32> [#uses=1]
|
||||
|
@ -4,6 +4,7 @@
|
||||
; RUN: not grep insertelement
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: not grep extractelement
|
||||
; END.
|
||||
|
||||
define <4 x float> @test(<4 x float> %tmp, <4 x float> %tmp1) {
|
||||
%tmp4 = extractelement <4 x float> %tmp, i32 1 ; <float> [#uses=1]
|
||||
|
@ -2,6 +2,7 @@
|
||||
;
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
|
||||
; RUN: not grep {xor }
|
||||
; END.
|
||||
@G1 = global i32 0 ; <i32*> [#uses=1]
|
||||
@G2 = global i32 0 ; <i32*> [#uses=1]
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user