1*8d90473cSFlorian Hahn; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5
2*8d90473cSFlorian Hahn; RUN: opt -passes='loop-vectorize' -force-vector-width=8 -force-vector-interleave=2 -S %s | FileCheck --check-prefixes=CHECK %s
3*8d90473cSFlorian Hahn
4*8d90473cSFlorian Hahntarget datalayout = "e-m:o-i64:64-i128:128-n32:64-S128"
5*8d90473cSFlorian Hahn
6*8d90473cSFlorian Hahndefine i64 @remove_loop_region_int_iv_used_outside(ptr %dst) {
7*8d90473cSFlorian Hahn; CHECK-LABEL: define i64 @remove_loop_region_int_iv_used_outside(
8*8d90473cSFlorian Hahn; CHECK-SAME: ptr [[DST:%.*]]) {
9*8d90473cSFlorian Hahn; CHECK-NEXT:  [[ENTRY:.*]]:
10*8d90473cSFlorian Hahn; CHECK-NEXT:    br i1 false, label %[[SCALAR_PH:.*]], label %[[VECTOR_PH:.*]]
11*8d90473cSFlorian Hahn; CHECK:       [[VECTOR_PH]]:
12*8d90473cSFlorian Hahn; CHECK-NEXT:    br label %[[VECTOR_BODY:.*]]
13*8d90473cSFlorian Hahn; CHECK:       [[VECTOR_BODY]]:
14*8d90473cSFlorian Hahn; CHECK-NEXT:    [[TMP0:%.*]] = getelementptr ptr, ptr [[DST]], i64 0
15*8d90473cSFlorian Hahn; CHECK-NEXT:    [[TMP1:%.*]] = getelementptr ptr, ptr [[TMP0]], i32 0
16*8d90473cSFlorian Hahn; CHECK-NEXT:    [[TMP2:%.*]] = getelementptr ptr, ptr [[TMP0]], i32 8
17*8d90473cSFlorian Hahn; CHECK-NEXT:    store <8 x ptr> zeroinitializer, ptr [[TMP1]], align 8
18*8d90473cSFlorian Hahn; CHECK-NEXT:    store <8 x ptr> zeroinitializer, ptr [[TMP2]], align 8
19*8d90473cSFlorian Hahn; CHECK-NEXT:    br label %[[MIDDLE_BLOCK:.*]]
20*8d90473cSFlorian Hahn; CHECK:       [[MIDDLE_BLOCK]]:
21*8d90473cSFlorian Hahn; CHECK-NEXT:    br i1 true, label %[[EXIT:.*]], label %[[SCALAR_PH]]
22*8d90473cSFlorian Hahn; CHECK:       [[SCALAR_PH]]:
23*8d90473cSFlorian Hahn; CHECK-NEXT:    [[BC_RESUME_VAL:%.*]] = phi i64 [ 16, %[[MIDDLE_BLOCK]] ], [ 0, %[[ENTRY]] ]
24*8d90473cSFlorian Hahn; CHECK-NEXT:    br label %[[LOOP:.*]]
25*8d90473cSFlorian Hahn; CHECK:       [[LOOP]]:
26*8d90473cSFlorian Hahn; CHECK-NEXT:    [[IV:%.*]] = phi i64 [ [[BC_RESUME_VAL]], %[[SCALAR_PH]] ], [ [[IV_NEXT:%.*]], %[[LOOP]] ]
27*8d90473cSFlorian Hahn; CHECK-NEXT:    [[GEP:%.*]] = getelementptr ptr, ptr [[DST]], i64 [[IV]]
28*8d90473cSFlorian Hahn; CHECK-NEXT:    store ptr null, ptr [[GEP]], align 8
29*8d90473cSFlorian Hahn; CHECK-NEXT:    [[IV_NEXT]] = add i64 [[IV]], 1
30*8d90473cSFlorian Hahn; CHECK-NEXT:    [[EC:%.*]] = icmp eq i64 [[IV_NEXT]], 16
31*8d90473cSFlorian Hahn; CHECK-NEXT:    br i1 [[EC]], label %[[EXIT]], label %[[LOOP]], !llvm.loop [[LOOP0:![0-9]+]]
32*8d90473cSFlorian Hahn; CHECK:       [[EXIT]]:
33*8d90473cSFlorian Hahn; CHECK-NEXT:    [[RES:%.*]] = phi i64 [ [[IV]], %[[LOOP]] ], [ 15, %[[MIDDLE_BLOCK]] ]
34*8d90473cSFlorian Hahn; CHECK-NEXT:    ret i64 [[RES]]
35*8d90473cSFlorian Hahn;
36*8d90473cSFlorian Hahnentry:
37*8d90473cSFlorian Hahn  br label %loop
38*8d90473cSFlorian Hahn
39*8d90473cSFlorian Hahnloop:
40*8d90473cSFlorian Hahn  %iv = phi i64 [ 0, %entry ], [ %iv.next, %loop ]
41*8d90473cSFlorian Hahn  %gep = getelementptr ptr, ptr %dst, i64 %iv
42*8d90473cSFlorian Hahn  store ptr null, ptr %gep, align 8
43*8d90473cSFlorian Hahn  %iv.next = add i64 %iv, 1
44*8d90473cSFlorian Hahn  %ec = icmp eq i64 %iv.next, 16
45*8d90473cSFlorian Hahn  br i1 %ec, label %exit, label %loop
46*8d90473cSFlorian Hahn
47*8d90473cSFlorian Hahnexit:
48*8d90473cSFlorian Hahn  %res = phi i64 [ %iv, %loop ]
49*8d90473cSFlorian Hahn  ret i64 %res
50*8d90473cSFlorian Hahn}
51*8d90473cSFlorian Hahn
52*8d90473cSFlorian Hahndefine i64 @remove_loop_region_int_iv_inc_used_outside(ptr %dst) {
53*8d90473cSFlorian Hahn; CHECK-LABEL: define i64 @remove_loop_region_int_iv_inc_used_outside(
54*8d90473cSFlorian Hahn; CHECK-SAME: ptr [[DST:%.*]]) {
55*8d90473cSFlorian Hahn; CHECK-NEXT:  [[ENTRY:.*]]:
56*8d90473cSFlorian Hahn; CHECK-NEXT:    br i1 false, label %[[SCALAR_PH:.*]], label %[[VECTOR_PH:.*]]
57*8d90473cSFlorian Hahn; CHECK:       [[VECTOR_PH]]:
58*8d90473cSFlorian Hahn; CHECK-NEXT:    br label %[[VECTOR_BODY:.*]]
59*8d90473cSFlorian Hahn; CHECK:       [[VECTOR_BODY]]:
60*8d90473cSFlorian Hahn; CHECK-NEXT:    [[TMP0:%.*]] = getelementptr ptr, ptr [[DST]], i64 0
61*8d90473cSFlorian Hahn; CHECK-NEXT:    [[TMP1:%.*]] = getelementptr ptr, ptr [[TMP0]], i32 0
62*8d90473cSFlorian Hahn; CHECK-NEXT:    [[TMP2:%.*]] = getelementptr ptr, ptr [[TMP0]], i32 8
63*8d90473cSFlorian Hahn; CHECK-NEXT:    store <8 x ptr> zeroinitializer, ptr [[TMP1]], align 8
64*8d90473cSFlorian Hahn; CHECK-NEXT:    store <8 x ptr> zeroinitializer, ptr [[TMP2]], align 8
65*8d90473cSFlorian Hahn; CHECK-NEXT:    br label %[[MIDDLE_BLOCK:.*]]
66*8d90473cSFlorian Hahn; CHECK:       [[MIDDLE_BLOCK]]:
67*8d90473cSFlorian Hahn; CHECK-NEXT:    br i1 true, label %[[EXIT:.*]], label %[[SCALAR_PH]]
68*8d90473cSFlorian Hahn; CHECK:       [[SCALAR_PH]]:
69*8d90473cSFlorian Hahn; CHECK-NEXT:    [[BC_RESUME_VAL:%.*]] = phi i64 [ 16, %[[MIDDLE_BLOCK]] ], [ 0, %[[ENTRY]] ]
70*8d90473cSFlorian Hahn; CHECK-NEXT:    br label %[[LOOP:.*]]
71*8d90473cSFlorian Hahn; CHECK:       [[LOOP]]:
72*8d90473cSFlorian Hahn; CHECK-NEXT:    [[IV:%.*]] = phi i64 [ [[BC_RESUME_VAL]], %[[SCALAR_PH]] ], [ [[IV_NEXT:%.*]], %[[LOOP]] ]
73*8d90473cSFlorian Hahn; CHECK-NEXT:    [[GEP:%.*]] = getelementptr ptr, ptr [[DST]], i64 [[IV]]
74*8d90473cSFlorian Hahn; CHECK-NEXT:    store ptr null, ptr [[GEP]], align 8
75*8d90473cSFlorian Hahn; CHECK-NEXT:    [[IV_NEXT]] = add i64 [[IV]], 1
76*8d90473cSFlorian Hahn; CHECK-NEXT:    [[EC:%.*]] = icmp eq i64 [[IV_NEXT]], 16
77*8d90473cSFlorian Hahn; CHECK-NEXT:    br i1 [[EC]], label %[[EXIT]], label %[[LOOP]], !llvm.loop [[LOOP3:![0-9]+]]
78*8d90473cSFlorian Hahn; CHECK:       [[EXIT]]:
79*8d90473cSFlorian Hahn; CHECK-NEXT:    [[RES:%.*]] = phi i64 [ [[IV_NEXT]], %[[LOOP]] ], [ 16, %[[MIDDLE_BLOCK]] ]
80*8d90473cSFlorian Hahn; CHECK-NEXT:    ret i64 [[RES]]
81*8d90473cSFlorian Hahn;
82*8d90473cSFlorian Hahnentry:
83*8d90473cSFlorian Hahn  br label %loop
84*8d90473cSFlorian Hahn
85*8d90473cSFlorian Hahnloop:
86*8d90473cSFlorian Hahn  %iv = phi i64 [ 0, %entry ], [ %iv.next, %loop ]
87*8d90473cSFlorian Hahn  %gep = getelementptr ptr, ptr %dst, i64 %iv
88*8d90473cSFlorian Hahn  store ptr null, ptr %gep, align 8
89*8d90473cSFlorian Hahn  %iv.next = add i64 %iv, 1
90*8d90473cSFlorian Hahn  %ec = icmp eq i64 %iv.next, 16
91*8d90473cSFlorian Hahn  br i1 %ec, label %exit, label %loop
92*8d90473cSFlorian Hahn
93*8d90473cSFlorian Hahnexit:
94*8d90473cSFlorian Hahn  %res = phi i64 [ %iv.next, %loop ]
95*8d90473cSFlorian Hahn  ret i64 %res
96*8d90473cSFlorian Hahn}
97*8d90473cSFlorian Hahn
98*8d90473cSFlorian Hahndefine ptr @remove_loop_region_ptr_iv_used_outside(ptr %dst) {
99*8d90473cSFlorian Hahn; CHECK-LABEL: define ptr @remove_loop_region_ptr_iv_used_outside(
100*8d90473cSFlorian Hahn; CHECK-SAME: ptr [[DST:%.*]]) {
101*8d90473cSFlorian Hahn; CHECK-NEXT:  [[ENTRY:.*]]:
102*8d90473cSFlorian Hahn; CHECK-NEXT:    br i1 false, label %[[SCALAR_PH:.*]], label %[[VECTOR_PH:.*]]
103*8d90473cSFlorian Hahn; CHECK:       [[VECTOR_PH]]:
104*8d90473cSFlorian Hahn; CHECK-NEXT:    [[TMP0:%.*]] = getelementptr i8, ptr [[DST]], i64 128
105*8d90473cSFlorian Hahn; CHECK-NEXT:    br label %[[VECTOR_BODY:.*]]
106*8d90473cSFlorian Hahn; CHECK:       [[VECTOR_BODY]]:
107*8d90473cSFlorian Hahn; CHECK-NEXT:    [[NEXT_GEP:%.*]] = getelementptr i8, ptr [[DST]], i64 0
108*8d90473cSFlorian Hahn; CHECK-NEXT:    [[TMP1:%.*]] = getelementptr ptr, ptr [[NEXT_GEP]], i32 0
109*8d90473cSFlorian Hahn; CHECK-NEXT:    [[TMP2:%.*]] = getelementptr ptr, ptr [[NEXT_GEP]], i32 8
110*8d90473cSFlorian Hahn; CHECK-NEXT:    store <8 x ptr> zeroinitializer, ptr [[TMP1]], align 8
111*8d90473cSFlorian Hahn; CHECK-NEXT:    store <8 x ptr> zeroinitializer, ptr [[TMP2]], align 8
112*8d90473cSFlorian Hahn; CHECK-NEXT:    br label %[[MIDDLE_BLOCK:.*]]
113*8d90473cSFlorian Hahn; CHECK:       [[MIDDLE_BLOCK]]:
114*8d90473cSFlorian Hahn; CHECK-NEXT:    [[IND_ESCAPE:%.*]] = getelementptr i8, ptr [[TMP0]], i64 -8
115*8d90473cSFlorian Hahn; CHECK-NEXT:    br i1 true, label %[[EXIT:.*]], label %[[SCALAR_PH]]
116*8d90473cSFlorian Hahn; CHECK:       [[SCALAR_PH]]:
117*8d90473cSFlorian Hahn; CHECK-NEXT:    [[BC_RESUME_VAL:%.*]] = phi ptr [ [[TMP0]], %[[MIDDLE_BLOCK]] ], [ [[DST]], %[[ENTRY]] ]
118*8d90473cSFlorian Hahn; CHECK-NEXT:    [[BC_RESUME_VAL1:%.*]] = phi i64 [ 16, %[[MIDDLE_BLOCK]] ], [ 0, %[[ENTRY]] ]
119*8d90473cSFlorian Hahn; CHECK-NEXT:    br label %[[LOOP:.*]]
120*8d90473cSFlorian Hahn; CHECK:       [[LOOP]]:
121*8d90473cSFlorian Hahn; CHECK-NEXT:    [[PTR_IV:%.*]] = phi ptr [ [[BC_RESUME_VAL]], %[[SCALAR_PH]] ], [ [[PTR_IV_NEXT:%.*]], %[[LOOP]] ]
122*8d90473cSFlorian Hahn; CHECK-NEXT:    [[INT_IV:%.*]] = phi i64 [ [[BC_RESUME_VAL1]], %[[SCALAR_PH]] ], [ [[INT_IV_NEXT:%.*]], %[[LOOP]] ]
123*8d90473cSFlorian Hahn; CHECK-NEXT:    store ptr null, ptr [[PTR_IV]], align 8
124*8d90473cSFlorian Hahn; CHECK-NEXT:    [[INT_IV_NEXT]] = add i64 [[INT_IV]], 1
125*8d90473cSFlorian Hahn; CHECK-NEXT:    [[PTR_IV_NEXT]] = getelementptr i8, ptr [[PTR_IV]], i64 8
126*8d90473cSFlorian Hahn; CHECK-NEXT:    [[EC:%.*]] = icmp eq i64 [[INT_IV_NEXT]], 16
127*8d90473cSFlorian Hahn; CHECK-NEXT:    br i1 [[EC]], label %[[EXIT]], label %[[LOOP]], !llvm.loop [[LOOP4:![0-9]+]]
128*8d90473cSFlorian Hahn; CHECK:       [[EXIT]]:
129*8d90473cSFlorian Hahn; CHECK-NEXT:    [[RES:%.*]] = phi ptr [ [[PTR_IV]], %[[LOOP]] ], [ [[IND_ESCAPE]], %[[MIDDLE_BLOCK]] ]
130*8d90473cSFlorian Hahn; CHECK-NEXT:    ret ptr [[RES]]
131*8d90473cSFlorian Hahn;
132*8d90473cSFlorian Hahnentry:
133*8d90473cSFlorian Hahn  br label %loop
134*8d90473cSFlorian Hahn
135*8d90473cSFlorian Hahnloop:
136*8d90473cSFlorian Hahn  %ptr.iv = phi ptr [ %dst, %entry ], [ %ptr.iv.next, %loop ]
137*8d90473cSFlorian Hahn  %int.iv = phi i64 [ 0, %entry ], [ %int.iv.next, %loop ]
138*8d90473cSFlorian Hahn  store ptr null, ptr %ptr.iv, align 8
139*8d90473cSFlorian Hahn  %int.iv.next = add i64 %int.iv, 1
140*8d90473cSFlorian Hahn  %ptr.iv.next = getelementptr i8, ptr %ptr.iv, i64 8
141*8d90473cSFlorian Hahn  %ec = icmp eq i64 %int.iv.next, 16
142*8d90473cSFlorian Hahn  br i1 %ec, label %exit, label %loop
143*8d90473cSFlorian Hahn
144*8d90473cSFlorian Hahnexit:
145*8d90473cSFlorian Hahn  %res = phi ptr [ %ptr.iv, %loop ]
146*8d90473cSFlorian Hahn  ret ptr %res
147*8d90473cSFlorian Hahn}
148*8d90473cSFlorian Hahn
149*8d90473cSFlorian Hahndefine ptr @remove_loop_region_ptr_iv_inc_used_outside(ptr %dst) {
150*8d90473cSFlorian Hahn; CHECK-LABEL: define ptr @remove_loop_region_ptr_iv_inc_used_outside(
151*8d90473cSFlorian Hahn; CHECK-SAME: ptr [[DST:%.*]]) {
152*8d90473cSFlorian Hahn; CHECK-NEXT:  [[ENTRY:.*]]:
153*8d90473cSFlorian Hahn; CHECK-NEXT:    br i1 false, label %[[SCALAR_PH:.*]], label %[[VECTOR_PH:.*]]
154*8d90473cSFlorian Hahn; CHECK:       [[VECTOR_PH]]:
155*8d90473cSFlorian Hahn; CHECK-NEXT:    [[TMP0:%.*]] = getelementptr i8, ptr [[DST]], i64 128
156*8d90473cSFlorian Hahn; CHECK-NEXT:    br label %[[VECTOR_BODY:.*]]
157*8d90473cSFlorian Hahn; CHECK:       [[VECTOR_BODY]]:
158*8d90473cSFlorian Hahn; CHECK-NEXT:    [[NEXT_GEP:%.*]] = getelementptr i8, ptr [[DST]], i64 0
159*8d90473cSFlorian Hahn; CHECK-NEXT:    [[TMP1:%.*]] = getelementptr ptr, ptr [[NEXT_GEP]], i32 0
160*8d90473cSFlorian Hahn; CHECK-NEXT:    [[TMP2:%.*]] = getelementptr ptr, ptr [[NEXT_GEP]], i32 8
161*8d90473cSFlorian Hahn; CHECK-NEXT:    store <8 x ptr> zeroinitializer, ptr [[TMP1]], align 8
162*8d90473cSFlorian Hahn; CHECK-NEXT:    store <8 x ptr> zeroinitializer, ptr [[TMP2]], align 8
163*8d90473cSFlorian Hahn; CHECK-NEXT:    br label %[[MIDDLE_BLOCK:.*]]
164*8d90473cSFlorian Hahn; CHECK:       [[MIDDLE_BLOCK]]:
165*8d90473cSFlorian Hahn; CHECK-NEXT:    br i1 true, label %[[EXIT:.*]], label %[[SCALAR_PH]]
166*8d90473cSFlorian Hahn; CHECK:       [[SCALAR_PH]]:
167*8d90473cSFlorian Hahn; CHECK-NEXT:    [[BC_RESUME_VAL:%.*]] = phi ptr [ [[TMP0]], %[[MIDDLE_BLOCK]] ], [ [[DST]], %[[ENTRY]] ]
168*8d90473cSFlorian Hahn; CHECK-NEXT:    [[BC_RESUME_VAL1:%.*]] = phi i64 [ 16, %[[MIDDLE_BLOCK]] ], [ 0, %[[ENTRY]] ]
169*8d90473cSFlorian Hahn; CHECK-NEXT:    br label %[[LOOP:.*]]
170*8d90473cSFlorian Hahn; CHECK:       [[LOOP]]:
171*8d90473cSFlorian Hahn; CHECK-NEXT:    [[PTR_IV:%.*]] = phi ptr [ [[BC_RESUME_VAL]], %[[SCALAR_PH]] ], [ [[PTR_IV_NEXT:%.*]], %[[LOOP]] ]
172*8d90473cSFlorian Hahn; CHECK-NEXT:    [[INT_IV:%.*]] = phi i64 [ [[BC_RESUME_VAL1]], %[[SCALAR_PH]] ], [ [[INT_IV_NEXT:%.*]], %[[LOOP]] ]
173*8d90473cSFlorian Hahn; CHECK-NEXT:    store ptr null, ptr [[PTR_IV]], align 8
174*8d90473cSFlorian Hahn; CHECK-NEXT:    [[INT_IV_NEXT]] = add i64 [[INT_IV]], 1
175*8d90473cSFlorian Hahn; CHECK-NEXT:    [[PTR_IV_NEXT]] = getelementptr i8, ptr [[PTR_IV]], i64 8
176*8d90473cSFlorian Hahn; CHECK-NEXT:    [[EC:%.*]] = icmp eq i64 [[INT_IV_NEXT]], 16
177*8d90473cSFlorian Hahn; CHECK-NEXT:    br i1 [[EC]], label %[[EXIT]], label %[[LOOP]], !llvm.loop [[LOOP5:![0-9]+]]
178*8d90473cSFlorian Hahn; CHECK:       [[EXIT]]:
179*8d90473cSFlorian Hahn; CHECK-NEXT:    [[RES:%.*]] = phi ptr [ [[PTR_IV_NEXT]], %[[LOOP]] ], [ [[TMP0]], %[[MIDDLE_BLOCK]] ]
180*8d90473cSFlorian Hahn; CHECK-NEXT:    ret ptr [[RES]]
181*8d90473cSFlorian Hahn;
182*8d90473cSFlorian Hahnentry:
183*8d90473cSFlorian Hahn  br label %loop
184*8d90473cSFlorian Hahn
185*8d90473cSFlorian Hahnloop:
186*8d90473cSFlorian Hahn  %ptr.iv = phi ptr [ %dst, %entry ], [ %ptr.iv.next, %loop ]
187*8d90473cSFlorian Hahn  %int.iv = phi i64 [ 0, %entry ], [ %int.iv.next, %loop ]
188*8d90473cSFlorian Hahn  store ptr null, ptr %ptr.iv, align 8
189*8d90473cSFlorian Hahn  %int.iv.next = add i64 %int.iv, 1
190*8d90473cSFlorian Hahn  %ptr.iv.next = getelementptr i8, ptr %ptr.iv, i64 8
191*8d90473cSFlorian Hahn  %ec = icmp eq i64 %int.iv.next, 16
192*8d90473cSFlorian Hahn  br i1 %ec, label %exit, label %loop
193*8d90473cSFlorian Hahn
194*8d90473cSFlorian Hahnexit:
195*8d90473cSFlorian Hahn  %res = phi ptr [ %ptr.iv.next, %loop ]
196*8d90473cSFlorian Hahn  ret ptr %res
197*8d90473cSFlorian Hahn}
198*8d90473cSFlorian Hahn;.
199*8d90473cSFlorian Hahn; CHECK: [[LOOP0]] = distinct !{[[LOOP0]], [[META1:![0-9]+]], [[META2:![0-9]+]]}
200*8d90473cSFlorian Hahn; CHECK: [[META1]] = !{!"llvm.loop.unroll.runtime.disable"}
201*8d90473cSFlorian Hahn; CHECK: [[META2]] = !{!"llvm.loop.isvectorized", i32 1}
202*8d90473cSFlorian Hahn; CHECK: [[LOOP3]] = distinct !{[[LOOP3]], [[META1]], [[META2]]}
203*8d90473cSFlorian Hahn; CHECK: [[LOOP4]] = distinct !{[[LOOP4]], [[META1]], [[META2]]}
204*8d90473cSFlorian Hahn; CHECK: [[LOOP5]] = distinct !{[[LOOP5]], [[META1]], [[META2]]}
205*8d90473cSFlorian Hahn;.
206