blob: 949fdd0c0c92ada123e37bb08ec3fcb4b1356fda [file] [log] [blame]
Owen Anderson5ab8d4b2010-12-21 23:54:34 +00001; RUN: opt < %s -basicaa -gvn -S | FileCheck %s
2
3@a = external global i32 ; <i32*> [#uses=7]
4
Stephen Linc1c7a132013-07-14 01:42:54 +00005; CHECK-LABEL: @test1(
Duncan Sandsf4f47cc2011-10-05 14:28:49 +00006define i32 @test1() nounwind {
Owen Anderson5ab8d4b2010-12-21 23:54:34 +00007entry:
David Blaikiea79ac142015-02-27 21:17:42 +00008 %0 = load i32, i32* @a, align 4
Owen Anderson5ab8d4b2010-12-21 23:54:34 +00009 %1 = icmp eq i32 %0, 4
10 br i1 %1, label %bb, label %bb1
11
12bb: ; preds = %entry
13 br label %bb8
14
15bb1: ; preds = %entry
David Blaikiea79ac142015-02-27 21:17:42 +000016 %2 = load i32, i32* @a, align 4
Owen Anderson5ab8d4b2010-12-21 23:54:34 +000017 %3 = icmp eq i32 %2, 5
18 br i1 %3, label %bb2, label %bb3
19
20bb2: ; preds = %bb1
21 br label %bb8
22
23bb3: ; preds = %bb1
David Blaikiea79ac142015-02-27 21:17:42 +000024 %4 = load i32, i32* @a, align 4
Owen Anderson5ab8d4b2010-12-21 23:54:34 +000025 %5 = icmp eq i32 %4, 4
26; CHECK: br i1 false, label %bb4, label %bb5
27 br i1 %5, label %bb4, label %bb5
28
29bb4: ; preds = %bb3
David Blaikiea79ac142015-02-27 21:17:42 +000030 %6 = load i32, i32* @a, align 4
Owen Anderson5ab8d4b2010-12-21 23:54:34 +000031 %7 = add i32 %6, 5
32 br label %bb8
33
34bb5: ; preds = %bb3
David Blaikiea79ac142015-02-27 21:17:42 +000035 %8 = load i32, i32* @a, align 4
Owen Anderson5ab8d4b2010-12-21 23:54:34 +000036 %9 = icmp eq i32 %8, 5
37; CHECK: br i1 false, label %bb6, label %bb7
38 br i1 %9, label %bb6, label %bb7
39
40bb6: ; preds = %bb5
David Blaikiea79ac142015-02-27 21:17:42 +000041 %10 = load i32, i32* @a, align 4
Owen Anderson5ab8d4b2010-12-21 23:54:34 +000042 %11 = add i32 %10, 4
43 br label %bb8
44
45bb7: ; preds = %bb5
David Blaikiea79ac142015-02-27 21:17:42 +000046 %12 = load i32, i32* @a, align 4
Owen Anderson5ab8d4b2010-12-21 23:54:34 +000047 br label %bb8
48
49bb8: ; preds = %bb7, %bb6, %bb4, %bb2, %bb
50 %.0 = phi i32 [ %12, %bb7 ], [ %11, %bb6 ], [ %7, %bb4 ], [ 4, %bb2 ], [ 5, %bb ]
51 br label %return
52
53return: ; preds = %bb8
54 ret i32 %.0
Duncan Sandse90dd052011-10-05 14:17:01 +000055}
56
Duncan Sandsf4f47cc2011-10-05 14:28:49 +000057declare void @foo(i1)
Duncan Sandsf4f47cc2011-10-05 14:28:49 +000058declare void @bar(i32)
59
Stephen Linc1c7a132013-07-14 01:42:54 +000060; CHECK-LABEL: @test3(
Duncan Sandsf4f47cc2011-10-05 14:28:49 +000061define void @test3(i32 %x, i32 %y) {
62 %xz = icmp eq i32 %x, 0
63 %yz = icmp eq i32 %y, 0
64 %z = and i1 %xz, %yz
65 br i1 %z, label %both_zero, label %nope
66both_zero:
67 call void @foo(i1 %xz)
68; CHECK: call void @foo(i1 true)
69 call void @foo(i1 %yz)
70; CHECK: call void @foo(i1 true)
71 call void @bar(i32 %x)
72; CHECK: call void @bar(i32 0)
73 call void @bar(i32 %y)
74; CHECK: call void @bar(i32 0)
75 ret void
76nope:
77 call void @foo(i1 %z)
78; CHECK: call void @foo(i1 false)
79 ret void
80}
Duncan Sandsc52af462011-10-07 08:29:06 +000081
Stephen Linc1c7a132013-07-14 01:42:54 +000082; CHECK-LABEL: @test4(
Duncan Sandsc52af462011-10-07 08:29:06 +000083define void @test4(i1 %b, i32 %x) {
84 br i1 %b, label %sw, label %case3
85sw:
86 switch i32 %x, label %default [
87 i32 0, label %case0
88 i32 1, label %case1
89 i32 2, label %case0
90 i32 3, label %case3
91 i32 4, label %default
92 ]
93default:
94; CHECK: default:
95 call void @bar(i32 %x)
96; CHECK: call void @bar(i32 %x)
97 ret void
98case0:
99; CHECK: case0:
100 call void @bar(i32 %x)
101; CHECK: call void @bar(i32 %x)
102 ret void
103case1:
104; CHECK: case1:
105 call void @bar(i32 %x)
106; CHECK: call void @bar(i32 1)
107 ret void
108case3:
109; CHECK: case3:
110 call void @bar(i32 %x)
111; CHECK: call void @bar(i32 %x)
112 ret void
113}
Duncan Sands27f45952012-02-27 08:14:30 +0000114
Stephen Linc1c7a132013-07-14 01:42:54 +0000115; CHECK-LABEL: @test5(
Duncan Sands27f45952012-02-27 08:14:30 +0000116define i1 @test5(i32 %x, i32 %y) {
117 %cmp = icmp eq i32 %x, %y
118 br i1 %cmp, label %same, label %different
119
120same:
121 %cmp2 = icmp ne i32 %x, %y
122; CHECK: ret i1 false
123 ret i1 %cmp2
124
125different:
126 %cmp3 = icmp eq i32 %x, %y
127; CHECK: ret i1 false
128 ret i1 %cmp3
129}
130
Stephen Linc1c7a132013-07-14 01:42:54 +0000131; CHECK-LABEL: @test6(
Duncan Sands27f45952012-02-27 08:14:30 +0000132define i1 @test6(i32 %x, i32 %y) {
133 %cmp2 = icmp ne i32 %x, %y
134 %cmp = icmp eq i32 %x, %y
135 %cmp3 = icmp eq i32 %x, %y
136 br i1 %cmp, label %same, label %different
137
138same:
139; CHECK: ret i1 false
140 ret i1 %cmp2
141
142different:
143; CHECK: ret i1 false
144 ret i1 %cmp3
145}
146
Sanjay Patel5f1d9ea2015-01-12 19:29:48 +0000147; CHECK-LABEL: @test6_fp(
148define i1 @test6_fp(float %x, float %y) {
149 %cmp2 = fcmp une float %x, %y
150 %cmp = fcmp oeq float %x, %y
151 %cmp3 = fcmp oeq float %x, %y
152 br i1 %cmp, label %same, label %different
153
154same:
155; CHECK: ret i1 false
156 ret i1 %cmp2
157
158different:
159; CHECK: ret i1 false
160 ret i1 %cmp3
161}
162
Stephen Linc1c7a132013-07-14 01:42:54 +0000163; CHECK-LABEL: @test7(
Duncan Sands27f45952012-02-27 08:14:30 +0000164define i1 @test7(i32 %x, i32 %y) {
165 %cmp = icmp sgt i32 %x, %y
166 br i1 %cmp, label %same, label %different
167
168same:
169 %cmp2 = icmp sle i32 %x, %y
170; CHECK: ret i1 false
171 ret i1 %cmp2
172
173different:
174 %cmp3 = icmp sgt i32 %x, %y
175; CHECK: ret i1 false
176 ret i1 %cmp3
177}
178
Sanjay Patel5f1d9ea2015-01-12 19:29:48 +0000179; CHECK-LABEL: @test7_fp(
180define i1 @test7_fp(float %x, float %y) {
181 %cmp = fcmp ogt float %x, %y
182 br i1 %cmp, label %same, label %different
183
184same:
185 %cmp2 = fcmp ule float %x, %y
186; CHECK: ret i1 false
187 ret i1 %cmp2
188
189different:
190 %cmp3 = fcmp ogt float %x, %y
191; CHECK: ret i1 false
192 ret i1 %cmp3
193}
194
Stephen Linc1c7a132013-07-14 01:42:54 +0000195; CHECK-LABEL: @test8(
Duncan Sands27f45952012-02-27 08:14:30 +0000196define i1 @test8(i32 %x, i32 %y) {
197 %cmp2 = icmp sle i32 %x, %y
198 %cmp = icmp sgt i32 %x, %y
199 %cmp3 = icmp sgt i32 %x, %y
200 br i1 %cmp, label %same, label %different
201
202same:
203; CHECK: ret i1 false
204 ret i1 %cmp2
205
206different:
207; CHECK: ret i1 false
208 ret i1 %cmp3
209}
Duncan Sandsbb2fe652012-02-29 11:12:03 +0000210
Sanjay Patel5f1d9ea2015-01-12 19:29:48 +0000211; CHECK-LABEL: @test8_fp(
212define i1 @test8_fp(float %x, float %y) {
213 %cmp2 = fcmp ule float %x, %y
214 %cmp = fcmp ogt float %x, %y
215 %cmp3 = fcmp ogt float %x, %y
216 br i1 %cmp, label %same, label %different
217
218same:
219; CHECK: ret i1 false
220 ret i1 %cmp2
221
222different:
223; CHECK: ret i1 false
224 ret i1 %cmp3
225}
226
Duncan Sandsbb2fe652012-02-29 11:12:03 +0000227; PR1768
Stephen Linc1c7a132013-07-14 01:42:54 +0000228; CHECK-LABEL: @test9(
Duncan Sandsbb2fe652012-02-29 11:12:03 +0000229define i32 @test9(i32 %i, i32 %j) {
230 %cmp = icmp eq i32 %i, %j
231 br i1 %cmp, label %cond_true, label %ret
232
233cond_true:
234 %diff = sub i32 %i, %j
235 ret i32 %diff
236; CHECK: ret i32 0
237
238ret:
239 ret i32 5
240; CHECK: ret i32 5
241}
242
243; PR1768
Stephen Linc1c7a132013-07-14 01:42:54 +0000244; CHECK-LABEL: @test10(
Duncan Sandsbb2fe652012-02-29 11:12:03 +0000245define i32 @test10(i32 %j, i32 %i) {
246 %cmp = icmp eq i32 %i, %j
247 br i1 %cmp, label %cond_true, label %ret
248
249cond_true:
250 %diff = sub i32 %i, %j
251 ret i32 %diff
252; CHECK: ret i32 0
253
254ret:
255 ret i32 5
256; CHECK: ret i32 5
257}
258
259declare i32 @yogibar()
260
Stephen Linc1c7a132013-07-14 01:42:54 +0000261; CHECK-LABEL: @test11(
Duncan Sandsbb2fe652012-02-29 11:12:03 +0000262define i32 @test11(i32 %x) {
263 %v0 = call i32 @yogibar()
264 %v1 = call i32 @yogibar()
265 %cmp = icmp eq i32 %v0, %v1
266 br i1 %cmp, label %cond_true, label %next
267
268cond_true:
269 ret i32 %v1
270; CHECK: ret i32 %v0
271
272next:
273 %cmp2 = icmp eq i32 %x, %v0
274 br i1 %cmp2, label %cond_true2, label %next2
275
276cond_true2:
277 ret i32 %v0
278; CHECK: ret i32 %x
279
280next2:
281 ret i32 0
282}
Duncan Sands4d928e72012-03-04 13:25:19 +0000283
Stephen Linc1c7a132013-07-14 01:42:54 +0000284; CHECK-LABEL: @test12(
Duncan Sands4d928e72012-03-04 13:25:19 +0000285define i32 @test12(i32 %x) {
286 %cmp = icmp eq i32 %x, 0
287 br i1 %cmp, label %cond_true, label %cond_false
288
289cond_true:
290 br label %ret
291
292cond_false:
293 br label %ret
294
295ret:
296 %res = phi i32 [ %x, %cond_true ], [ %x, %cond_false ]
297; CHECK: %res = phi i32 [ 0, %cond_true ], [ %x, %cond_false ]
298 ret i32 %res
299}
John Brawn8967e182018-09-10 12:23:05 +0000300
301; On the path from entry->if->end we know that ptr1==ptr2, so we can determine
302; that gep2 does not alias ptr1 on that path (as it would require that
303; ptr2==ptr2+2), so we can perform PRE of the load.
304; CHECK-LABEL: @test13
305define i32 @test13(i32* %ptr1, i32* %ptr2) {
306; CHECK-LABEL: entry:
307entry:
308 %gep1 = getelementptr i32, i32* %ptr2, i32 1
309 %gep2 = getelementptr i32, i32* %ptr2, i32 2
310 %cmp = icmp eq i32* %ptr1, %ptr2
311 br i1 %cmp, label %if, label %end
312
313; CHECK: [[CRIT_EDGE:.*]]:
314; CHECK: %[[PRE:.*]] = load i32, i32* %gep2, align 4
315
316; CHECK-LABEL: if:
317if:
318 %val1 = load i32, i32* %gep2, align 4
319 br label %end
320
321; CHECK-LABEL: end:
322; CHECK: %val2 = phi i32 [ %val1, %if ], [ %[[PRE]], %[[CRIT_EDGE]] ]
323; CHECK-NOT: load
324end:
325 %phi1 = phi i32* [ %ptr1, %if ], [ %gep1, %entry ]
326 %phi2 = phi i32 [ %val1, %if ], [ 0, %entry ]
327 store i32 0, i32* %phi1, align 4
328 %val2 = load i32, i32* %gep2, align 4
329 %ret = add i32 %phi2, %val2
330 ret i32 %ret
331}
332
333; CHECK-LABEL: @test14
334define void @test14(i32* %ptr1, i32* noalias %ptr2) {
335entry:
336 %gep1 = getelementptr inbounds i32, i32* %ptr1, i32 1
337 %gep2 = getelementptr inbounds i32, i32* %ptr1, i32 2
338 br label %loop
339
340; CHECK-LABEL: loop:
341loop:
342 %phi1 = phi i32* [ %gep3, %loop.end ], [ %gep1, %entry ]
343 br i1 undef, label %if1, label %then
344
345; CHECK: [[CRIT_EDGE:.*]]:
346; CHECK: %[[PRE:.*]] = load i32, i32* %gep2, align 4
347
348; CHECK-LABEL: if1:
349; CHECK: %val2 = phi i32 [ %[[PRE]], %[[CRIT_EDGE]] ], [ %val3, %loop.end ]
350; CHECK-NOT: load
351if1:
352 %val2 = load i32, i32* %gep2, align 4
353 store i32 %val2, i32* %gep2, align 4
354 store i32 0, i32* %phi1, align 4
355 br label %then
356
357; CHECK-LABEL: then:
358then:
359 %cmp = icmp eq i32* %gep2, %ptr2
360 br i1 %cmp, label %loop.end, label %if2
361
362if2:
363 br label %loop.end
364
365loop.end:
366 %phi3 = phi i32* [ %gep2, %then ], [ %ptr1, %if2 ]
367 %val3 = load i32, i32* %gep2, align 4
368 store i32 %val3, i32* %phi3, align 4
369 %gep3 = getelementptr inbounds i32, i32* %ptr1, i32 1
370 br i1 undef, label %loop, label %if1
371}