• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1; RUN: opt < %s -basicaa -licm -S | FileCheck %s
2
3declare i32 @strlen(i8*) readonly
4
5declare void @foo()
6
7; Sink readonly function.
8define i32 @test1(i8* %P) {
9	br label %Loop
10
11Loop:		; preds = %Loop, %0
12	%A = call i32 @strlen( i8* %P ) readonly
13	br i1 false, label %Loop, label %Out
14
15Out:		; preds = %Loop
16	ret i32 %A
17; CHECK-LABEL: @test1(
18; CHECK: Out:
19; CHECK-NEXT: call i32 @strlen
20; CHECK-NEXT: ret i32 %A
21}
22
23declare double @sin(double) readnone
24
25; Sink readnone function out of loop with unknown memory behavior.
26define double @test2(double %X) {
27	br label %Loop
28
29Loop:		; preds = %Loop, %0
30	call void @foo( )
31	%A = call double @sin( double %X ) readnone
32	br i1 true, label %Loop, label %Out
33
34Out:		; preds = %Loop
35	ret double %A
36; CHECK-LABEL: @test2(
37; CHECK: Out:
38; CHECK-NEXT: call double @sin
39; CHECK-NEXT: ret double %A
40}
41
42; This testcase checks to make sure the sinker does not cause problems with
43; critical edges.
44define void @test3() {
45Entry:
46	br i1 false, label %Loop, label %Exit
47Loop:
48	%X = add i32 0, 1
49	br i1 false, label %Loop, label %Exit
50Exit:
51	%Y = phi i32 [ 0, %Entry ], [ %X, %Loop ]
52	ret void
53
54; CHECK-LABEL: @test3(
55; CHECK:     Exit.loopexit:
56; CHECK-NEXT:  %X.le = add i32 0, 1
57; CHECK-NEXT:  br label %Exit
58
59}
60
61; If the result of an instruction is only used outside of the loop, sink
62; the instruction to the exit blocks instead of executing it on every
63; iteration of the loop.
64;
65define i32 @test4(i32 %N) {
66Entry:
67	br label %Loop
68Loop:		; preds = %Loop, %Entry
69	%N_addr.0.pn = phi i32 [ %dec, %Loop ], [ %N, %Entry ]
70	%tmp.6 = mul i32 %N, %N_addr.0.pn		; <i32> [#uses=1]
71	%tmp.7 = sub i32 %tmp.6, %N		; <i32> [#uses=1]
72	%dec = add i32 %N_addr.0.pn, -1		; <i32> [#uses=1]
73	%tmp.1 = icmp ne i32 %N_addr.0.pn, 1		; <i1> [#uses=1]
74	br i1 %tmp.1, label %Loop, label %Out
75Out:		; preds = %Loop
76	ret i32 %tmp.7
77; CHECK-LABEL: @test4(
78; CHECK:     Out:
79; CHECK-NEXT:  %[[LCSSAPHI:.*]] = phi i32 [ %N_addr.0.pn
80; CHECK-NEXT:  mul i32 %N, %[[LCSSAPHI]]
81; CHECK-NEXT:  sub i32 %tmp.6.le, %N
82; CHECK-NEXT:  ret i32
83}
84
85; To reduce register pressure, if a load is hoistable out of the loop, and the
86; result of the load is only used outside of the loop, sink the load instead of
87; hoisting it!
88;
89@X = global i32 5		; <i32*> [#uses=1]
90
91define i32 @test5(i32 %N) {
92Entry:
93	br label %Loop
94Loop:		; preds = %Loop, %Entry
95	%N_addr.0.pn = phi i32 [ %dec, %Loop ], [ %N, %Entry ]
96	%tmp.6 = load i32* @X		; <i32> [#uses=1]
97	%dec = add i32 %N_addr.0.pn, -1		; <i32> [#uses=1]
98	%tmp.1 = icmp ne i32 %N_addr.0.pn, 1		; <i1> [#uses=1]
99	br i1 %tmp.1, label %Loop, label %Out
100Out:		; preds = %Loop
101	ret i32 %tmp.6
102; CHECK-LABEL: @test5(
103; CHECK:     Out:
104; CHECK-NEXT:  %tmp.6.le = load i32* @X
105; CHECK-NEXT:  ret i32 %tmp.6.le
106}
107
108
109
110; The loop sinker was running from the bottom of the loop to the top, causing
111; it to miss opportunities to sink instructions that depended on sinking other
112; instructions from the loop.  Instead they got hoisted, which is better than
113; leaving them in the loop, but increases register pressure pointlessly.
114
115	%Ty = type { i32, i32 }
116@X2 = external global %Ty
117
118define i32 @test6() {
119	br label %Loop
120Loop:
121	%dead = getelementptr %Ty* @X2, i64 0, i32 0
122	%sunk2 = load i32* %dead
123	br i1 false, label %Loop, label %Out
124Out:		; preds = %Loop
125	ret i32 %sunk2
126; CHECK-LABEL: @test6(
127; CHECK:     Out:
128; CHECK-NEXT:  %dead.le = getelementptr %Ty* @X2, i64 0, i32 0
129; CHECK-NEXT:  %sunk2.le = load i32* %dead.le
130; CHECK-NEXT:  ret i32 %sunk2.le
131}
132
133
134
135; This testcase ensures that we can sink instructions from loops with
136; multiple exits.
137;
138define i32 @test7(i32 %N, i1 %C) {
139Entry:
140	br label %Loop
141Loop:		; preds = %ContLoop, %Entry
142	%N_addr.0.pn = phi i32 [ %dec, %ContLoop ], [ %N, %Entry ]
143	%tmp.6 = mul i32 %N, %N_addr.0.pn
144	%tmp.7 = sub i32 %tmp.6, %N		; <i32> [#uses=2]
145	%dec = add i32 %N_addr.0.pn, -1		; <i32> [#uses=1]
146	br i1 %C, label %ContLoop, label %Out1
147ContLoop:
148	%tmp.1 = icmp ne i32 %N_addr.0.pn, 1
149	br i1 %tmp.1, label %Loop, label %Out2
150Out1:		; preds = %Loop
151	ret i32 %tmp.7
152Out2:		; preds = %ContLoop
153	ret i32 %tmp.7
154; CHECK-LABEL: @test7(
155; CHECK:     Out1:
156; CHECK-NEXT:  %[[LCSSAPHI:.*]] = phi i32 [ %N_addr.0.pn
157; CHECK-NEXT:  mul i32 %N, %[[LCSSAPHI]]
158; CHECK-NEXT:  sub i32 %tmp.6.le, %N
159; CHECK-NEXT:  ret
160; CHECK:     Out2:
161; CHECK-NEXT:  %[[LCSSAPHI:.*]] = phi i32 [ %N_addr.0.pn
162; CHECK-NEXT:  mul i32 %N, %[[LCSSAPHI]]
163; CHECK-NEXT:  sub i32 %tmp.6.le4, %N
164; CHECK-NEXT:  ret
165}
166
167
168; This testcase checks to make sure we can sink values which are only live on
169; some exits out of the loop, and that we can do so without breaking dominator
170; info.
171define i32 @test8(i1 %C1, i1 %C2, i32* %P, i32* %Q) {
172Entry:
173	br label %Loop
174Loop:		; preds = %Cont, %Entry
175	br i1 %C1, label %Cont, label %exit1
176Cont:		; preds = %Loop
177	%X = load i32* %P		; <i32> [#uses=2]
178	store i32 %X, i32* %Q
179	%V = add i32 %X, 1		; <i32> [#uses=1]
180	br i1 %C2, label %Loop, label %exit2
181exit1:		; preds = %Loop
182	ret i32 0
183exit2:		; preds = %Cont
184	ret i32 %V
185; CHECK-LABEL: @test8(
186; CHECK:     exit1:
187; CHECK-NEXT:  ret i32 0
188; CHECK:     exit2:
189; CHECK-NEXT:  %[[LCSSAPHI:.*]] = phi i32 [ %X
190; CHECK-NEXT:  %V.le = add i32 %[[LCSSAPHI]], 1
191; CHECK-NEXT:  ret i32 %V.le
192}
193
194
195define void @test9() {
196loopentry.2.i:
197	br i1 false, label %no_exit.1.i.preheader, label %loopentry.3.i.preheader
198no_exit.1.i.preheader:		; preds = %loopentry.2.i
199	br label %no_exit.1.i
200no_exit.1.i:		; preds = %endif.8.i, %no_exit.1.i.preheader
201	br i1 false, label %return.i, label %endif.8.i
202endif.8.i:		; preds = %no_exit.1.i
203	%inc.1.i = add i32 0, 1		; <i32> [#uses=1]
204	br i1 false, label %no_exit.1.i, label %loopentry.3.i.preheader.loopexit
205loopentry.3.i.preheader.loopexit:		; preds = %endif.8.i
206	br label %loopentry.3.i.preheader
207loopentry.3.i.preheader:		; preds = %loopentry.3.i.preheader.loopexit, %loopentry.2.i
208	%arg_num.0.i.ph13000 = phi i32 [ 0, %loopentry.2.i ], [ %inc.1.i, %loopentry.3.i.preheader.loopexit ]		; <i32> [#uses=0]
209	ret void
210return.i:		; preds = %no_exit.1.i
211	ret void
212
213; CHECK-LABEL: @test9(
214; CHECK: loopentry.3.i.preheader.loopexit:
215; CHECK-NEXT:  %inc.1.i.le = add i32 0, 1
216; CHECK-NEXT:  br label %loopentry.3.i.preheader
217}
218
219
220; Potentially trapping instructions may be sunk as long as they are guaranteed
221; to be executed.
222define i32 @test10(i32 %N) {
223Entry:
224	br label %Loop
225Loop:		; preds = %Loop, %Entry
226	%N_addr.0.pn = phi i32 [ %dec, %Loop ], [ %N, %Entry ]		; <i32> [#uses=3]
227	%tmp.6 = sdiv i32 %N, %N_addr.0.pn		; <i32> [#uses=1]
228	%dec = add i32 %N_addr.0.pn, -1		; <i32> [#uses=1]
229	%tmp.1 = icmp ne i32 %N_addr.0.pn, 0		; <i1> [#uses=1]
230	br i1 %tmp.1, label %Loop, label %Out
231Out:		; preds = %Loop
232	ret i32 %tmp.6
233
234; CHECK-LABEL: @test10(
235; CHECK: Out:
236; CHECK-NEXT:  %[[LCSSAPHI:.*]] = phi i32 [ %N_addr.0.pn
237; CHECK-NEXT:  %tmp.6.le = sdiv i32 %N, %[[LCSSAPHI]]
238; CHECK-NEXT:  ret i32 %tmp.6.le
239}
240
241; Should delete, not sink, dead instructions.
242define void @test11() {
243	br label %Loop
244Loop:
245	%dead = getelementptr %Ty* @X2, i64 0, i32 0
246	br i1 false, label %Loop, label %Out
247Out:
248	ret void
249; CHECK-LABEL: @test11(
250; CHECK:     Out:
251; CHECK-NEXT:  ret void
252}
253
254@c = common global [1 x i32] zeroinitializer, align 4
255
256; Test a *many* way nested loop with multiple exit blocks both of which exit
257; multiple loop nests. This exercises LCSSA corner cases.
258define i32 @PR18753(i1* %a, i1* %b, i1* %c, i1* %d) {
259entry:
260  br label %l1.header
261
262l1.header:
263  %iv = phi i64 [ %iv.next, %l1.latch ], [ 0, %entry ]
264  %arrayidx.i = getelementptr inbounds [1 x i32]* @c, i64 0, i64 %iv
265  br label %l2.header
266
267l2.header:
268  %x0 = load i1* %c, align 4
269  br i1 %x0, label %l1.latch, label %l3.preheader
270
271l3.preheader:
272  br label %l3.header
273
274l3.header:
275  %x1 = load i1* %d, align 4
276  br i1 %x1, label %l2.latch, label %l4.preheader
277
278l4.preheader:
279  br label %l4.header
280
281l4.header:
282  %x2 = load i1* %a
283  br i1 %x2, label %l3.latch, label %l4.body
284
285l4.body:
286  call void @f(i32* %arrayidx.i)
287  %x3 = load i1* %b
288  %l = trunc i64 %iv to i32
289  br i1 %x3, label %l4.latch, label %exit
290
291l4.latch:
292  call void @g()
293  %x4 = load i1* %b, align 4
294  br i1 %x4, label %l4.header, label %exit
295
296l3.latch:
297  br label %l3.header
298
299l2.latch:
300  br label %l2.header
301
302l1.latch:
303  %iv.next = add nsw i64 %iv, 1
304  br label %l1.header
305
306exit:
307  %lcssa = phi i32 [ %l, %l4.latch ], [ %l, %l4.body ]
308; CHECK-LABEL: @PR18753(
309; CHECK:       exit:
310; CHECK-NEXT:    %[[LCSSAPHI:.*]] = phi i64 [ %iv, %l4.latch ], [ %iv, %l4.body ]
311; CHECK-NEXT:    %l.le = trunc i64 %[[LCSSAPHI]] to i32
312; CHECK-NEXT:    ret i32 %l.le
313
314  ret i32 %lcssa
315}
316
317declare void @f(i32*)
318
319declare void @g()
320