Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / Analysis / ScalarEvolution / trip-count14.ll
blob1e835303146687acde51746c769dedfc72fe3950
1 ; NOTE: Assertions have been autogenerated by utils/update_analyze_test_checks.py
2 ; RUN: opt -S -disable-output "-passes=print<scalar-evolution>" -scalar-evolution-classify-expressions=0 < %s 2>&1 | FileCheck %s
4 define void @s32_max1(i32 %n, ptr %p) {
5 ; CHECK-LABEL: 's32_max1'
6 ; CHECK-NEXT:  Determining loop execution counts for: @s32_max1
7 ; CHECK-NEXT:  Loop %do.body: backedge-taken count is ((-1 * %n) + ((1 + %n) smax %n))
8 ; CHECK-NEXT:  Loop %do.body: constant max backedge-taken count is 1, actual taken count either this or zero.
9 ; CHECK-NEXT:  Loop %do.body: symbolic max backedge-taken count is ((-1 * %n) + ((1 + %n) smax %n)), actual taken count either this or zero.
10 ; CHECK-NEXT:  Loop %do.body: Predicated backedge-taken count is ((-1 * %n) + ((1 + %n) smax %n))
11 ; CHECK-NEXT:   Predicates:
12 ; CHECK:       Loop %do.body: Trip multiple is 1
14 entry:
15   %add = add i32 %n, 1
16   br label %do.body
18 do.body:
19   %i.0 = phi i32 [ %n, %entry ], [ %inc, %do.body ]
20   %arrayidx = getelementptr i32, ptr %p, i32 %i.0
21   store i32 %i.0, ptr %arrayidx, align 4
22   %inc = add i32 %i.0, 1
23   %cmp = icmp slt i32 %i.0, %add
24   br i1 %cmp, label %do.body, label %do.end ; taken either 0 or 1 times
26 do.end:
27   ret void
30 define void @s32_max2(i32 %n, ptr %p) {
31 ; CHECK-LABEL: 's32_max2'
32 ; CHECK-NEXT:  Determining loop execution counts for: @s32_max2
33 ; CHECK-NEXT:  Loop %do.body: backedge-taken count is ((-1 * %n) + ((2 + %n) smax %n))
34 ; CHECK-NEXT:  Loop %do.body: constant max backedge-taken count is 2, actual taken count either this or zero.
35 ; CHECK-NEXT:  Loop %do.body: symbolic max backedge-taken count is ((-1 * %n) + ((2 + %n) smax %n)), actual taken count either this or zero.
36 ; CHECK-NEXT:  Loop %do.body: Predicated backedge-taken count is ((-1 * %n) + ((2 + %n) smax %n))
37 ; CHECK-NEXT:   Predicates:
38 ; CHECK:       Loop %do.body: Trip multiple is 1
40 entry:
41   %add = add i32 %n, 2
42   br label %do.body
44 do.body:
45   %i.0 = phi i32 [ %n, %entry ], [ %inc, %do.body ]
46   %arrayidx = getelementptr i32, ptr %p, i32 %i.0
47   store i32 %i.0, ptr %arrayidx, align 4
48   %inc = add i32 %i.0, 1
49   %cmp = icmp slt i32 %i.0, %add
50   br i1 %cmp, label %do.body, label %do.end ; taken either 0 or 2 times
52 do.end:
53   ret void
56 define void @s32_maxx(i32 %n, i32 %x, ptr %p) {
57 ; CHECK-LABEL: 's32_maxx'
58 ; CHECK-NEXT:  Determining loop execution counts for: @s32_maxx
59 ; CHECK-NEXT:  Loop %do.body: backedge-taken count is ((-1 * %n) + ((%n + %x) smax %n))
60 ; CHECK-NEXT:  Loop %do.body: constant max backedge-taken count is -1
61 ; CHECK-NEXT:  Loop %do.body: symbolic max backedge-taken count is ((-1 * %n) + ((%n + %x) smax %n))
62 ; CHECK-NEXT:  Loop %do.body: Predicated backedge-taken count is ((-1 * %n) + ((%n + %x) smax %n))
63 ; CHECK-NEXT:   Predicates:
64 ; CHECK:       Loop %do.body: Trip multiple is 1
66 entry:
67   %add = add i32 %x, %n
68   br label %do.body
70 do.body:
71   %i.0 = phi i32 [ %n, %entry ], [ %inc, %do.body ]
72   %arrayidx = getelementptr i32, ptr %p, i32 %i.0
73   store i32 %i.0, ptr %arrayidx, align 4
74   %inc = add i32 %i.0, 1
75   %cmp = icmp slt i32 %i.0, %add
76   br i1 %cmp, label %do.body, label %do.end ; taken either 0 or x times
78 do.end:
79   ret void
82 define void @s32_max2_unpredictable_exit(i32 %n, i32 %x, ptr %p) {
83 ; CHECK-LABEL: 's32_max2_unpredictable_exit'
84 ; CHECK-NEXT:  Determining loop execution counts for: @s32_max2_unpredictable_exit
85 ; CHECK-NEXT:  Loop %do.body: <multiple exits> backedge-taken count is (((-1 * %n) + ((2 + %n) smax %n)) umin ((-1 * %n) + %x))
86 ; CHECK-NEXT:    exit count for do.body: ((-1 * %n) + %x)
87 ; CHECK-NEXT:    exit count for if.end: ((-1 * %n) + ((2 + %n) smax %n))
88 ; CHECK-NEXT:  Loop %do.body: constant max backedge-taken count is 2
89 ; CHECK-NEXT:  Loop %do.body: symbolic max backedge-taken count is (((-1 * %n) + ((2 + %n) smax %n)) umin ((-1 * %n) + %x))
90 ; CHECK-NEXT:    symbolic max exit count for do.body: ((-1 * %n) + %x)
91 ; CHECK-NEXT:    symbolic max exit count for if.end: ((-1 * %n) + ((2 + %n) smax %n))
92 ; CHECK-NEXT:  Loop %do.body: Predicated backedge-taken count is (((-1 * %n) + ((2 + %n) smax %n)) umin ((-1 * %n) + %x))
93 ; CHECK-NEXT:   Predicates:
94 ; CHECK:       Loop %do.body: Trip multiple is 1
96 entry:
97   %add = add i32 %n, 2
98   br label %do.body
100 do.body:
101   %i.0 = phi i32 [ %n, %entry ], [ %inc, %if.end ]
102   %cmp = icmp eq i32 %i.0, %x
103   br i1 %cmp, label %do.end, label %if.end ; unpredictable
105 if.end:
106   %arrayidx = getelementptr i32, ptr %p, i32 %i.0
107   store i32 %i.0, ptr %arrayidx, align 4
108   %inc = add i32 %i.0, 1
109   %cmp1 = icmp slt i32 %i.0, %add
110   br i1 %cmp1, label %do.body, label %do.end ; taken either 0 or 2 times
112 do.end:
113   ret void
116 define void @u32_max1(i32 %n, ptr %p) {
117 ; CHECK-LABEL: 'u32_max1'
118 ; CHECK-NEXT:  Determining loop execution counts for: @u32_max1
119 ; CHECK-NEXT:  Loop %do.body: backedge-taken count is ((-1 * %n) + ((1 + %n) umax %n))
120 ; CHECK-NEXT:  Loop %do.body: constant max backedge-taken count is 1, actual taken count either this or zero.
121 ; CHECK-NEXT:  Loop %do.body: symbolic max backedge-taken count is ((-1 * %n) + ((1 + %n) umax %n)), actual taken count either this or zero.
122 ; CHECK-NEXT:  Loop %do.body: Predicated backedge-taken count is ((-1 * %n) + ((1 + %n) umax %n))
123 ; CHECK-NEXT:   Predicates:
124 ; CHECK:       Loop %do.body: Trip multiple is 1
126 entry:
127   %add = add i32 %n, 1
128   br label %do.body
130 do.body:
131   %i.0 = phi i32 [ %n, %entry ], [ %inc, %do.body ]
132   %arrayidx = getelementptr i32, ptr %p, i32 %i.0
133   store i32 %i.0, ptr %arrayidx, align 4
134   %inc = add i32 %i.0, 1
135   %cmp = icmp ult i32 %i.0, %add
136   br i1 %cmp, label %do.body, label %do.end ; taken either 0 or 1 times
138 do.end:
139   ret void
142 define void @u32_max2(i32 %n, ptr %p) {
143 ; CHECK-LABEL: 'u32_max2'
144 ; CHECK-NEXT:  Determining loop execution counts for: @u32_max2
145 ; CHECK-NEXT:  Loop %do.body: backedge-taken count is ((-1 * %n) + ((2 + %n) umax %n))
146 ; CHECK-NEXT:  Loop %do.body: constant max backedge-taken count is 2, actual taken count either this or zero.
147 ; CHECK-NEXT:  Loop %do.body: symbolic max backedge-taken count is ((-1 * %n) + ((2 + %n) umax %n)), actual taken count either this or zero.
148 ; CHECK-NEXT:  Loop %do.body: Predicated backedge-taken count is ((-1 * %n) + ((2 + %n) umax %n))
149 ; CHECK-NEXT:   Predicates:
150 ; CHECK:       Loop %do.body: Trip multiple is 1
152 entry:
153   %add = add i32 %n, 2
154   br label %do.body
156 do.body:
157   %i.0 = phi i32 [ %n, %entry ], [ %inc, %do.body ]
158   %arrayidx = getelementptr i32, ptr %p, i32 %i.0
159   store i32 %i.0, ptr %arrayidx, align 4
160   %inc = add i32 %i.0, 1
161   %cmp = icmp ult i32 %i.0, %add
162   br i1 %cmp, label %do.body, label %do.end ; taken either 0 or 2 times
164 do.end:
165   ret void
168 define void @u32_maxx(i32 %n, i32 %x, ptr %p) {
169 ; CHECK-LABEL: 'u32_maxx'
170 ; CHECK-NEXT:  Determining loop execution counts for: @u32_maxx
171 ; CHECK-NEXT:  Loop %do.body: backedge-taken count is ((-1 * %n) + ((%n + %x) umax %n))
172 ; CHECK-NEXT:  Loop %do.body: constant max backedge-taken count is -1
173 ; CHECK-NEXT:  Loop %do.body: symbolic max backedge-taken count is ((-1 * %n) + ((%n + %x) umax %n))
174 ; CHECK-NEXT:  Loop %do.body: Predicated backedge-taken count is ((-1 * %n) + ((%n + %x) umax %n))
175 ; CHECK-NEXT:   Predicates:
176 ; CHECK:       Loop %do.body: Trip multiple is 1
178 entry:
179   %add = add i32 %x, %n
180   br label %do.body
182 do.body:
183   %i.0 = phi i32 [ %n, %entry ], [ %inc, %do.body ]
184   %arrayidx = getelementptr i32, ptr %p, i32 %i.0
185   store i32 %i.0, ptr %arrayidx, align 4
186   %inc = add i32 %i.0, 1
187   %cmp = icmp ult i32 %i.0, %add
188   br i1 %cmp, label %do.body, label %do.end ; taken either 0 or x times
190 do.end:
191   ret void
194 define void @u32_max2_unpredictable_exit(i32 %n, i32 %x, ptr %p) {
195 ; CHECK-LABEL: 'u32_max2_unpredictable_exit'
196 ; CHECK-NEXT:  Determining loop execution counts for: @u32_max2_unpredictable_exit
197 ; CHECK-NEXT:  Loop %do.body: <multiple exits> backedge-taken count is (((-1 * %n) + ((2 + %n) umax %n)) umin ((-1 * %n) + %x))
198 ; CHECK-NEXT:    exit count for do.body: ((-1 * %n) + %x)
199 ; CHECK-NEXT:    exit count for if.end: ((-1 * %n) + ((2 + %n) umax %n))
200 ; CHECK-NEXT:  Loop %do.body: constant max backedge-taken count is 2
201 ; CHECK-NEXT:  Loop %do.body: symbolic max backedge-taken count is (((-1 * %n) + ((2 + %n) umax %n)) umin ((-1 * %n) + %x))
202 ; CHECK-NEXT:    symbolic max exit count for do.body: ((-1 * %n) + %x)
203 ; CHECK-NEXT:    symbolic max exit count for if.end: ((-1 * %n) + ((2 + %n) umax %n))
204 ; CHECK-NEXT:  Loop %do.body: Predicated backedge-taken count is (((-1 * %n) + ((2 + %n) umax %n)) umin ((-1 * %n) + %x))
205 ; CHECK-NEXT:   Predicates:
206 ; CHECK:       Loop %do.body: Trip multiple is 1
208 entry:
209   %add = add i32 %n, 2
210   br label %do.body
212 do.body:
213   %i.0 = phi i32 [ %n, %entry ], [ %inc, %if.end ]
214   %cmp = icmp eq i32 %i.0, %x
215   br i1 %cmp, label %do.end, label %if.end ; unpredictable
217 if.end:
218   %arrayidx = getelementptr i32, ptr %p, i32 %i.0
219   store i32 %i.0, ptr %arrayidx, align 4
220   %inc = add i32 %i.0, 1
221   %cmp1 = icmp ult i32 %i.0, %add
222   br i1 %cmp1, label %do.body, label %do.end ; taken either 0 or 2 times
224 do.end:
225   ret void