1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt -S -indvars < %s | FileCheck %s
4 ; Check that we don't reuse %zext instead of %inc11 for LCSSA Phi node. Case
7 define i32 @test_01() {
8 ; CHECK-LABEL: @test_01(
10 ; CHECK-NEXT: br label [[FOR_COND1_PREHEADER:%.*]]
11 ; CHECK: for.cond1.preheader:
12 ; CHECK-NEXT: br label [[FOR_COND4_PREHEADER:%.*]]
13 ; CHECK: for.cond4.preheader:
14 ; CHECK-NEXT: [[ZEXT:%.*]] = zext i16 1 to i32
15 ; CHECK-NEXT: br label [[FOR_BODY6:%.*]]
17 ; CHECK-NEXT: [[CMP5:%.*]] = icmp ult i32 [[INC:%.*]], 2
18 ; CHECK-NEXT: br i1 [[CMP5]], label [[FOR_BODY6]], label [[FOR_END:%.*]]
20 ; CHECK-NEXT: [[IV:%.*]] = phi i32 [ 0, [[FOR_COND4_PREHEADER]] ], [ [[INC]], [[FOR_COND4:%.*]] ]
21 ; CHECK-NEXT: [[TMP0:%.*]] = icmp eq i32 [[IV]], [[ZEXT]]
22 ; CHECK-NEXT: [[INC]] = add nuw nsw i32 [[IV]], 1
23 ; CHECK-NEXT: br i1 [[TMP0]], label [[RETURN_LOOPEXIT:%.*]], label [[FOR_COND4]]
25 ; CHECK-NEXT: br i1 false, label [[FOR_COND4_PREHEADER]], label [[FOR_END9:%.*]]
27 ; CHECK-NEXT: br i1 false, label [[FOR_COND1_PREHEADER]], label [[RETURN_LOOPEXIT3:%.*]]
28 ; CHECK: return.loopexit:
29 ; CHECK-NEXT: unreachable
30 ; CHECK: return.loopexit3:
31 ; CHECK-NEXT: br label [[RETURN:%.*]]
33 ; CHECK-NEXT: ret i32 1
36 br label %for.cond1.preheader
38 for.cond1.preheader: ; preds = %for.end9, %entry
39 br label %for.cond4.preheader
41 for.cond4.preheader: ; preds = %for.end, %for.cond1.preheader
42 %zext = zext i16 1 to i32
45 for.cond4: ; preds = %for.body6
46 %cmp5 = icmp ult i32 %inc, 2
47 br i1 %cmp5, label %for.body6, label %for.end
49 for.body6: ; preds = %for.cond4, %for.cond4.preheader
50 %iv = phi i32 [ 0, %for.cond4.preheader ], [ %inc, %for.cond4 ]
51 %0 = icmp eq i32 %iv, %zext
52 %inc = add nuw nsw i32 %iv, 1
53 br i1 %0, label %return.loopexit, label %for.cond4
55 for.end: ; preds = %for.cond4
56 br i1 false, label %for.cond4.preheader, label %for.end9
58 for.end9: ; preds = %for.end
59 %inc11 = add nuw nsw i32 0, 1
60 br i1 false, label %for.cond1.preheader, label %return.loopexit3
62 return.loopexit: ; preds = %for.body6
65 return.loopexit3: ; preds = %for.end9
66 %inc11.lcssa = phi i32 [ %inc11, %for.end9 ]
69 return: ; preds = %return.loopexit3
73 ; Same as test_01, but the instructions with the same SCEV have a non-constant
75 define i32 @test_02(i32 %x) {
76 ; CHECK-LABEL: @test_02(
78 ; CHECK-NEXT: br label [[FOR_COND1_PREHEADER:%.*]]
79 ; CHECK: for.cond1.preheader:
80 ; CHECK-NEXT: br label [[FOR_COND4_PREHEADER:%.*]]
81 ; CHECK: for.cond4.preheader:
82 ; CHECK-NEXT: [[ZEXT:%.*]] = mul i32 [[X:%.*]], 1
83 ; CHECK-NEXT: br label [[FOR_BODY6:%.*]]
85 ; CHECK-NEXT: [[CMP5:%.*]] = icmp ult i32 [[INC:%.*]], 2
86 ; CHECK-NEXT: br i1 [[CMP5]], label [[FOR_BODY6]], label [[FOR_END:%.*]]
88 ; CHECK-NEXT: [[IV:%.*]] = phi i32 [ 0, [[FOR_COND4_PREHEADER]] ], [ [[INC]], [[FOR_COND4:%.*]] ]
89 ; CHECK-NEXT: [[TMP0:%.*]] = icmp eq i32 [[IV]], [[ZEXT]]
90 ; CHECK-NEXT: [[INC]] = add nuw nsw i32 [[IV]], 1
91 ; CHECK-NEXT: br i1 [[TMP0]], label [[RETURN_LOOPEXIT:%.*]], label [[FOR_COND4]]
93 ; CHECK-NEXT: br i1 false, label [[FOR_COND4_PREHEADER]], label [[FOR_END9:%.*]]
95 ; CHECK-NEXT: br i1 false, label [[FOR_COND1_PREHEADER]], label [[RETURN_LOOPEXIT3:%.*]]
96 ; CHECK: return.loopexit:
97 ; CHECK-NEXT: unreachable
98 ; CHECK: return.loopexit3:
99 ; CHECK-NEXT: br label [[RETURN:%.*]]
101 ; CHECK-NEXT: ret i32 [[X]]
104 br label %for.cond1.preheader
106 for.cond1.preheader: ; preds = %for.end9, %entry
107 br label %for.cond4.preheader
109 for.cond4.preheader: ; preds = %for.end, %for.cond1.preheader
110 %zext = mul i32 %x, 1
113 for.cond4: ; preds = %for.body6
114 %cmp5 = icmp ult i32 %inc, 2
115 br i1 %cmp5, label %for.body6, label %for.end
117 for.body6: ; preds = %for.cond4, %for.cond4.preheader
118 %iv = phi i32 [ 0, %for.cond4.preheader ], [ %inc, %for.cond4 ]
119 %0 = icmp eq i32 %iv, %zext
120 %inc = add nuw nsw i32 %iv, 1
121 br i1 %0, label %return.loopexit, label %for.cond4
123 for.end: ; preds = %for.cond4
124 br i1 false, label %for.cond4.preheader, label %for.end9
126 for.end9: ; preds = %for.end
127 %inc11 = add nuw nsw i32 0, %x
128 br i1 false, label %for.cond1.preheader, label %return.loopexit3
130 return.loopexit: ; preds = %for.body6
133 return.loopexit3: ; preds = %for.end9
134 %inc11.lcssa = phi i32 [ %inc11, %for.end9 ]
137 return: ; preds = %return.loopexit3