blob: c2cb720803194c14a00d3da5bf8499f74e844855 [file] [log] [blame]
Dan Gohmanf17a25c2007-07-18 16:29:46 +00001; The %A getelementptr instruction should be eliminated here
2
Tanya Lattner348c6182008-03-25 04:26:08 +00003; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
Dan Gohmanf17a25c2007-07-18 16:29:46 +00004; RUN: grep -v %B | not grep getelementptr
Tanya Lattner348c6182008-03-25 04:26:08 +00005; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep foo1
Dan Gohmanf17a25c2007-07-18 16:29:46 +00006; END.
7
Tanya Lattner348c6182008-03-25 04:26:08 +00008@Global = constant [10 x i8] c"helloworld" ; <[10 x i8]*> [#uses=1]
Dan Gohmanf17a25c2007-07-18 16:29:46 +00009
Tanya Lattner348c6182008-03-25 04:26:08 +000010; Test noop elimination
11define i32* @foo1(i32* %I) {
12 %A = getelementptr i32* %I, i64 0 ; <i32*> [#uses=1]
13 ret i32* %A
Dan Gohmanf17a25c2007-07-18 16:29:46 +000014}
15
Tanya Lattner348c6182008-03-25 04:26:08 +000016; Test noop elimination
17define i32* @foo2(i32* %I) {
18 %A = getelementptr i32* %I ; <i32*> [#uses=1]
19 ret i32* %A
Dan Gohmanf17a25c2007-07-18 16:29:46 +000020}
21
Tanya Lattner348c6182008-03-25 04:26:08 +000022; Test that two array indexing geps fold
23define i32* @foo3(i32* %I) {
24 %A = getelementptr i32* %I, i64 17 ; <i32*> [#uses=1]
25 %B = getelementptr i32* %A, i64 4 ; <i32*> [#uses=1]
26 ret i32* %B
Dan Gohmanf17a25c2007-07-18 16:29:46 +000027}
28
Tanya Lattner348c6182008-03-25 04:26:08 +000029; Test that two getelementptr insts fold
30define i32* @foo4({ i32 }* %I) {
31 %A = getelementptr { i32 }* %I, i64 1 ; <{ i32 }*> [#uses=1]
32 %B = getelementptr { i32 }* %A, i64 0, i32 0 ; <i32*> [#uses=1]
33 ret i32* %B
Dan Gohmanf17a25c2007-07-18 16:29:46 +000034}
35
Tanya Lattner348c6182008-03-25 04:26:08 +000036define void @foo5(i8 %B) {
37 ; This should be turned into a constexpr instead of being an instruction
38 %A = getelementptr [10 x i8]* @Global, i64 0, i64 4 ; <i8*> [#uses=1]
39 store i8 %B, i8* %A
40 ret void
Dan Gohmanf17a25c2007-07-18 16:29:46 +000041}
42
Tanya Lattner348c6182008-03-25 04:26:08 +000043define i32* @foo6() {
44 %M = malloc [4 x i32] ; <[4 x i32]*> [#uses=1]
45 %A = getelementptr [4 x i32]* %M, i64 0, i64 0 ; <i32*> [#uses=1]
46 %B = getelementptr i32* %A, i64 2 ; <i32*> [#uses=1]
47 ret i32* %B
Dan Gohmanf17a25c2007-07-18 16:29:46 +000048}
49
Tanya Lattner348c6182008-03-25 04:26:08 +000050define i32* @foo7(i32* %I, i64 %C, i64 %D) {
51 %A = getelementptr i32* %I, i64 %C ; <i32*> [#uses=1]
52 %B = getelementptr i32* %A, i64 %D ; <i32*> [#uses=1]
53 ret i32* %B
Dan Gohmanf17a25c2007-07-18 16:29:46 +000054}
55
Tanya Lattner348c6182008-03-25 04:26:08 +000056define i8* @foo8([10 x i32]* %X) {
57 ;; Fold into the cast.
58 %A = getelementptr [10 x i32]* %X, i64 0, i64 0 ; <i32*> [#uses=1]
59 %B = bitcast i32* %A to i8* ; <i8*> [#uses=1]
60 ret i8* %B
Dan Gohmanf17a25c2007-07-18 16:29:46 +000061}
62
Tanya Lattner348c6182008-03-25 04:26:08 +000063define i32 @test9() {
64 %A = getelementptr { i32, double }* null, i32 0, i32 1 ; <double*> [#uses=1]
65 %B = ptrtoint double* %A to i32 ; <i32> [#uses=1]
66 ret i32 %B
Dan Gohmanf17a25c2007-07-18 16:29:46 +000067}
68
Tanya Lattner348c6182008-03-25 04:26:08 +000069define i1 @test10({ i32, i32 }* %x, { i32, i32 }* %y) {
70 %tmp.1 = getelementptr { i32, i32 }* %x, i32 0, i32 1 ; <i32*> [#uses=1]
71 %tmp.3 = getelementptr { i32, i32 }* %y, i32 0, i32 1 ; <i32*> [#uses=1]
72 ;; seteq x, y
73 %tmp.4 = icmp eq i32* %tmp.1, %tmp.3 ; <i1> [#uses=1]
74 ret i1 %tmp.4
75}
76
77define i1 @test11({ i32, i32 }* %X) {
78 %P = getelementptr { i32, i32 }* %X, i32 0, i32 0 ; <i32*> [#uses=1]
79 %Q = icmp eq i32* %P, null ; <i1> [#uses=1]
80 ret i1 %Q
Dan Gohmanf17a25c2007-07-18 16:29:46 +000081}