xref: /llvm-project/llvm/test/Transforms/SimpleLoopUnswitch/endless-unswitch.ll (revision 6561fa3d02b746743139212f31f24c4a81e5138c)
1f3a27511SJingu Kang; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
21db2551cSBjorn Pettersson; RUN: opt -passes='loop-mssa(simple-loop-unswitch<nontrivial>),loop-mssa(simple-loop-unswitch<nontrivial>),verify<loops>' -S < %s | FileCheck %s
3f3a27511SJingu Kang
4f3a27511SJingu Kang; Below bugs have caused endless unswitch.
5f3a27511SJingu Kang;
6f3a27511SJingu Kang; https://bugs.llvm.org/show_bug.cgi?id=50279
7f3a27511SJingu Kang; https://bugs.llvm.org/show_bug.cgi?id=50302
8f3a27511SJingu Kang;
9f3a27511SJingu Kang; This test's loop should be unswitched only one time even though we run
10f3a27511SJingu Kang; SimpleLoopUnswitch pass two times.
11f3a27511SJingu Kang
12f3a27511SJingu Kang@a = dso_local local_unnamed_addr global i32 0, align 4
13f3a27511SJingu Kang@c = dso_local local_unnamed_addr global i32 0, align 4
14f3a27511SJingu Kang@b = dso_local local_unnamed_addr global i8 0, align 1
15f3a27511SJingu Kang
16f3a27511SJingu Kang; Function Attrs: nofree norecurse nosync nounwind uwtable
17f3a27511SJingu Kangdefine dso_local void @d() {
18f3a27511SJingu Kang; CHECK-LABEL: @d(
19f3a27511SJingu Kang; CHECK-NEXT:  entry:
20f3a27511SJingu Kang; CHECK-NEXT:    br label [[FOR_COND:%.*]]
21f3a27511SJingu Kang; CHECK:       for.cond:
22f3a27511SJingu Kang; CHECK-NEXT:    br i1 false, label [[FOR_END:%.*]], label [[FOR_COND]]
23f3a27511SJingu Kang; CHECK:       for.end:
242f79f543SNikita Popov; CHECK-NEXT:    [[TMP0:%.*]] = load i16, ptr null, align 2
25f3a27511SJingu Kang; CHECK-NEXT:    [[TMP1:%.*]] = icmp eq i16 [[TMP0]], 0
26f3a27511SJingu Kang; CHECK-NEXT:    br i1 [[TMP1]], label [[FOR_END_SPLIT:%.*]], label [[FOR_END_SPLIT_US:%.*]]
27f3a27511SJingu Kang; CHECK:       for.end.split.us:
28f3a27511SJingu Kang; CHECK-NEXT:    br label [[G_US:%.*]]
29f3a27511SJingu Kang; CHECK:       g.us:
30f3a27511SJingu Kang; CHECK-NEXT:    br label [[G_SPLIT_US6:%.*]]
31f3a27511SJingu Kang; CHECK:       for.cond1.us1:
322f79f543SNikita Popov; CHECK-NEXT:    [[TMP2:%.*]] = load i16, ptr null, align 2
33f3a27511SJingu Kang; CHECK-NEXT:    [[TOBOOL4_NOT_US:%.*]] = icmp eq i16 [[TMP2]], 0
34f3a27511SJingu Kang; CHECK-NEXT:    br i1 [[TOBOOL4_NOT_US]], label [[FOR_COND5_PREHEADER_US4:%.*]], label [[G_LOOPEXIT_US:%.*]]
35f3a27511SJingu Kang; CHECK:       for.cond5.us2:
36f3a27511SJingu Kang; CHECK-NEXT:    br i1 false, label [[FOR_COND1_LOOPEXIT_US5:%.*]], label [[FOR_INC_US3:%.*]]
37f3a27511SJingu Kang; CHECK:       for.inc.us3:
382f79f543SNikita Popov; CHECK-NEXT:    store i8 0, ptr @b, align 1
39f3a27511SJingu Kang; CHECK-NEXT:    br label [[FOR_COND5_US2:%.*]]
40f3a27511SJingu Kang; CHECK:       for.cond5.preheader.us4:
41f3a27511SJingu Kang; CHECK-NEXT:    br label [[FOR_COND5_US2]]
42f3a27511SJingu Kang; CHECK:       for.cond1.loopexit.us5:
43f3a27511SJingu Kang; CHECK-NEXT:    br label [[FOR_COND1_US1:%.*]], !llvm.loop [[LOOP0:![0-9]+]]
44f3a27511SJingu Kang; CHECK:       g.loopexit.us:
45f3a27511SJingu Kang; CHECK-NEXT:    br label [[G_US]]
46f3a27511SJingu Kang; CHECK:       g.split.us6:
47f3a27511SJingu Kang; CHECK-NEXT:    br label [[FOR_COND1_US1]]
48f3a27511SJingu Kang; CHECK:       for.end.split:
49f3a27511SJingu Kang; CHECK-NEXT:    br label [[G:%.*]]
50f3a27511SJingu Kang; CHECK:       g.loopexit:
51f3a27511SJingu Kang; CHECK-NEXT:    br label [[G]], !llvm.loop [[LOOP2:![0-9]+]]
52f3a27511SJingu Kang; CHECK:       g:
532f79f543SNikita Popov; CHECK-NEXT:    [[TMP3:%.*]] = load i16, ptr null, align 2
54f3a27511SJingu Kang; CHECK-NEXT:    [[TMP4:%.*]] = icmp eq i16 [[TMP3]], 0
55f3a27511SJingu Kang; CHECK-NEXT:    br i1 [[TMP4]], label [[G_SPLIT_US:%.*]], label [[G_SPLIT:%.*]]
56f3a27511SJingu Kang; CHECK:       g.split.us:
57f3a27511SJingu Kang; CHECK-NEXT:    br label [[FOR_COND1_US:%.*]]
58f3a27511SJingu Kang; CHECK:       for.cond1.us:
59f3a27511SJingu Kang; CHECK-NEXT:    br label [[FOR_COND5_PREHEADER_US:%.*]]
60f3a27511SJingu Kang; CHECK:       for.cond5.us:
61f3a27511SJingu Kang; CHECK-NEXT:    br i1 false, label [[FOR_COND1_LOOPEXIT_US:%.*]], label [[FOR_INC_US:%.*]]
62f3a27511SJingu Kang; CHECK:       for.inc.us:
632f79f543SNikita Popov; CHECK-NEXT:    store i8 0, ptr @b, align 1
64f3a27511SJingu Kang; CHECK-NEXT:    br label [[FOR_COND5_US:%.*]]
65f3a27511SJingu Kang; CHECK:       for.cond5.preheader.us:
66f3a27511SJingu Kang; CHECK-NEXT:    br label [[FOR_COND5_US]]
67f3a27511SJingu Kang; CHECK:       for.cond1.loopexit.us:
68f3a27511SJingu Kang; CHECK-NEXT:    br label [[FOR_COND1_US]]
69f3a27511SJingu Kang; CHECK:       g.split:
70f3a27511SJingu Kang; CHECK-NEXT:    br label [[FOR_COND1:%.*]]
71f3a27511SJingu Kang; CHECK:       for.cond1.loopexit:
72f3a27511SJingu Kang; CHECK-NEXT:    br label [[FOR_COND1]], !llvm.loop [[LOOP0]]
73f3a27511SJingu Kang; CHECK:       for.cond1:
742f79f543SNikita Popov; CHECK-NEXT:    [[TMP5:%.*]] = load i16, ptr null, align 2
75f3a27511SJingu Kang; CHECK-NEXT:    [[TOBOOL4_NOT:%.*]] = icmp eq i16 [[TMP5]], 0
76f3a27511SJingu Kang; CHECK-NEXT:    br i1 [[TOBOOL4_NOT]], label [[FOR_COND5_PREHEADER:%.*]], label [[G_LOOPEXIT:%.*]]
77f3a27511SJingu Kang; CHECK:       for.cond5.preheader:
78f3a27511SJingu Kang; CHECK-NEXT:    br label [[FOR_COND5:%.*]]
79f3a27511SJingu Kang; CHECK:       for.cond5:
80f3a27511SJingu Kang; CHECK-NEXT:    br i1 false, label [[FOR_COND1_LOOPEXIT:%.*]], label [[FOR_INC:%.*]]
81f3a27511SJingu Kang; CHECK:       for.inc:
822f79f543SNikita Popov; CHECK-NEXT:    store i8 0, ptr @b, align 1
83f3a27511SJingu Kang; CHECK-NEXT:    br label [[FOR_COND5]]
84f3a27511SJingu Kang;
85f3a27511SJingu Kangentry:
86f3a27511SJingu Kang  br label %for.cond
87f3a27511SJingu Kang
88f3a27511SJingu Kangfor.cond:                                         ; preds = %for.cond, %entry
89f3a27511SJingu Kang  br i1 false, label %for.end, label %for.cond
90f3a27511SJingu Kang
91f3a27511SJingu Kangfor.end:                                          ; preds = %for.cond
92f3a27511SJingu Kang  br label %g
93f3a27511SJingu Kang
94f3a27511SJingu Kangg:                                                ; preds = %for.cond1, %for.end
95f3a27511SJingu Kang  br label %for.cond1
96f3a27511SJingu Kang
97f3a27511SJingu Kangfor.cond1:                                        ; preds = %for.cond5, %g
982f79f543SNikita Popov  %0 = load i16, ptr null, align 2
99f3a27511SJingu Kang  %tobool4.not = icmp eq i16 %0, 0
100f3a27511SJingu Kang  br i1 %tobool4.not, label %for.cond5, label %g
101f3a27511SJingu Kang
102f3a27511SJingu Kangfor.cond5:                                        ; preds = %for.inc, %for.cond1
103f3a27511SJingu Kang  br i1 false, label %for.cond1, label %for.inc
104f3a27511SJingu Kang
105f3a27511SJingu Kangfor.inc:                                          ; preds = %for.cond5
1062f79f543SNikita Popov  store i8 0, ptr @b, align 1
107f3a27511SJingu Kang  br label %for.cond5
108f3a27511SJingu Kang}
109*6561fa3dSMatthew Devereau
110*6561fa3dSMatthew Devereaudefine void @e(ptr %p) {
111*6561fa3dSMatthew Devereau; CHECK-LABEL: @e(
112*6561fa3dSMatthew Devereau; CHECK-NEXT:  entry:
113*6561fa3dSMatthew Devereau; CHECK-NEXT:    br label [[FOR_COND:%.*]]
114*6561fa3dSMatthew Devereau; CHECK:       for.cond:
115*6561fa3dSMatthew Devereau; CHECK-NEXT:    br i1 false, label [[FOR_END:%.*]], label [[FOR_COND]]
116*6561fa3dSMatthew Devereau; CHECK:       for.end:
117*6561fa3dSMatthew Devereau; CHECK-NEXT:    [[TMP0:%.*]] = load i16, ptr [[P:%.*]], align 2
118*6561fa3dSMatthew Devereau; CHECK-NEXT:    [[TMP1:%.*]] = trunc i16 [[TMP0]] to i1
119*6561fa3dSMatthew Devereau; CHECK-NEXT:    br i1 [[TMP1]], label [[FOR_END_SPLIT:%.*]], label [[FOR_END_SPLIT_US:%.*]]
120*6561fa3dSMatthew Devereau; CHECK:       for.end.split.us:
121*6561fa3dSMatthew Devereau; CHECK-NEXT:    br label [[G_US:%.*]]
122*6561fa3dSMatthew Devereau; CHECK:       g.us:
123*6561fa3dSMatthew Devereau; CHECK-NEXT:    br label [[G_SPLIT_US6:%.*]]
124*6561fa3dSMatthew Devereau; CHECK:       for.cond1.us1:
125*6561fa3dSMatthew Devereau; CHECK-NEXT:    [[TMP2:%.*]] = load i16, ptr [[P]], align 2
126*6561fa3dSMatthew Devereau; CHECK-NEXT:    [[TOBOOL4_NOT_US:%.*]] = trunc i16 [[TMP2]] to i1
127*6561fa3dSMatthew Devereau; CHECK-NEXT:    br i1 [[TOBOOL4_NOT_US]], label [[FOR_COND5_PREHEADER_US4:%.*]], label [[G_LOOPEXIT_US:%.*]]
128*6561fa3dSMatthew Devereau; CHECK:       for.cond5.us2:
129*6561fa3dSMatthew Devereau; CHECK-NEXT:    br i1 false, label [[FOR_COND1_LOOPEXIT_US5:%.*]], label [[FOR_INC_US3:%.*]]
130*6561fa3dSMatthew Devereau; CHECK:       for.inc.us3:
131*6561fa3dSMatthew Devereau; CHECK-NEXT:    store i8 0, ptr @b, align 1
132*6561fa3dSMatthew Devereau; CHECK-NEXT:    br label [[FOR_COND5_US2:%.*]]
133*6561fa3dSMatthew Devereau; CHECK:       for.cond5.preheader.us4:
134*6561fa3dSMatthew Devereau; CHECK-NEXT:    br label [[FOR_COND5_US2]]
135*6561fa3dSMatthew Devereau; CHECK:       for.cond1.loopexit.us5:
136*6561fa3dSMatthew Devereau; CHECK-NEXT:    br label [[FOR_COND1_US1:%.*]], !llvm.loop [[LOOP3:![0-9]+]]
137*6561fa3dSMatthew Devereau; CHECK:       g.loopexit.us:
138*6561fa3dSMatthew Devereau; CHECK-NEXT:    br label [[G_US]]
139*6561fa3dSMatthew Devereau; CHECK:       g.split.us6:
140*6561fa3dSMatthew Devereau; CHECK-NEXT:    br label [[FOR_COND1_US1]]
141*6561fa3dSMatthew Devereau; CHECK:       for.end.split:
142*6561fa3dSMatthew Devereau; CHECK-NEXT:    br label [[G:%.*]]
143*6561fa3dSMatthew Devereau; CHECK:       g.loopexit:
144*6561fa3dSMatthew Devereau; CHECK-NEXT:    br label [[G]], !llvm.loop [[LOOP4:![0-9]+]]
145*6561fa3dSMatthew Devereau; CHECK:       g:
146*6561fa3dSMatthew Devereau; CHECK-NEXT:    [[TMP3:%.*]] = load i16, ptr [[P]], align 2
147*6561fa3dSMatthew Devereau; CHECK-NEXT:    [[TMP4:%.*]] = trunc i16 [[TMP3]] to i1
148*6561fa3dSMatthew Devereau; CHECK-NEXT:    br i1 [[TMP4]], label [[G_SPLIT_US:%.*]], label [[G_SPLIT:%.*]]
149*6561fa3dSMatthew Devereau; CHECK:       g.split.us:
150*6561fa3dSMatthew Devereau; CHECK-NEXT:    br label [[FOR_COND1_US:%.*]]
151*6561fa3dSMatthew Devereau; CHECK:       for.cond1.us:
152*6561fa3dSMatthew Devereau; CHECK-NEXT:    br label [[FOR_COND5_PREHEADER_US:%.*]]
153*6561fa3dSMatthew Devereau; CHECK:       for.cond5.us:
154*6561fa3dSMatthew Devereau; CHECK-NEXT:    br i1 false, label [[FOR_COND1_LOOPEXIT_US:%.*]], label [[FOR_INC_US:%.*]]
155*6561fa3dSMatthew Devereau; CHECK:       for.inc.us:
156*6561fa3dSMatthew Devereau; CHECK-NEXT:    store i8 0, ptr @b, align 1
157*6561fa3dSMatthew Devereau; CHECK-NEXT:    br label [[FOR_COND5_US:%.*]]
158*6561fa3dSMatthew Devereau; CHECK:       for.cond5.preheader.us:
159*6561fa3dSMatthew Devereau; CHECK-NEXT:    br label [[FOR_COND5_US]]
160*6561fa3dSMatthew Devereau; CHECK:       for.cond1.loopexit.us:
161*6561fa3dSMatthew Devereau; CHECK-NEXT:    br label [[FOR_COND1_US]]
162*6561fa3dSMatthew Devereau; CHECK:       g.split:
163*6561fa3dSMatthew Devereau; CHECK-NEXT:    br label [[FOR_COND1:%.*]]
164*6561fa3dSMatthew Devereau; CHECK:       for.cond1.loopexit:
165*6561fa3dSMatthew Devereau; CHECK-NEXT:    br label [[FOR_COND1]], !llvm.loop [[LOOP3]]
166*6561fa3dSMatthew Devereau; CHECK:       for.cond1:
167*6561fa3dSMatthew Devereau; CHECK-NEXT:    [[TMP5:%.*]] = load i16, ptr [[P]], align 2
168*6561fa3dSMatthew Devereau; CHECK-NEXT:    [[TOBOOL4_NOT:%.*]] = trunc i16 [[TMP5]] to i1
169*6561fa3dSMatthew Devereau; CHECK-NEXT:    br i1 [[TOBOOL4_NOT]], label [[FOR_COND5_PREHEADER:%.*]], label [[G_LOOPEXIT:%.*]]
170*6561fa3dSMatthew Devereau; CHECK:       for.cond5.preheader:
171*6561fa3dSMatthew Devereau; CHECK-NEXT:    br label [[FOR_COND5:%.*]]
172*6561fa3dSMatthew Devereau; CHECK:       for.cond5:
173*6561fa3dSMatthew Devereau; CHECK-NEXT:    br i1 false, label [[FOR_COND1_LOOPEXIT:%.*]], label [[FOR_INC:%.*]]
174*6561fa3dSMatthew Devereau; CHECK:       for.inc:
175*6561fa3dSMatthew Devereau; CHECK-NEXT:    store i8 0, ptr @b, align 1
176*6561fa3dSMatthew Devereau; CHECK-NEXT:    br label [[FOR_COND5]]
177*6561fa3dSMatthew Devereau;
178*6561fa3dSMatthew Devereauentry:
179*6561fa3dSMatthew Devereau  br label %for.cond
180*6561fa3dSMatthew Devereau
181*6561fa3dSMatthew Devereaufor.cond:                                         ; preds = %for.cond, %entry
182*6561fa3dSMatthew Devereau  br i1 false, label %for.end, label %for.cond
183*6561fa3dSMatthew Devereau
184*6561fa3dSMatthew Devereaufor.end:                                          ; preds = %for.cond
185*6561fa3dSMatthew Devereau  br label %g
186*6561fa3dSMatthew Devereau
187*6561fa3dSMatthew Devereaug:                                                ; preds = %for.cond1, %for.end
188*6561fa3dSMatthew Devereau  br label %for.cond1
189*6561fa3dSMatthew Devereau
190*6561fa3dSMatthew Devereaufor.cond1:                                        ; preds = %for.cond5, %g
191*6561fa3dSMatthew Devereau  %0 = load i16, ptr %p, align 2
192*6561fa3dSMatthew Devereau  %tobool4.not = trunc i16 %0 to i1
193*6561fa3dSMatthew Devereau  br i1 %tobool4.not, label %for.cond5, label %g
194*6561fa3dSMatthew Devereau
195*6561fa3dSMatthew Devereaufor.cond5:                                        ; preds = %for.inc, %for.cond1
196*6561fa3dSMatthew Devereau  br i1 false, label %for.cond1, label %for.inc
197*6561fa3dSMatthew Devereau
198*6561fa3dSMatthew Devereaufor.inc:                                          ; preds = %for.cond5
199*6561fa3dSMatthew Devereau  store i8 0, ptr @b, align 1
200*6561fa3dSMatthew Devereau  br label %for.cond5
201*6561fa3dSMatthew Devereau}
202