blob: e3eaf6ffaf20a002f02d6ba55e37c4d854c00a43 [file] [log] [blame]
Daniel Berlin439042b2017-02-07 21:10:46 +00001; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2; RUN: opt -print-predicateinfo -analyze < %s 2>&1 | FileCheck %s
3
4@a = external global i32 ; <i32*> [#uses=7]
5
6define i32 @test1() nounwind {
7; CHECK-LABEL: @test1(
8; CHECK-NEXT: entry:
9; CHECK-NEXT: [[TMP0:%.*]] = load i32, i32* @a, align 4
10; CHECK-NEXT: [[TMP1:%.*]] = icmp eq i32 [[TMP0]], 4
11; CHECK-NEXT: br i1 [[TMP1]], label [[BB:%.*]], label [[BB1:%.*]]
12; CHECK: bb:
13; CHECK-NEXT: br label [[BB8:%.*]]
14; CHECK: bb1:
15; CHECK-NEXT: [[TMP2:%.*]] = load i32, i32* @a, align 4
16; CHECK-NEXT: [[TMP3:%.*]] = icmp eq i32 [[TMP2]], 5
17; CHECK-NEXT: br i1 [[TMP3]], label [[BB2:%.*]], label [[BB3:%.*]]
18; CHECK: bb2:
19; CHECK-NEXT: br label [[BB8]]
20; CHECK: bb3:
21; CHECK-NEXT: [[TMP4:%.*]] = load i32, i32* @a, align 4
22; CHECK-NEXT: [[TMP5:%.*]] = icmp eq i32 [[TMP4]], 4
23; CHECK-NEXT: br i1 [[TMP5]], label [[BB4:%.*]], label [[BB5:%.*]]
24; CHECK: bb4:
25; CHECK-NEXT: [[TMP6:%.*]] = load i32, i32* @a, align 4
26; CHECK-NEXT: [[TMP7:%.*]] = add i32 [[TMP6]], 5
27; CHECK-NEXT: br label [[BB8]]
28; CHECK: bb5:
29; CHECK-NEXT: [[TMP8:%.*]] = load i32, i32* @a, align 4
30; CHECK-NEXT: [[TMP9:%.*]] = icmp eq i32 [[TMP8]], 5
31; CHECK-NEXT: br i1 [[TMP9]], label [[BB6:%.*]], label [[BB7:%.*]]
32; CHECK: bb6:
33; CHECK-NEXT: [[TMP10:%.*]] = load i32, i32* @a, align 4
34; CHECK-NEXT: [[TMP11:%.*]] = add i32 [[TMP10]], 4
35; CHECK-NEXT: br label [[BB8]]
36; CHECK: bb7:
37; CHECK-NEXT: [[TMP12:%.*]] = load i32, i32* @a, align 4
38; CHECK-NEXT: br label [[BB8]]
39; CHECK: bb8:
40; CHECK-NEXT: [[DOT0:%.*]] = phi i32 [ [[TMP12]], [[BB7]] ], [ [[TMP11]], [[BB6]] ], [ [[TMP7]], [[BB4]] ], [ 4, [[BB2]] ], [ 5, [[BB]] ]
41; CHECK-NEXT: br label [[RETURN:%.*]]
42; CHECK: return:
43; CHECK-NEXT: ret i32 [[DOT0]]
44;
45entry:
46 %0 = load i32, i32* @a, align 4
47 %1 = icmp eq i32 %0, 4
48 br i1 %1, label %bb, label %bb1
49
50bb: ; preds = %entry
51 br label %bb8
52
53bb1: ; preds = %entry
54 %2 = load i32, i32* @a, align 4
55 %3 = icmp eq i32 %2, 5
56 br i1 %3, label %bb2, label %bb3
57
58bb2: ; preds = %bb1
59 br label %bb8
60
61bb3: ; preds = %bb1
62 %4 = load i32, i32* @a, align 4
63 %5 = icmp eq i32 %4, 4
64 br i1 %5, label %bb4, label %bb5
65
66bb4: ; preds = %bb3
67 %6 = load i32, i32* @a, align 4
68 %7 = add i32 %6, 5
69 br label %bb8
70
71bb5: ; preds = %bb3
72 %8 = load i32, i32* @a, align 4
73 %9 = icmp eq i32 %8, 5
74 br i1 %9, label %bb6, label %bb7
75
76bb6: ; preds = %bb5
77 %10 = load i32, i32* @a, align 4
78 %11 = add i32 %10, 4
79 br label %bb8
80
81bb7: ; preds = %bb5
82 %12 = load i32, i32* @a, align 4
83 br label %bb8
84
85bb8: ; preds = %bb7, %bb6, %bb4, %bb2, %bb
86 %.0 = phi i32 [ %12, %bb7 ], [ %11, %bb6 ], [ %7, %bb4 ], [ 4, %bb2 ], [ 5, %bb ]
87 br label %return
88
89return: ; preds = %bb8
90 ret i32 %.0
91}
92
93declare void @foo(i1)
94declare void @bar(i32)
95
96define void @test3(i32 %x, i32 %y) {
97; CHECK-LABEL: @test3(
98; CHECK-NEXT: [[XZ:%.*]] = icmp eq i32 [[X:%.*]], 0
99; CHECK-NEXT: [[YZ:%.*]] = icmp eq i32 [[Y:%.*]], 0
100; CHECK-NEXT: [[Z:%.*]] = and i1 [[XZ]], [[YZ]]
Daniel Berlindbe82642017-02-12 22:12:20 +0000101; CHECK: [[XZ_0:%.*]] = call i1 @llvm.ssa.copy.i1(i1 [[XZ]])
102; CHECK: [[X_0:%.*]] = call i32 @llvm.ssa.copy.i32(i32 [[X]])
103; CHECK: [[YZ_0:%.*]] = call i1 @llvm.ssa.copy.i1(i1 [[YZ]])
104; CHECK: [[Y_0:%.*]] = call i32 @llvm.ssa.copy.i32(i32 [[Y]])
Daniel Berlin588e0be2017-02-18 23:06:38 +0000105; CHECK: [[Z_0:%.*]] = call i1 @llvm.ssa.copy.i1(i1 [[Z]])
Daniel Berlin439042b2017-02-07 21:10:46 +0000106; CHECK-NEXT: br i1 [[Z]], label [[BOTH_ZERO:%.*]], label [[NOPE:%.*]]
107; CHECK: both_zero:
Daniel Berlin439042b2017-02-07 21:10:46 +0000108; CHECK-NEXT: call void @foo(i1 [[XZ_0]])
109; CHECK-NEXT: call void @foo(i1 [[YZ_0]])
110; CHECK-NEXT: call void @bar(i32 [[X_0]])
111; CHECK-NEXT: call void @bar(i32 [[Y_0]])
112; CHECK-NEXT: ret void
113; CHECK: nope:
Daniel Berlin588e0be2017-02-18 23:06:38 +0000114; CHECK-NEXT: call void @foo(i1 [[Z_0]])
Daniel Berlin439042b2017-02-07 21:10:46 +0000115; CHECK-NEXT: ret void
116;
117 %xz = icmp eq i32 %x, 0
118 %yz = icmp eq i32 %y, 0
119 %z = and i1 %xz, %yz
120 br i1 %z, label %both_zero, label %nope
121both_zero:
122 call void @foo(i1 %xz)
123 call void @foo(i1 %yz)
124 call void @bar(i32 %x)
125 call void @bar(i32 %y)
126 ret void
127nope:
128 call void @foo(i1 %z)
129 ret void
130}
131
132define void @test4(i1 %b, i32 %x) {
133; CHECK-LABEL: @test4(
134; CHECK-NEXT: br i1 [[B:%.*]], label [[SW:%.*]], label [[CASE3:%.*]]
135; CHECK: sw:
136; CHECK-NEXT: switch i32 [[X:%.*]], label [[DEFAULT:%.*]] [
137; CHECK-NEXT: i32 0, label [[CASE0:%.*]]
138; CHECK-NEXT: i32 1, label [[CASE1:%.*]]
139; CHECK-NEXT: i32 2, label [[CASE0]]
140; CHECK-NEXT: i32 3, label [[CASE3]]
141; CHECK-NEXT: i32 4, label [[DEFAULT]]
142; CHECK-NEXT: ]
143; CHECK: default:
144; CHECK-NEXT: call void @bar(i32 [[X]])
145; CHECK-NEXT: ret void
146; CHECK: case0:
147; CHECK-NEXT: call void @bar(i32 [[X]])
148; CHECK-NEXT: ret void
149; CHECK: case1:
150; CHECK-NEXT: call void @bar(i32 [[X]])
151; CHECK-NEXT: ret void
152; CHECK: case3:
153; CHECK-NEXT: call void @bar(i32 [[X]])
154; CHECK-NEXT: ret void
155;
156 br i1 %b, label %sw, label %case3
157sw:
158 switch i32 %x, label %default [
159 i32 0, label %case0
160 i32 1, label %case1
161 i32 2, label %case0
162 i32 3, label %case3
163 i32 4, label %default
164 ]
165default:
166 call void @bar(i32 %x)
167 ret void
168case0:
169 call void @bar(i32 %x)
170 ret void
171case1:
172 call void @bar(i32 %x)
173 ret void
174case3:
175 call void @bar(i32 %x)
176 ret void
177}
178
179define i1 @test5(i32 %x, i32 %y) {
180; CHECK-LABEL: @test5(
181; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[X:%.*]], [[Y:%.*]]
Daniel Berlindbe82642017-02-12 22:12:20 +0000182; CHECK: [[X_0:%.*]] = call i32 @llvm.ssa.copy.i32(i32 [[X]])
183; CHECK: [[X_1:%.*]] = call i32 @llvm.ssa.copy.i32(i32 [[X]])
184; CHECK: [[Y_0:%.*]] = call i32 @llvm.ssa.copy.i32(i32 [[Y]])
185; CHECK: [[Y_1:%.*]] = call i32 @llvm.ssa.copy.i32(i32 [[Y]])
Daniel Berlin439042b2017-02-07 21:10:46 +0000186; CHECK-NEXT: br i1 [[CMP]], label [[SAME:%.*]], label [[DIFFERENT:%.*]]
187; CHECK: same:
Daniel Berlin439042b2017-02-07 21:10:46 +0000188; CHECK-NEXT: [[CMP2:%.*]] = icmp ne i32 [[X_0]], [[Y_0]]
189; CHECK-NEXT: ret i1 [[CMP2]]
190; CHECK: different:
Daniel Berlin439042b2017-02-07 21:10:46 +0000191; CHECK-NEXT: [[CMP3:%.*]] = icmp eq i32 [[X_1]], [[Y_1]]
192; CHECK-NEXT: ret i1 [[CMP3]]
193;
194 %cmp = icmp eq i32 %x, %y
195 br i1 %cmp, label %same, label %different
196
197same:
198 %cmp2 = icmp ne i32 %x, %y
199 ret i1 %cmp2
200
201different:
202 %cmp3 = icmp eq i32 %x, %y
203 ret i1 %cmp3
204}
205
206define i1 @test6(i32 %x, i32 %y) {
207; CHECK-LABEL: @test6(
208; CHECK-NEXT: [[CMP2:%.*]] = icmp ne i32 [[X:%.*]], [[Y:%.*]]
209; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[X]], [[Y]]
210; CHECK-NEXT: [[CMP3:%.*]] = icmp eq i32 [[X]], [[Y]]
211; CHECK-NEXT: br i1 [[CMP]], label [[SAME:%.*]], label [[DIFFERENT:%.*]]
212; CHECK: same:
213; CHECK-NEXT: ret i1 [[CMP2]]
214; CHECK: different:
215; CHECK-NEXT: ret i1 [[CMP3]]
216;
217 %cmp2 = icmp ne i32 %x, %y
218 %cmp = icmp eq i32 %x, %y
219 %cmp3 = icmp eq i32 %x, %y
220 br i1 %cmp, label %same, label %different
221
222same:
223 ret i1 %cmp2
224
225different:
226 ret i1 %cmp3
227}
228
229define i1 @test6_fp(float %x, float %y) {
230; CHECK-LABEL: @test6_fp(
231; CHECK-NEXT: [[CMP2:%.*]] = fcmp une float [[X:%.*]], [[Y:%.*]]
232; CHECK-NEXT: [[CMP:%.*]] = fcmp oeq float [[X]], [[Y]]
233; CHECK-NEXT: [[CMP3:%.*]] = fcmp oeq float [[X]], [[Y]]
234; CHECK-NEXT: br i1 [[CMP]], label [[SAME:%.*]], label [[DIFFERENT:%.*]]
235; CHECK: same:
236; CHECK-NEXT: ret i1 [[CMP2]]
237; CHECK: different:
238; CHECK-NEXT: ret i1 [[CMP3]]
239;
240 %cmp2 = fcmp une float %x, %y
241 %cmp = fcmp oeq float %x, %y
242 %cmp3 = fcmp oeq float %x, %y
243 br i1 %cmp, label %same, label %different
244
245same:
246 ret i1 %cmp2
247
248different:
249 ret i1 %cmp3
250}
251
252define i1 @test7(i32 %x, i32 %y) {
253; CHECK-LABEL: @test7(
254; CHECK-NEXT: [[CMP:%.*]] = icmp sgt i32 [[X:%.*]], [[Y:%.*]]
Daniel Berlindbe82642017-02-12 22:12:20 +0000255; CHECK: [[X_0:%.*]] = call i32 @llvm.ssa.copy.i32(i32 [[X]])
256; CHECK: [[X_1:%.*]] = call i32 @llvm.ssa.copy.i32(i32 [[X]])
257; CHECK: [[Y_0:%.*]] = call i32 @llvm.ssa.copy.i32(i32 [[Y]])
258; CHECK: [[Y_1:%.*]] = call i32 @llvm.ssa.copy.i32(i32 [[Y]])
Daniel Berlin439042b2017-02-07 21:10:46 +0000259; CHECK-NEXT: br i1 [[CMP]], label [[SAME:%.*]], label [[DIFFERENT:%.*]]
260; CHECK: same:
Daniel Berlin439042b2017-02-07 21:10:46 +0000261; CHECK-NEXT: [[CMP2:%.*]] = icmp sle i32 [[X_0]], [[Y_0]]
262; CHECK-NEXT: ret i1 [[CMP2]]
263; CHECK: different:
Daniel Berlin439042b2017-02-07 21:10:46 +0000264; CHECK-NEXT: [[CMP3:%.*]] = icmp sgt i32 [[X_1]], [[Y_1]]
265; CHECK-NEXT: ret i1 [[CMP3]]
266;
267 %cmp = icmp sgt i32 %x, %y
268 br i1 %cmp, label %same, label %different
269
270same:
271 %cmp2 = icmp sle i32 %x, %y
272 ret i1 %cmp2
273
274different:
275 %cmp3 = icmp sgt i32 %x, %y
276 ret i1 %cmp3
277}
278
279define i1 @test7_fp(float %x, float %y) {
280; CHECK-LABEL: @test7_fp(
281; CHECK-NEXT: [[CMP:%.*]] = fcmp ogt float [[X:%.*]], [[Y:%.*]]
Daniel Berlindbe82642017-02-12 22:12:20 +0000282; CHECK: [[X_0:%.*]] = call float @llvm.ssa.copy.f32(float [[X]])
283; CHECK: [[X_1:%.*]] = call float @llvm.ssa.copy.f32(float [[X]])
284; CHECK: [[Y_0:%.*]] = call float @llvm.ssa.copy.f32(float [[Y]])
285; CHECK: [[Y_1:%.*]] = call float @llvm.ssa.copy.f32(float [[Y]])
Daniel Berlin439042b2017-02-07 21:10:46 +0000286; CHECK-NEXT: br i1 [[CMP]], label [[SAME:%.*]], label [[DIFFERENT:%.*]]
287; CHECK: same:
Daniel Berlin439042b2017-02-07 21:10:46 +0000288; CHECK-NEXT: [[CMP2:%.*]] = fcmp ule float [[X_0]], [[Y_0]]
289; CHECK-NEXT: ret i1 [[CMP2]]
290; CHECK: different:
Daniel Berlin439042b2017-02-07 21:10:46 +0000291; CHECK-NEXT: [[CMP3:%.*]] = fcmp ogt float [[X_1]], [[Y_1]]
292; CHECK-NEXT: ret i1 [[CMP3]]
293;
294 %cmp = fcmp ogt float %x, %y
295 br i1 %cmp, label %same, label %different
296
297same:
298 %cmp2 = fcmp ule float %x, %y
299 ret i1 %cmp2
300
301different:
302 %cmp3 = fcmp ogt float %x, %y
303 ret i1 %cmp3
304}
305
306define i1 @test8(i32 %x, i32 %y) {
307; CHECK-LABEL: @test8(
308; CHECK-NEXT: [[CMP2:%.*]] = icmp sle i32 [[X:%.*]], [[Y:%.*]]
309; CHECK-NEXT: [[CMP:%.*]] = icmp sgt i32 [[X]], [[Y]]
310; CHECK-NEXT: [[CMP3:%.*]] = icmp sgt i32 [[X]], [[Y]]
311; CHECK-NEXT: br i1 [[CMP]], label [[SAME:%.*]], label [[DIFFERENT:%.*]]
312; CHECK: same:
313; CHECK-NEXT: ret i1 [[CMP2]]
314; CHECK: different:
315; CHECK-NEXT: ret i1 [[CMP3]]
316;
317 %cmp2 = icmp sle i32 %x, %y
318 %cmp = icmp sgt i32 %x, %y
319 %cmp3 = icmp sgt i32 %x, %y
320 br i1 %cmp, label %same, label %different
321
322same:
323 ret i1 %cmp2
324
325different:
326 ret i1 %cmp3
327}
328
329define i1 @test8_fp(float %x, float %y) {
330; CHECK-LABEL: @test8_fp(
331; CHECK-NEXT: [[CMP2:%.*]] = fcmp ule float [[X:%.*]], [[Y:%.*]]
332; CHECK-NEXT: [[CMP:%.*]] = fcmp ogt float [[X]], [[Y]]
333; CHECK-NEXT: [[CMP3:%.*]] = fcmp ogt float [[X]], [[Y]]
334; CHECK-NEXT: br i1 [[CMP]], label [[SAME:%.*]], label [[DIFFERENT:%.*]]
335; CHECK: same:
336; CHECK-NEXT: ret i1 [[CMP2]]
337; CHECK: different:
338; CHECK-NEXT: ret i1 [[CMP3]]
339;
340 %cmp2 = fcmp ule float %x, %y
341 %cmp = fcmp ogt float %x, %y
342 %cmp3 = fcmp ogt float %x, %y
343 br i1 %cmp, label %same, label %different
344
345same:
346 ret i1 %cmp2
347
348different:
349 ret i1 %cmp3
350}
351
352define i32 @test9(i32 %i, i32 %j) {
353; CHECK-LABEL: @test9(
354; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[I:%.*]], [[J:%.*]]
Daniel Berlindbe82642017-02-12 22:12:20 +0000355; CHECK: [[I_0:%.*]] = call i32 @llvm.ssa.copy.i32(i32 [[I]])
356; CHECK: [[J_0:%.*]] = call i32 @llvm.ssa.copy.i32(i32 [[J]])
Daniel Berlin439042b2017-02-07 21:10:46 +0000357; CHECK-NEXT: br i1 [[CMP]], label [[COND_TRUE:%.*]], label [[RET:%.*]]
358; CHECK: cond_true:
Daniel Berlin439042b2017-02-07 21:10:46 +0000359; CHECK-NEXT: [[DIFF:%.*]] = sub i32 [[I_0]], [[J_0]]
360; CHECK-NEXT: ret i32 [[DIFF]]
361; CHECK: ret:
362; CHECK-NEXT: ret i32 5
363;
364 %cmp = icmp eq i32 %i, %j
365 br i1 %cmp, label %cond_true, label %ret
366
367cond_true:
368 %diff = sub i32 %i, %j
369 ret i32 %diff
370
371ret:
372 ret i32 5
373}
374
375define i32 @test10(i32 %j, i32 %i) {
376; CHECK-LABEL: @test10(
377; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[I:%.*]], [[J:%.*]]
Daniel Berlindbe82642017-02-12 22:12:20 +0000378; CHECK: [[I_0:%.*]] = call i32 @llvm.ssa.copy.i32(i32 [[I]])
379; CHECK: [[J_0:%.*]] = call i32 @llvm.ssa.copy.i32(i32 [[J]])
Daniel Berlin439042b2017-02-07 21:10:46 +0000380; CHECK-NEXT: br i1 [[CMP]], label [[COND_TRUE:%.*]], label [[RET:%.*]]
381; CHECK: cond_true:
Daniel Berlin439042b2017-02-07 21:10:46 +0000382; CHECK-NEXT: [[DIFF:%.*]] = sub i32 [[I_0]], [[J_0]]
383; CHECK-NEXT: ret i32 [[DIFF]]
384; CHECK: ret:
385; CHECK-NEXT: ret i32 5
386;
387 %cmp = icmp eq i32 %i, %j
388 br i1 %cmp, label %cond_true, label %ret
389
390cond_true:
391 %diff = sub i32 %i, %j
392 ret i32 %diff
393
394ret:
395 ret i32 5
396}
397
398declare i32 @yogibar()
399
400define i32 @test11(i32 %x) {
401; CHECK-LABEL: @test11(
402; CHECK-NEXT: [[V0:%.*]] = call i32 @yogibar()
403; CHECK-NEXT: [[V1:%.*]] = call i32 @yogibar()
404; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[V0]], [[V1]]
Daniel Berlindbe82642017-02-12 22:12:20 +0000405; CHECK: [[V0_0:%.*]] = call i32 @llvm.ssa.copy.i32(i32 [[V0]])
406; CHECK: [[V1_0:%.*]] = call i32 @llvm.ssa.copy.i32(i32 [[V1]])
Daniel Berlin439042b2017-02-07 21:10:46 +0000407; CHECK-NEXT: br i1 [[CMP]], label [[COND_TRUE:%.*]], label [[NEXT:%.*]]
408; CHECK: cond_true:
Daniel Berlin439042b2017-02-07 21:10:46 +0000409; CHECK-NEXT: ret i32 [[V1_0]]
410; CHECK: next:
Daniel Berlin439042b2017-02-07 21:10:46 +0000411; CHECK-NEXT: [[CMP2:%.*]] = icmp eq i32 [[X:%.*]], [[V0_0]]
Daniel Berlindbe82642017-02-12 22:12:20 +0000412; CHECK: [[V0_0_1:%.*]] = call i32 @llvm.ssa.copy.i32(i32 [[V0_0]])
Daniel Berlin439042b2017-02-07 21:10:46 +0000413; CHECK-NEXT: br i1 [[CMP2]], label [[COND_TRUE2:%.*]], label [[NEXT2:%.*]]
414; CHECK: cond_true2:
Daniel Berlin439042b2017-02-07 21:10:46 +0000415; CHECK-NEXT: ret i32 [[V0_0_1]]
416; CHECK: next2:
417; CHECK-NEXT: ret i32 0
418;
419 %v0 = call i32 @yogibar()
420 %v1 = call i32 @yogibar()
421 %cmp = icmp eq i32 %v0, %v1
422 br i1 %cmp, label %cond_true, label %next
423
424cond_true:
425 ret i32 %v1
426
427next:
428 %cmp2 = icmp eq i32 %x, %v0
429 br i1 %cmp2, label %cond_true2, label %next2
430
431cond_true2:
432 ret i32 %v0
433
434next2:
435 ret i32 0
436}
437
438define i32 @test12(i32 %x) {
439; CHECK-LABEL: @test12(
440; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[X:%.*]], 0
Daniel Berlindbe82642017-02-12 22:12:20 +0000441; CHECK: [[X_0:%.*]] = call i32 @llvm.ssa.copy.i32(i32 [[X]])
442; CHECK: [[X_1:%.*]] = call i32 @llvm.ssa.copy.i32(i32 [[X]])
Daniel Berlin439042b2017-02-07 21:10:46 +0000443; CHECK-NEXT: br i1 [[CMP]], label [[COND_TRUE:%.*]], label [[COND_FALSE:%.*]]
444; CHECK: cond_true:
Daniel Berlin439042b2017-02-07 21:10:46 +0000445; CHECK-NEXT: br label [[RET:%.*]]
446; CHECK: cond_false:
Daniel Berlin439042b2017-02-07 21:10:46 +0000447; CHECK-NEXT: br label [[RET]]
448; CHECK: ret:
449; CHECK-NEXT: [[RES:%.*]] = phi i32 [ [[X_0]], [[COND_TRUE]] ], [ [[X_1]], [[COND_FALSE]] ]
450; CHECK-NEXT: ret i32 [[RES]]
451;
452 %cmp = icmp eq i32 %x, 0
453 br i1 %cmp, label %cond_true, label %cond_false
454
455cond_true:
456 br label %ret
457
458cond_false:
459 br label %ret
460
461ret:
462 %res = phi i32 [ %x, %cond_true ], [ %x, %cond_false ]
463 ret i32 %res
464}