Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / VE / VELIntrinsics / vdiv.ll
blobec149ee8a0d4156033b83106f660cbe01e8abe62
1 ; RUN: llc < %s -mtriple=ve -mattr=+vpu | FileCheck %s
3 ;;; Test vector divide intrinsic instructions
4 ;;;
5 ;;; Note:
6 ;;;   We test VDIV*vvl, VDIV*vvl_v, VDIV*rvl, VDIV*rvl_v, VDIV*ivl,
7 ;;;   VDIV*ivl_v, VDIV*vvml_v, VDIV*rvml_v, VDIV*ivml_v, VDIV*vrl,
8 ;;;   VDIV*vrl_v, VDIV*vil, VDIV*vil_v, VDIV*vrml_v, and VDIV*viml_v
9 ;;;   instructions.
11 ; Function Attrs: nounwind readnone
12 define fastcc <256 x double> @vdivul_vvvl(<256 x double> %0, <256 x double> %1) {
13 ; CHECK-LABEL: vdivul_vvvl:
14 ; CHECK:       # %bb.0:
15 ; CHECK-NEXT:    lea %s0, 256
16 ; CHECK-NEXT:    lvl %s0
17 ; CHECK-NEXT:    vdivu.l %v0, %v0, %v1
18 ; CHECK-NEXT:    b.l.t (, %s10)
19   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivul.vvvl(<256 x double> %0, <256 x double> %1, i32 256)
20   ret <256 x double> %3
23 ; Function Attrs: nounwind readnone
24 declare <256 x double> @llvm.ve.vl.vdivul.vvvl(<256 x double>, <256 x double>, i32)
26 ; Function Attrs: nounwind readnone
27 define fastcc <256 x double> @vdivul_vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2) {
28 ; CHECK-LABEL: vdivul_vvvvl:
29 ; CHECK:       # %bb.0:
30 ; CHECK-NEXT:    lea %s0, 128
31 ; CHECK-NEXT:    lvl %s0
32 ; CHECK-NEXT:    vdivu.l %v2, %v0, %v1
33 ; CHECK-NEXT:    lea %s16, 256
34 ; CHECK-NEXT:    lvl %s16
35 ; CHECK-NEXT:    vor %v0, (0)1, %v2
36 ; CHECK-NEXT:    b.l.t (, %s10)
37   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivul.vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, i32 128)
38   ret <256 x double> %4
41 ; Function Attrs: nounwind readnone
42 declare <256 x double> @llvm.ve.vl.vdivul.vvvvl(<256 x double>, <256 x double>, <256 x double>, i32)
44 ; Function Attrs: nounwind readnone
45 define fastcc <256 x double> @vdivul_vsvl(i64 %0, <256 x double> %1) {
46 ; CHECK-LABEL: vdivul_vsvl:
47 ; CHECK:       # %bb.0:
48 ; CHECK-NEXT:    lea %s1, 256
49 ; CHECK-NEXT:    lvl %s1
50 ; CHECK-NEXT:    vdivu.l %v0, %s0, %v0
51 ; CHECK-NEXT:    b.l.t (, %s10)
52   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivul.vsvl(i64 %0, <256 x double> %1, i32 256)
53   ret <256 x double> %3
56 ; Function Attrs: nounwind readnone
57 declare <256 x double> @llvm.ve.vl.vdivul.vsvl(i64, <256 x double>, i32)
59 ; Function Attrs: nounwind readnone
60 define fastcc <256 x double> @vdivul_vsvvl(i64 %0, <256 x double> %1, <256 x double> %2) {
61 ; CHECK-LABEL: vdivul_vsvvl:
62 ; CHECK:       # %bb.0:
63 ; CHECK-NEXT:    lea %s1, 128
64 ; CHECK-NEXT:    lvl %s1
65 ; CHECK-NEXT:    vdivu.l %v1, %s0, %v0
66 ; CHECK-NEXT:    lea %s16, 256
67 ; CHECK-NEXT:    lvl %s16
68 ; CHECK-NEXT:    vor %v0, (0)1, %v1
69 ; CHECK-NEXT:    b.l.t (, %s10)
70   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivul.vsvvl(i64 %0, <256 x double> %1, <256 x double> %2, i32 128)
71   ret <256 x double> %4
74 ; Function Attrs: nounwind readnone
75 declare <256 x double> @llvm.ve.vl.vdivul.vsvvl(i64, <256 x double>, <256 x double>, i32)
77 ; Function Attrs: nounwind readnone
78 define fastcc <256 x double> @vdivul_vsvl_imm(<256 x double> %0) {
79 ; CHECK-LABEL: vdivul_vsvl_imm:
80 ; CHECK:       # %bb.0:
81 ; CHECK-NEXT:    lea %s0, 256
82 ; CHECK-NEXT:    lvl %s0
83 ; CHECK-NEXT:    vdivu.l %v0, 8, %v0
84 ; CHECK-NEXT:    b.l.t (, %s10)
85   %2 = tail call fast <256 x double> @llvm.ve.vl.vdivul.vsvl(i64 8, <256 x double> %0, i32 256)
86   ret <256 x double> %2
89 ; Function Attrs: nounwind readnone
90 define fastcc <256 x double> @vdivul_vsvvl_imm(<256 x double> %0, <256 x double> %1) {
91 ; CHECK-LABEL: vdivul_vsvvl_imm:
92 ; CHECK:       # %bb.0:
93 ; CHECK-NEXT:    lea %s0, 128
94 ; CHECK-NEXT:    lvl %s0
95 ; CHECK-NEXT:    vdivu.l %v1, 8, %v0
96 ; CHECK-NEXT:    lea %s16, 256
97 ; CHECK-NEXT:    lvl %s16
98 ; CHECK-NEXT:    vor %v0, (0)1, %v1
99 ; CHECK-NEXT:    b.l.t (, %s10)
100   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivul.vsvvl(i64 8, <256 x double> %0, <256 x double> %1, i32 128)
101   ret <256 x double> %3
104 ; Function Attrs: nounwind readnone
105 define fastcc <256 x double> @vdivul_vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3) {
106 ; CHECK-LABEL: vdivul_vvvmvl:
107 ; CHECK:       # %bb.0:
108 ; CHECK-NEXT:    lea %s0, 128
109 ; CHECK-NEXT:    lvl %s0
110 ; CHECK-NEXT:    vdivu.l %v2, %v0, %v1, %vm1
111 ; CHECK-NEXT:    lea %s16, 256
112 ; CHECK-NEXT:    lvl %s16
113 ; CHECK-NEXT:    vor %v0, (0)1, %v2
114 ; CHECK-NEXT:    b.l.t (, %s10)
115   %5 = tail call fast <256 x double> @llvm.ve.vl.vdivul.vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3, i32 128)
116   ret <256 x double> %5
119 ; Function Attrs: nounwind readnone
120 declare <256 x double> @llvm.ve.vl.vdivul.vvvmvl(<256 x double>, <256 x double>, <256 x i1>, <256 x double>, i32)
122 ; Function Attrs: nounwind readnone
123 define fastcc <256 x double> @vdivul_vsvmvl(i64 %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3) {
124 ; CHECK-LABEL: vdivul_vsvmvl:
125 ; CHECK:       # %bb.0:
126 ; CHECK-NEXT:    lea %s1, 128
127 ; CHECK-NEXT:    lvl %s1
128 ; CHECK-NEXT:    vdivu.l %v1, %s0, %v0, %vm1
129 ; CHECK-NEXT:    lea %s16, 256
130 ; CHECK-NEXT:    lvl %s16
131 ; CHECK-NEXT:    vor %v0, (0)1, %v1
132 ; CHECK-NEXT:    b.l.t (, %s10)
133   %5 = tail call fast <256 x double> @llvm.ve.vl.vdivul.vsvmvl(i64 %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3, i32 128)
134   ret <256 x double> %5
137 ; Function Attrs: nounwind readnone
138 declare <256 x double> @llvm.ve.vl.vdivul.vsvmvl(i64, <256 x double>, <256 x i1>, <256 x double>, i32)
140 ; Function Attrs: nounwind readnone
141 define fastcc <256 x double> @vdivul_vsvmvl_imm(<256 x double> %0, <256 x i1> %1, <256 x double> %2) {
142 ; CHECK-LABEL: vdivul_vsvmvl_imm:
143 ; CHECK:       # %bb.0:
144 ; CHECK-NEXT:    lea %s0, 128
145 ; CHECK-NEXT:    lvl %s0
146 ; CHECK-NEXT:    vdivu.l %v1, 8, %v0, %vm1
147 ; CHECK-NEXT:    lea %s16, 256
148 ; CHECK-NEXT:    lvl %s16
149 ; CHECK-NEXT:    vor %v0, (0)1, %v1
150 ; CHECK-NEXT:    b.l.t (, %s10)
151   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivul.vsvmvl(i64 8, <256 x double> %0, <256 x i1> %1, <256 x double> %2, i32 128)
152   ret <256 x double> %4
155 ; Function Attrs: nounwind readnone
156 define fastcc <256 x double> @vdivul_vvsl(<256 x double> %0, i64 %1) {
157 ; CHECK-LABEL: vdivul_vvsl:
158 ; CHECK:       # %bb.0:
159 ; CHECK-NEXT:    lea %s1, 256
160 ; CHECK-NEXT:    lvl %s1
161 ; CHECK-NEXT:    vdivu.l %v0, %v0, %s0
162 ; CHECK-NEXT:    b.l.t (, %s10)
163   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivul.vvsl(<256 x double> %0, i64 %1, i32 256)
164   ret <256 x double> %3
167 ; Function Attrs: nounwind readnone
168 declare <256 x double> @llvm.ve.vl.vdivul.vvsl(<256 x double>, i64, i32)
170 ; Function Attrs: nounwind readnone
171 define fastcc <256 x double> @vdivul_vvsvl(<256 x double> %0, i64 %1, <256 x double> %2) {
172 ; CHECK-LABEL: vdivul_vvsvl:
173 ; CHECK:       # %bb.0:
174 ; CHECK-NEXT:    lea %s1, 128
175 ; CHECK-NEXT:    lvl %s1
176 ; CHECK-NEXT:    vdivu.l %v1, %v0, %s0
177 ; CHECK-NEXT:    lea %s16, 256
178 ; CHECK-NEXT:    lvl %s16
179 ; CHECK-NEXT:    vor %v0, (0)1, %v1
180 ; CHECK-NEXT:    b.l.t (, %s10)
181   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivul.vvsvl(<256 x double> %0, i64 %1, <256 x double> %2, i32 128)
182   ret <256 x double> %4
185 ; Function Attrs: nounwind readnone
186 declare <256 x double> @llvm.ve.vl.vdivul.vvsvl(<256 x double>, i64, <256 x double>, i32)
188 ; Function Attrs: nounwind readnone
189 define fastcc <256 x double> @vdivul_vvsl_imm(<256 x double> %0) {
190 ; CHECK-LABEL: vdivul_vvsl_imm:
191 ; CHECK:       # %bb.0:
192 ; CHECK-NEXT:    lea %s0, 256
193 ; CHECK-NEXT:    lvl %s0
194 ; CHECK-NEXT:    vdivu.l %v0, %v0, 8
195 ; CHECK-NEXT:    b.l.t (, %s10)
196   %2 = tail call fast <256 x double> @llvm.ve.vl.vdivul.vvsl(<256 x double> %0, i64 8, i32 256)
197   ret <256 x double> %2
200 ; Function Attrs: nounwind readnone
201 define fastcc <256 x double> @vdivul_vvsvl_imm(<256 x double> %0, <256 x double> %1) {
202 ; CHECK-LABEL: vdivul_vvsvl_imm:
203 ; CHECK:       # %bb.0:
204 ; CHECK-NEXT:    lea %s0, 128
205 ; CHECK-NEXT:    lvl %s0
206 ; CHECK-NEXT:    vdivu.l %v1, %v0, 8
207 ; CHECK-NEXT:    lea %s16, 256
208 ; CHECK-NEXT:    lvl %s16
209 ; CHECK-NEXT:    vor %v0, (0)1, %v1
210 ; CHECK-NEXT:    b.l.t (, %s10)
211   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivul.vvsvl(<256 x double> %0, i64 8, <256 x double> %1, i32 128)
212   ret <256 x double> %3
215 ; Function Attrs: nounwind readnone
216 define fastcc <256 x double> @vdivul_vvsmvl(<256 x double> %0, i64 %1, <256 x i1> %2, <256 x double> %3) {
217 ; CHECK-LABEL: vdivul_vvsmvl:
218 ; CHECK:       # %bb.0:
219 ; CHECK-NEXT:    lea %s1, 128
220 ; CHECK-NEXT:    lvl %s1
221 ; CHECK-NEXT:    vdivu.l %v1, %v0, %s0, %vm1
222 ; CHECK-NEXT:    lea %s16, 256
223 ; CHECK-NEXT:    lvl %s16
224 ; CHECK-NEXT:    vor %v0, (0)1, %v1
225 ; CHECK-NEXT:    b.l.t (, %s10)
226   %5 = tail call fast <256 x double> @llvm.ve.vl.vdivul.vvsmvl(<256 x double> %0, i64 %1, <256 x i1> %2, <256 x double> %3, i32 128)
227   ret <256 x double> %5
230 ; Function Attrs: nounwind readnone
231 declare <256 x double> @llvm.ve.vl.vdivul.vvsmvl(<256 x double>, i64, <256 x i1>, <256 x double>, i32)
233 ; Function Attrs: nounwind readnone
234 define fastcc <256 x double> @vdivul_vvsmvl_imm(<256 x double> %0, <256 x i1> %1, <256 x double> %2) {
235 ; CHECK-LABEL: vdivul_vvsmvl_imm:
236 ; CHECK:       # %bb.0:
237 ; CHECK-NEXT:    lea %s0, 128
238 ; CHECK-NEXT:    lvl %s0
239 ; CHECK-NEXT:    vdivu.l %v1, %v0, 8, %vm1
240 ; CHECK-NEXT:    lea %s16, 256
241 ; CHECK-NEXT:    lvl %s16
242 ; CHECK-NEXT:    vor %v0, (0)1, %v1
243 ; CHECK-NEXT:    b.l.t (, %s10)
244   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivul.vvsmvl(<256 x double> %0, i64 8, <256 x i1> %1, <256 x double> %2, i32 128)
245   ret <256 x double> %4
248 ; Function Attrs: nounwind readnone
249 define fastcc <256 x double> @vdivuw_vvvl(<256 x double> %0, <256 x double> %1) {
250 ; CHECK-LABEL: vdivuw_vvvl:
251 ; CHECK:       # %bb.0:
252 ; CHECK-NEXT:    lea %s0, 256
253 ; CHECK-NEXT:    lvl %s0
254 ; CHECK-NEXT:    vdivu.w %v0, %v0, %v1
255 ; CHECK-NEXT:    b.l.t (, %s10)
256   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivuw.vvvl(<256 x double> %0, <256 x double> %1, i32 256)
257   ret <256 x double> %3
260 ; Function Attrs: nounwind readnone
261 declare <256 x double> @llvm.ve.vl.vdivuw.vvvl(<256 x double>, <256 x double>, i32)
263 ; Function Attrs: nounwind readnone
264 define fastcc <256 x double> @vdivuw_vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2) {
265 ; CHECK-LABEL: vdivuw_vvvvl:
266 ; CHECK:       # %bb.0:
267 ; CHECK-NEXT:    lea %s0, 128
268 ; CHECK-NEXT:    lvl %s0
269 ; CHECK-NEXT:    vdivu.w %v2, %v0, %v1
270 ; CHECK-NEXT:    lea %s16, 256
271 ; CHECK-NEXT:    lvl %s16
272 ; CHECK-NEXT:    vor %v0, (0)1, %v2
273 ; CHECK-NEXT:    b.l.t (, %s10)
274   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivuw.vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, i32 128)
275   ret <256 x double> %4
278 ; Function Attrs: nounwind readnone
279 declare <256 x double> @llvm.ve.vl.vdivuw.vvvvl(<256 x double>, <256 x double>, <256 x double>, i32)
281 ; Function Attrs: nounwind readnone
282 define fastcc <256 x double> @vdivuw_vsvl(i32 signext %0, <256 x double> %1) {
283 ; CHECK-LABEL: vdivuw_vsvl:
284 ; CHECK:       # %bb.0:
285 ; CHECK-NEXT:    and %s0, %s0, (32)0
286 ; CHECK-NEXT:    lea %s1, 256
287 ; CHECK-NEXT:    lvl %s1
288 ; CHECK-NEXT:    vdivu.w %v0, %s0, %v0
289 ; CHECK-NEXT:    b.l.t (, %s10)
290   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivuw.vsvl(i32 %0, <256 x double> %1, i32 256)
291   ret <256 x double> %3
294 ; Function Attrs: nounwind readnone
295 declare <256 x double> @llvm.ve.vl.vdivuw.vsvl(i32, <256 x double>, i32)
297 ; Function Attrs: nounwind readnone
298 define fastcc <256 x double> @vdivuw_vsvvl(i32 signext %0, <256 x double> %1, <256 x double> %2) {
299 ; CHECK-LABEL: vdivuw_vsvvl:
300 ; CHECK:       # %bb.0:
301 ; CHECK-NEXT:    and %s0, %s0, (32)0
302 ; CHECK-NEXT:    lea %s1, 128
303 ; CHECK-NEXT:    lvl %s1
304 ; CHECK-NEXT:    vdivu.w %v1, %s0, %v0
305 ; CHECK-NEXT:    lea %s16, 256
306 ; CHECK-NEXT:    lvl %s16
307 ; CHECK-NEXT:    vor %v0, (0)1, %v1
308 ; CHECK-NEXT:    b.l.t (, %s10)
309   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivuw.vsvvl(i32 %0, <256 x double> %1, <256 x double> %2, i32 128)
310   ret <256 x double> %4
313 ; Function Attrs: nounwind readnone
314 declare <256 x double> @llvm.ve.vl.vdivuw.vsvvl(i32, <256 x double>, <256 x double>, i32)
316 ; Function Attrs: nounwind readnone
317 define fastcc <256 x double> @vdivuw_vsvl_imm(<256 x double> %0) {
318 ; CHECK-LABEL: vdivuw_vsvl_imm:
319 ; CHECK:       # %bb.0:
320 ; CHECK-NEXT:    lea %s0, 256
321 ; CHECK-NEXT:    lvl %s0
322 ; CHECK-NEXT:    vdivu.w %v0, 8, %v0
323 ; CHECK-NEXT:    b.l.t (, %s10)
324   %2 = tail call fast <256 x double> @llvm.ve.vl.vdivuw.vsvl(i32 8, <256 x double> %0, i32 256)
325   ret <256 x double> %2
328 ; Function Attrs: nounwind readnone
329 define fastcc <256 x double> @vdivuw_vsvvl_imm(<256 x double> %0, <256 x double> %1) {
330 ; CHECK-LABEL: vdivuw_vsvvl_imm:
331 ; CHECK:       # %bb.0:
332 ; CHECK-NEXT:    lea %s0, 128
333 ; CHECK-NEXT:    lvl %s0
334 ; CHECK-NEXT:    vdivu.w %v1, 8, %v0
335 ; CHECK-NEXT:    lea %s16, 256
336 ; CHECK-NEXT:    lvl %s16
337 ; CHECK-NEXT:    vor %v0, (0)1, %v1
338 ; CHECK-NEXT:    b.l.t (, %s10)
339   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivuw.vsvvl(i32 8, <256 x double> %0, <256 x double> %1, i32 128)
340   ret <256 x double> %3
343 ; Function Attrs: nounwind readnone
344 define fastcc <256 x double> @vdivuw_vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3) {
345 ; CHECK-LABEL: vdivuw_vvvmvl:
346 ; CHECK:       # %bb.0:
347 ; CHECK-NEXT:    lea %s0, 128
348 ; CHECK-NEXT:    lvl %s0
349 ; CHECK-NEXT:    vdivu.w %v2, %v0, %v1, %vm1
350 ; CHECK-NEXT:    lea %s16, 256
351 ; CHECK-NEXT:    lvl %s16
352 ; CHECK-NEXT:    vor %v0, (0)1, %v2
353 ; CHECK-NEXT:    b.l.t (, %s10)
354   %5 = tail call fast <256 x double> @llvm.ve.vl.vdivuw.vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3, i32 128)
355   ret <256 x double> %5
358 ; Function Attrs: nounwind readnone
359 declare <256 x double> @llvm.ve.vl.vdivuw.vvvmvl(<256 x double>, <256 x double>, <256 x i1>, <256 x double>, i32)
361 ; Function Attrs: nounwind readnone
362 define fastcc <256 x double> @vdivuw_vsvmvl(i32 signext %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3) {
363 ; CHECK-LABEL: vdivuw_vsvmvl:
364 ; CHECK:       # %bb.0:
365 ; CHECK-NEXT:    and %s0, %s0, (32)0
366 ; CHECK-NEXT:    lea %s1, 128
367 ; CHECK-NEXT:    lvl %s1
368 ; CHECK-NEXT:    vdivu.w %v1, %s0, %v0, %vm1
369 ; CHECK-NEXT:    lea %s16, 256
370 ; CHECK-NEXT:    lvl %s16
371 ; CHECK-NEXT:    vor %v0, (0)1, %v1
372 ; CHECK-NEXT:    b.l.t (, %s10)
373   %5 = tail call fast <256 x double> @llvm.ve.vl.vdivuw.vsvmvl(i32 %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3, i32 128)
374   ret <256 x double> %5
377 ; Function Attrs: nounwind readnone
378 declare <256 x double> @llvm.ve.vl.vdivuw.vsvmvl(i32, <256 x double>, <256 x i1>, <256 x double>, i32)
380 ; Function Attrs: nounwind readnone
381 define fastcc <256 x double> @vdivuw_vsvmvl_imm(<256 x double> %0, <256 x i1> %1, <256 x double> %2) {
382 ; CHECK-LABEL: vdivuw_vsvmvl_imm:
383 ; CHECK:       # %bb.0:
384 ; CHECK-NEXT:    lea %s0, 128
385 ; CHECK-NEXT:    lvl %s0
386 ; CHECK-NEXT:    vdivu.w %v1, 8, %v0, %vm1
387 ; CHECK-NEXT:    lea %s16, 256
388 ; CHECK-NEXT:    lvl %s16
389 ; CHECK-NEXT:    vor %v0, (0)1, %v1
390 ; CHECK-NEXT:    b.l.t (, %s10)
391   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivuw.vsvmvl(i32 8, <256 x double> %0, <256 x i1> %1, <256 x double> %2, i32 128)
392   ret <256 x double> %4
395 ; Function Attrs: nounwind readnone
396 define fastcc <256 x double> @vdivuw_vvsl(<256 x double> %0, i32 signext %1) {
397 ; CHECK-LABEL: vdivuw_vvsl:
398 ; CHECK:       # %bb.0:
399 ; CHECK-NEXT:    and %s0, %s0, (32)0
400 ; CHECK-NEXT:    lea %s1, 256
401 ; CHECK-NEXT:    lvl %s1
402 ; CHECK-NEXT:    vdivu.w %v0, %v0, %s0
403 ; CHECK-NEXT:    b.l.t (, %s10)
404   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivuw.vvsl(<256 x double> %0, i32 %1, i32 256)
405   ret <256 x double> %3
408 ; Function Attrs: nounwind readnone
409 declare <256 x double> @llvm.ve.vl.vdivuw.vvsl(<256 x double>, i32, i32)
411 ; Function Attrs: nounwind readnone
412 define fastcc <256 x double> @vdivuw_vvsvl(<256 x double> %0, i32 signext %1, <256 x double> %2) {
413 ; CHECK-LABEL: vdivuw_vvsvl:
414 ; CHECK:       # %bb.0:
415 ; CHECK-NEXT:    and %s0, %s0, (32)0
416 ; CHECK-NEXT:    lea %s1, 128
417 ; CHECK-NEXT:    lvl %s1
418 ; CHECK-NEXT:    vdivu.w %v1, %v0, %s0
419 ; CHECK-NEXT:    lea %s16, 256
420 ; CHECK-NEXT:    lvl %s16
421 ; CHECK-NEXT:    vor %v0, (0)1, %v1
422 ; CHECK-NEXT:    b.l.t (, %s10)
423   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivuw.vvsvl(<256 x double> %0, i32 %1, <256 x double> %2, i32 128)
424   ret <256 x double> %4
427 ; Function Attrs: nounwind readnone
428 declare <256 x double> @llvm.ve.vl.vdivuw.vvsvl(<256 x double>, i32, <256 x double>, i32)
430 ; Function Attrs: nounwind readnone
431 define fastcc <256 x double> @vdivuw_vvsl_imm(<256 x double> %0) {
432 ; CHECK-LABEL: vdivuw_vvsl_imm:
433 ; CHECK:       # %bb.0:
434 ; CHECK-NEXT:    lea %s0, 256
435 ; CHECK-NEXT:    lvl %s0
436 ; CHECK-NEXT:    vdivu.w %v0, %v0, 8
437 ; CHECK-NEXT:    b.l.t (, %s10)
438   %2 = tail call fast <256 x double> @llvm.ve.vl.vdivuw.vvsl(<256 x double> %0, i32 8, i32 256)
439   ret <256 x double> %2
442 ; Function Attrs: nounwind readnone
443 define fastcc <256 x double> @vdivuw_vvsvl_imm(<256 x double> %0, <256 x double> %1) {
444 ; CHECK-LABEL: vdivuw_vvsvl_imm:
445 ; CHECK:       # %bb.0:
446 ; CHECK-NEXT:    lea %s0, 128
447 ; CHECK-NEXT:    lvl %s0
448 ; CHECK-NEXT:    vdivu.w %v1, %v0, 8
449 ; CHECK-NEXT:    lea %s16, 256
450 ; CHECK-NEXT:    lvl %s16
451 ; CHECK-NEXT:    vor %v0, (0)1, %v1
452 ; CHECK-NEXT:    b.l.t (, %s10)
453   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivuw.vvsvl(<256 x double> %0, i32 8, <256 x double> %1, i32 128)
454   ret <256 x double> %3
457 ; Function Attrs: nounwind readnone
458 define fastcc <256 x double> @vdivuw_vvsmvl(<256 x double> %0, i32 signext %1, <256 x i1> %2, <256 x double> %3) {
459 ; CHECK-LABEL: vdivuw_vvsmvl:
460 ; CHECK:       # %bb.0:
461 ; CHECK-NEXT:    and %s0, %s0, (32)0
462 ; CHECK-NEXT:    lea %s1, 128
463 ; CHECK-NEXT:    lvl %s1
464 ; CHECK-NEXT:    vdivu.w %v1, %v0, %s0, %vm1
465 ; CHECK-NEXT:    lea %s16, 256
466 ; CHECK-NEXT:    lvl %s16
467 ; CHECK-NEXT:    vor %v0, (0)1, %v1
468 ; CHECK-NEXT:    b.l.t (, %s10)
469   %5 = tail call fast <256 x double> @llvm.ve.vl.vdivuw.vvsmvl(<256 x double> %0, i32 %1, <256 x i1> %2, <256 x double> %3, i32 128)
470   ret <256 x double> %5
473 ; Function Attrs: nounwind readnone
474 declare <256 x double> @llvm.ve.vl.vdivuw.vvsmvl(<256 x double>, i32, <256 x i1>, <256 x double>, i32)
476 ; Function Attrs: nounwind readnone
477 define fastcc <256 x double> @vdivuw_vvsmvl_imm(<256 x double> %0, <256 x i1> %1, <256 x double> %2) {
478 ; CHECK-LABEL: vdivuw_vvsmvl_imm:
479 ; CHECK:       # %bb.0:
480 ; CHECK-NEXT:    lea %s0, 128
481 ; CHECK-NEXT:    lvl %s0
482 ; CHECK-NEXT:    vdivu.w %v1, %v0, 8, %vm1
483 ; CHECK-NEXT:    lea %s16, 256
484 ; CHECK-NEXT:    lvl %s16
485 ; CHECK-NEXT:    vor %v0, (0)1, %v1
486 ; CHECK-NEXT:    b.l.t (, %s10)
487   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivuw.vvsmvl(<256 x double> %0, i32 8, <256 x i1> %1, <256 x double> %2, i32 128)
488   ret <256 x double> %4
491 ; Function Attrs: nounwind readnone
492 define fastcc <256 x double> @vdivswsx_vvvl(<256 x double> %0, <256 x double> %1) {
493 ; CHECK-LABEL: vdivswsx_vvvl:
494 ; CHECK:       # %bb.0:
495 ; CHECK-NEXT:    lea %s0, 256
496 ; CHECK-NEXT:    lvl %s0
497 ; CHECK-NEXT:    vdivs.w.sx %v0, %v0, %v1
498 ; CHECK-NEXT:    b.l.t (, %s10)
499   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivswsx.vvvl(<256 x double> %0, <256 x double> %1, i32 256)
500   ret <256 x double> %3
503 ; Function Attrs: nounwind readnone
504 declare <256 x double> @llvm.ve.vl.vdivswsx.vvvl(<256 x double>, <256 x double>, i32)
506 ; Function Attrs: nounwind readnone
507 define fastcc <256 x double> @vdivswsx_vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2) {
508 ; CHECK-LABEL: vdivswsx_vvvvl:
509 ; CHECK:       # %bb.0:
510 ; CHECK-NEXT:    lea %s0, 128
511 ; CHECK-NEXT:    lvl %s0
512 ; CHECK-NEXT:    vdivs.w.sx %v2, %v0, %v1
513 ; CHECK-NEXT:    lea %s16, 256
514 ; CHECK-NEXT:    lvl %s16
515 ; CHECK-NEXT:    vor %v0, (0)1, %v2
516 ; CHECK-NEXT:    b.l.t (, %s10)
517   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivswsx.vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, i32 128)
518   ret <256 x double> %4
521 ; Function Attrs: nounwind readnone
522 declare <256 x double> @llvm.ve.vl.vdivswsx.vvvvl(<256 x double>, <256 x double>, <256 x double>, i32)
524 ; Function Attrs: nounwind readnone
525 define fastcc <256 x double> @vdivswsx_vsvl(i32 signext %0, <256 x double> %1) {
526 ; CHECK-LABEL: vdivswsx_vsvl:
527 ; CHECK:       # %bb.0:
528 ; CHECK-NEXT:    and %s0, %s0, (32)0
529 ; CHECK-NEXT:    lea %s1, 256
530 ; CHECK-NEXT:    lvl %s1
531 ; CHECK-NEXT:    vdivs.w.sx %v0, %s0, %v0
532 ; CHECK-NEXT:    b.l.t (, %s10)
533   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivswsx.vsvl(i32 %0, <256 x double> %1, i32 256)
534   ret <256 x double> %3
537 ; Function Attrs: nounwind readnone
538 declare <256 x double> @llvm.ve.vl.vdivswsx.vsvl(i32, <256 x double>, i32)
540 ; Function Attrs: nounwind readnone
541 define fastcc <256 x double> @vdivswsx_vsvvl(i32 signext %0, <256 x double> %1, <256 x double> %2) {
542 ; CHECK-LABEL: vdivswsx_vsvvl:
543 ; CHECK:       # %bb.0:
544 ; CHECK-NEXT:    and %s0, %s0, (32)0
545 ; CHECK-NEXT:    lea %s1, 128
546 ; CHECK-NEXT:    lvl %s1
547 ; CHECK-NEXT:    vdivs.w.sx %v1, %s0, %v0
548 ; CHECK-NEXT:    lea %s16, 256
549 ; CHECK-NEXT:    lvl %s16
550 ; CHECK-NEXT:    vor %v0, (0)1, %v1
551 ; CHECK-NEXT:    b.l.t (, %s10)
552   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivswsx.vsvvl(i32 %0, <256 x double> %1, <256 x double> %2, i32 128)
553   ret <256 x double> %4
556 ; Function Attrs: nounwind readnone
557 declare <256 x double> @llvm.ve.vl.vdivswsx.vsvvl(i32, <256 x double>, <256 x double>, i32)
559 ; Function Attrs: nounwind readnone
560 define fastcc <256 x double> @vdivswsx_vsvl_imm(<256 x double> %0) {
561 ; CHECK-LABEL: vdivswsx_vsvl_imm:
562 ; CHECK:       # %bb.0:
563 ; CHECK-NEXT:    lea %s0, 256
564 ; CHECK-NEXT:    lvl %s0
565 ; CHECK-NEXT:    vdivs.w.sx %v0, 8, %v0
566 ; CHECK-NEXT:    b.l.t (, %s10)
567   %2 = tail call fast <256 x double> @llvm.ve.vl.vdivswsx.vsvl(i32 8, <256 x double> %0, i32 256)
568   ret <256 x double> %2
571 ; Function Attrs: nounwind readnone
572 define fastcc <256 x double> @vdivswsx_vsvvl_imm(<256 x double> %0, <256 x double> %1) {
573 ; CHECK-LABEL: vdivswsx_vsvvl_imm:
574 ; CHECK:       # %bb.0:
575 ; CHECK-NEXT:    lea %s0, 128
576 ; CHECK-NEXT:    lvl %s0
577 ; CHECK-NEXT:    vdivs.w.sx %v1, 8, %v0
578 ; CHECK-NEXT:    lea %s16, 256
579 ; CHECK-NEXT:    lvl %s16
580 ; CHECK-NEXT:    vor %v0, (0)1, %v1
581 ; CHECK-NEXT:    b.l.t (, %s10)
582   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivswsx.vsvvl(i32 8, <256 x double> %0, <256 x double> %1, i32 128)
583   ret <256 x double> %3
586 ; Function Attrs: nounwind readnone
587 define fastcc <256 x double> @vdivswsx_vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3) {
588 ; CHECK-LABEL: vdivswsx_vvvmvl:
589 ; CHECK:       # %bb.0:
590 ; CHECK-NEXT:    lea %s0, 128
591 ; CHECK-NEXT:    lvl %s0
592 ; CHECK-NEXT:    vdivs.w.sx %v2, %v0, %v1, %vm1
593 ; CHECK-NEXT:    lea %s16, 256
594 ; CHECK-NEXT:    lvl %s16
595 ; CHECK-NEXT:    vor %v0, (0)1, %v2
596 ; CHECK-NEXT:    b.l.t (, %s10)
597   %5 = tail call fast <256 x double> @llvm.ve.vl.vdivswsx.vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3, i32 128)
598   ret <256 x double> %5
601 ; Function Attrs: nounwind readnone
602 declare <256 x double> @llvm.ve.vl.vdivswsx.vvvmvl(<256 x double>, <256 x double>, <256 x i1>, <256 x double>, i32)
604 ; Function Attrs: nounwind readnone
605 define fastcc <256 x double> @vdivswsx_vsvmvl(i32 signext %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3) {
606 ; CHECK-LABEL: vdivswsx_vsvmvl:
607 ; CHECK:       # %bb.0:
608 ; CHECK-NEXT:    and %s0, %s0, (32)0
609 ; CHECK-NEXT:    lea %s1, 128
610 ; CHECK-NEXT:    lvl %s1
611 ; CHECK-NEXT:    vdivs.w.sx %v1, %s0, %v0, %vm1
612 ; CHECK-NEXT:    lea %s16, 256
613 ; CHECK-NEXT:    lvl %s16
614 ; CHECK-NEXT:    vor %v0, (0)1, %v1
615 ; CHECK-NEXT:    b.l.t (, %s10)
616   %5 = tail call fast <256 x double> @llvm.ve.vl.vdivswsx.vsvmvl(i32 %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3, i32 128)
617   ret <256 x double> %5
620 ; Function Attrs: nounwind readnone
621 declare <256 x double> @llvm.ve.vl.vdivswsx.vsvmvl(i32, <256 x double>, <256 x i1>, <256 x double>, i32)
623 ; Function Attrs: nounwind readnone
624 define fastcc <256 x double> @vdivswsx_vsvmvl_imm(<256 x double> %0, <256 x i1> %1, <256 x double> %2) {
625 ; CHECK-LABEL: vdivswsx_vsvmvl_imm:
626 ; CHECK:       # %bb.0:
627 ; CHECK-NEXT:    lea %s0, 128
628 ; CHECK-NEXT:    lvl %s0
629 ; CHECK-NEXT:    vdivs.w.sx %v1, 8, %v0, %vm1
630 ; CHECK-NEXT:    lea %s16, 256
631 ; CHECK-NEXT:    lvl %s16
632 ; CHECK-NEXT:    vor %v0, (0)1, %v1
633 ; CHECK-NEXT:    b.l.t (, %s10)
634   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivswsx.vsvmvl(i32 8, <256 x double> %0, <256 x i1> %1, <256 x double> %2, i32 128)
635   ret <256 x double> %4
638 ; Function Attrs: nounwind readnone
639 define fastcc <256 x double> @vdivswsx_vvsl(<256 x double> %0, i32 signext %1) {
640 ; CHECK-LABEL: vdivswsx_vvsl:
641 ; CHECK:       # %bb.0:
642 ; CHECK-NEXT:    and %s0, %s0, (32)0
643 ; CHECK-NEXT:    lea %s1, 256
644 ; CHECK-NEXT:    lvl %s1
645 ; CHECK-NEXT:    vdivs.w.sx %v0, %v0, %s0
646 ; CHECK-NEXT:    b.l.t (, %s10)
647   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivswsx.vvsl(<256 x double> %0, i32 %1, i32 256)
648   ret <256 x double> %3
651 ; Function Attrs: nounwind readnone
652 declare <256 x double> @llvm.ve.vl.vdivswsx.vvsl(<256 x double>, i32, i32)
654 ; Function Attrs: nounwind readnone
655 define fastcc <256 x double> @vdivswsx_vvsvl(<256 x double> %0, i32 signext %1, <256 x double> %2) {
656 ; CHECK-LABEL: vdivswsx_vvsvl:
657 ; CHECK:       # %bb.0:
658 ; CHECK-NEXT:    and %s0, %s0, (32)0
659 ; CHECK-NEXT:    lea %s1, 128
660 ; CHECK-NEXT:    lvl %s1
661 ; CHECK-NEXT:    vdivs.w.sx %v1, %v0, %s0
662 ; CHECK-NEXT:    lea %s16, 256
663 ; CHECK-NEXT:    lvl %s16
664 ; CHECK-NEXT:    vor %v0, (0)1, %v1
665 ; CHECK-NEXT:    b.l.t (, %s10)
666   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivswsx.vvsvl(<256 x double> %0, i32 %1, <256 x double> %2, i32 128)
667   ret <256 x double> %4
670 ; Function Attrs: nounwind readnone
671 declare <256 x double> @llvm.ve.vl.vdivswsx.vvsvl(<256 x double>, i32, <256 x double>, i32)
673 ; Function Attrs: nounwind readnone
674 define fastcc <256 x double> @vdivswsx_vvsl_imm(<256 x double> %0) {
675 ; CHECK-LABEL: vdivswsx_vvsl_imm:
676 ; CHECK:       # %bb.0:
677 ; CHECK-NEXT:    lea %s0, 256
678 ; CHECK-NEXT:    lvl %s0
679 ; CHECK-NEXT:    vdivs.w.sx %v0, %v0, 8
680 ; CHECK-NEXT:    b.l.t (, %s10)
681   %2 = tail call fast <256 x double> @llvm.ve.vl.vdivswsx.vvsl(<256 x double> %0, i32 8, i32 256)
682   ret <256 x double> %2
685 ; Function Attrs: nounwind readnone
686 define fastcc <256 x double> @vdivswsx_vvsvl_imm(<256 x double> %0, <256 x double> %1) {
687 ; CHECK-LABEL: vdivswsx_vvsvl_imm:
688 ; CHECK:       # %bb.0:
689 ; CHECK-NEXT:    lea %s0, 128
690 ; CHECK-NEXT:    lvl %s0
691 ; CHECK-NEXT:    vdivs.w.sx %v1, %v0, 8
692 ; CHECK-NEXT:    lea %s16, 256
693 ; CHECK-NEXT:    lvl %s16
694 ; CHECK-NEXT:    vor %v0, (0)1, %v1
695 ; CHECK-NEXT:    b.l.t (, %s10)
696   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivswsx.vvsvl(<256 x double> %0, i32 8, <256 x double> %1, i32 128)
697   ret <256 x double> %3
700 ; Function Attrs: nounwind readnone
701 define fastcc <256 x double> @vdivswsx_vvsmvl(<256 x double> %0, i32 signext %1, <256 x i1> %2, <256 x double> %3) {
702 ; CHECK-LABEL: vdivswsx_vvsmvl:
703 ; CHECK:       # %bb.0:
704 ; CHECK-NEXT:    and %s0, %s0, (32)0
705 ; CHECK-NEXT:    lea %s1, 128
706 ; CHECK-NEXT:    lvl %s1
707 ; CHECK-NEXT:    vdivs.w.sx %v1, %v0, %s0, %vm1
708 ; CHECK-NEXT:    lea %s16, 256
709 ; CHECK-NEXT:    lvl %s16
710 ; CHECK-NEXT:    vor %v0, (0)1, %v1
711 ; CHECK-NEXT:    b.l.t (, %s10)
712   %5 = tail call fast <256 x double> @llvm.ve.vl.vdivswsx.vvsmvl(<256 x double> %0, i32 %1, <256 x i1> %2, <256 x double> %3, i32 128)
713   ret <256 x double> %5
716 ; Function Attrs: nounwind readnone
717 declare <256 x double> @llvm.ve.vl.vdivswsx.vvsmvl(<256 x double>, i32, <256 x i1>, <256 x double>, i32)
719 ; Function Attrs: nounwind readnone
720 define fastcc <256 x double> @vdivswsx_vvsmvl_imm(<256 x double> %0, <256 x i1> %1, <256 x double> %2) {
721 ; CHECK-LABEL: vdivswsx_vvsmvl_imm:
722 ; CHECK:       # %bb.0:
723 ; CHECK-NEXT:    lea %s0, 128
724 ; CHECK-NEXT:    lvl %s0
725 ; CHECK-NEXT:    vdivs.w.sx %v1, %v0, 8, %vm1
726 ; CHECK-NEXT:    lea %s16, 256
727 ; CHECK-NEXT:    lvl %s16
728 ; CHECK-NEXT:    vor %v0, (0)1, %v1
729 ; CHECK-NEXT:    b.l.t (, %s10)
730   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivswsx.vvsmvl(<256 x double> %0, i32 8, <256 x i1> %1, <256 x double> %2, i32 128)
731   ret <256 x double> %4
734 ; Function Attrs: nounwind readnone
735 define fastcc <256 x double> @vdivswzx_vvvl(<256 x double> %0, <256 x double> %1) {
736 ; CHECK-LABEL: vdivswzx_vvvl:
737 ; CHECK:       # %bb.0:
738 ; CHECK-NEXT:    lea %s0, 256
739 ; CHECK-NEXT:    lvl %s0
740 ; CHECK-NEXT:    vdivs.w.zx %v0, %v0, %v1
741 ; CHECK-NEXT:    b.l.t (, %s10)
742   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivswzx.vvvl(<256 x double> %0, <256 x double> %1, i32 256)
743   ret <256 x double> %3
746 ; Function Attrs: nounwind readnone
747 declare <256 x double> @llvm.ve.vl.vdivswzx.vvvl(<256 x double>, <256 x double>, i32)
749 ; Function Attrs: nounwind readnone
750 define fastcc <256 x double> @vdivswzx_vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2) {
751 ; CHECK-LABEL: vdivswzx_vvvvl:
752 ; CHECK:       # %bb.0:
753 ; CHECK-NEXT:    lea %s0, 128
754 ; CHECK-NEXT:    lvl %s0
755 ; CHECK-NEXT:    vdivs.w.zx %v2, %v0, %v1
756 ; CHECK-NEXT:    lea %s16, 256
757 ; CHECK-NEXT:    lvl %s16
758 ; CHECK-NEXT:    vor %v0, (0)1, %v2
759 ; CHECK-NEXT:    b.l.t (, %s10)
760   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivswzx.vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, i32 128)
761   ret <256 x double> %4
764 ; Function Attrs: nounwind readnone
765 declare <256 x double> @llvm.ve.vl.vdivswzx.vvvvl(<256 x double>, <256 x double>, <256 x double>, i32)
767 ; Function Attrs: nounwind readnone
768 define fastcc <256 x double> @vdivswzx_vsvl(i32 signext %0, <256 x double> %1) {
769 ; CHECK-LABEL: vdivswzx_vsvl:
770 ; CHECK:       # %bb.0:
771 ; CHECK-NEXT:    and %s0, %s0, (32)0
772 ; CHECK-NEXT:    lea %s1, 256
773 ; CHECK-NEXT:    lvl %s1
774 ; CHECK-NEXT:    vdivs.w.zx %v0, %s0, %v0
775 ; CHECK-NEXT:    b.l.t (, %s10)
776   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivswzx.vsvl(i32 %0, <256 x double> %1, i32 256)
777   ret <256 x double> %3
780 ; Function Attrs: nounwind readnone
781 declare <256 x double> @llvm.ve.vl.vdivswzx.vsvl(i32, <256 x double>, i32)
783 ; Function Attrs: nounwind readnone
784 define fastcc <256 x double> @vdivswzx_vsvvl(i32 signext %0, <256 x double> %1, <256 x double> %2) {
785 ; CHECK-LABEL: vdivswzx_vsvvl:
786 ; CHECK:       # %bb.0:
787 ; CHECK-NEXT:    and %s0, %s0, (32)0
788 ; CHECK-NEXT:    lea %s1, 128
789 ; CHECK-NEXT:    lvl %s1
790 ; CHECK-NEXT:    vdivs.w.zx %v1, %s0, %v0
791 ; CHECK-NEXT:    lea %s16, 256
792 ; CHECK-NEXT:    lvl %s16
793 ; CHECK-NEXT:    vor %v0, (0)1, %v1
794 ; CHECK-NEXT:    b.l.t (, %s10)
795   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivswzx.vsvvl(i32 %0, <256 x double> %1, <256 x double> %2, i32 128)
796   ret <256 x double> %4
799 ; Function Attrs: nounwind readnone
800 declare <256 x double> @llvm.ve.vl.vdivswzx.vsvvl(i32, <256 x double>, <256 x double>, i32)
802 ; Function Attrs: nounwind readnone
803 define fastcc <256 x double> @vdivswzx_vsvl_imm(<256 x double> %0) {
804 ; CHECK-LABEL: vdivswzx_vsvl_imm:
805 ; CHECK:       # %bb.0:
806 ; CHECK-NEXT:    lea %s0, 256
807 ; CHECK-NEXT:    lvl %s0
808 ; CHECK-NEXT:    vdivs.w.zx %v0, 8, %v0
809 ; CHECK-NEXT:    b.l.t (, %s10)
810   %2 = tail call fast <256 x double> @llvm.ve.vl.vdivswzx.vsvl(i32 8, <256 x double> %0, i32 256)
811   ret <256 x double> %2
814 ; Function Attrs: nounwind readnone
815 define fastcc <256 x double> @vdivswzx_vsvvl_imm(<256 x double> %0, <256 x double> %1) {
816 ; CHECK-LABEL: vdivswzx_vsvvl_imm:
817 ; CHECK:       # %bb.0:
818 ; CHECK-NEXT:    lea %s0, 128
819 ; CHECK-NEXT:    lvl %s0
820 ; CHECK-NEXT:    vdivs.w.zx %v1, 8, %v0
821 ; CHECK-NEXT:    lea %s16, 256
822 ; CHECK-NEXT:    lvl %s16
823 ; CHECK-NEXT:    vor %v0, (0)1, %v1
824 ; CHECK-NEXT:    b.l.t (, %s10)
825   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivswzx.vsvvl(i32 8, <256 x double> %0, <256 x double> %1, i32 128)
826   ret <256 x double> %3
829 ; Function Attrs: nounwind readnone
830 define fastcc <256 x double> @vdivswzx_vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3) {
831 ; CHECK-LABEL: vdivswzx_vvvmvl:
832 ; CHECK:       # %bb.0:
833 ; CHECK-NEXT:    lea %s0, 128
834 ; CHECK-NEXT:    lvl %s0
835 ; CHECK-NEXT:    vdivs.w.zx %v2, %v0, %v1, %vm1
836 ; CHECK-NEXT:    lea %s16, 256
837 ; CHECK-NEXT:    lvl %s16
838 ; CHECK-NEXT:    vor %v0, (0)1, %v2
839 ; CHECK-NEXT:    b.l.t (, %s10)
840   %5 = tail call fast <256 x double> @llvm.ve.vl.vdivswzx.vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3, i32 128)
841   ret <256 x double> %5
844 ; Function Attrs: nounwind readnone
845 declare <256 x double> @llvm.ve.vl.vdivswzx.vvvmvl(<256 x double>, <256 x double>, <256 x i1>, <256 x double>, i32)
847 ; Function Attrs: nounwind readnone
848 define fastcc <256 x double> @vdivswzx_vsvmvl(i32 signext %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3) {
849 ; CHECK-LABEL: vdivswzx_vsvmvl:
850 ; CHECK:       # %bb.0:
851 ; CHECK-NEXT:    and %s0, %s0, (32)0
852 ; CHECK-NEXT:    lea %s1, 128
853 ; CHECK-NEXT:    lvl %s1
854 ; CHECK-NEXT:    vdivs.w.zx %v1, %s0, %v0, %vm1
855 ; CHECK-NEXT:    lea %s16, 256
856 ; CHECK-NEXT:    lvl %s16
857 ; CHECK-NEXT:    vor %v0, (0)1, %v1
858 ; CHECK-NEXT:    b.l.t (, %s10)
859   %5 = tail call fast <256 x double> @llvm.ve.vl.vdivswzx.vsvmvl(i32 %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3, i32 128)
860   ret <256 x double> %5
863 ; Function Attrs: nounwind readnone
864 declare <256 x double> @llvm.ve.vl.vdivswzx.vsvmvl(i32, <256 x double>, <256 x i1>, <256 x double>, i32)
866 ; Function Attrs: nounwind readnone
867 define fastcc <256 x double> @vdivswzx_vsvmvl_imm(<256 x double> %0, <256 x i1> %1, <256 x double> %2) {
868 ; CHECK-LABEL: vdivswzx_vsvmvl_imm:
869 ; CHECK:       # %bb.0:
870 ; CHECK-NEXT:    lea %s0, 128
871 ; CHECK-NEXT:    lvl %s0
872 ; CHECK-NEXT:    vdivs.w.zx %v1, 8, %v0, %vm1
873 ; CHECK-NEXT:    lea %s16, 256
874 ; CHECK-NEXT:    lvl %s16
875 ; CHECK-NEXT:    vor %v0, (0)1, %v1
876 ; CHECK-NEXT:    b.l.t (, %s10)
877   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivswzx.vsvmvl(i32 8, <256 x double> %0, <256 x i1> %1, <256 x double> %2, i32 128)
878   ret <256 x double> %4
881 ; Function Attrs: nounwind readnone
882 define fastcc <256 x double> @vdivswzx_vvsl(<256 x double> %0, i32 signext %1) {
883 ; CHECK-LABEL: vdivswzx_vvsl:
884 ; CHECK:       # %bb.0:
885 ; CHECK-NEXT:    and %s0, %s0, (32)0
886 ; CHECK-NEXT:    lea %s1, 256
887 ; CHECK-NEXT:    lvl %s1
888 ; CHECK-NEXT:    vdivs.w.zx %v0, %v0, %s0
889 ; CHECK-NEXT:    b.l.t (, %s10)
890   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivswzx.vvsl(<256 x double> %0, i32 %1, i32 256)
891   ret <256 x double> %3
894 ; Function Attrs: nounwind readnone
895 declare <256 x double> @llvm.ve.vl.vdivswzx.vvsl(<256 x double>, i32, i32)
897 ; Function Attrs: nounwind readnone
898 define fastcc <256 x double> @vdivswzx_vvsvl(<256 x double> %0, i32 signext %1, <256 x double> %2) {
899 ; CHECK-LABEL: vdivswzx_vvsvl:
900 ; CHECK:       # %bb.0:
901 ; CHECK-NEXT:    and %s0, %s0, (32)0
902 ; CHECK-NEXT:    lea %s1, 128
903 ; CHECK-NEXT:    lvl %s1
904 ; CHECK-NEXT:    vdivs.w.zx %v1, %v0, %s0
905 ; CHECK-NEXT:    lea %s16, 256
906 ; CHECK-NEXT:    lvl %s16
907 ; CHECK-NEXT:    vor %v0, (0)1, %v1
908 ; CHECK-NEXT:    b.l.t (, %s10)
909   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivswzx.vvsvl(<256 x double> %0, i32 %1, <256 x double> %2, i32 128)
910   ret <256 x double> %4
913 ; Function Attrs: nounwind readnone
914 declare <256 x double> @llvm.ve.vl.vdivswzx.vvsvl(<256 x double>, i32, <256 x double>, i32)
916 ; Function Attrs: nounwind readnone
917 define fastcc <256 x double> @vdivswzx_vvsl_imm(<256 x double> %0) {
918 ; CHECK-LABEL: vdivswzx_vvsl_imm:
919 ; CHECK:       # %bb.0:
920 ; CHECK-NEXT:    lea %s0, 256
921 ; CHECK-NEXT:    lvl %s0
922 ; CHECK-NEXT:    vdivs.w.zx %v0, %v0, 8
923 ; CHECK-NEXT:    b.l.t (, %s10)
924   %2 = tail call fast <256 x double> @llvm.ve.vl.vdivswzx.vvsl(<256 x double> %0, i32 8, i32 256)
925   ret <256 x double> %2
928 ; Function Attrs: nounwind readnone
929 define fastcc <256 x double> @vdivswzx_vvsvl_imm(<256 x double> %0, <256 x double> %1) {
930 ; CHECK-LABEL: vdivswzx_vvsvl_imm:
931 ; CHECK:       # %bb.0:
932 ; CHECK-NEXT:    lea %s0, 128
933 ; CHECK-NEXT:    lvl %s0
934 ; CHECK-NEXT:    vdivs.w.zx %v1, %v0, 8
935 ; CHECK-NEXT:    lea %s16, 256
936 ; CHECK-NEXT:    lvl %s16
937 ; CHECK-NEXT:    vor %v0, (0)1, %v1
938 ; CHECK-NEXT:    b.l.t (, %s10)
939   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivswzx.vvsvl(<256 x double> %0, i32 8, <256 x double> %1, i32 128)
940   ret <256 x double> %3
943 ; Function Attrs: nounwind readnone
944 define fastcc <256 x double> @vdivswzx_vvsmvl(<256 x double> %0, i32 signext %1, <256 x i1> %2, <256 x double> %3) {
945 ; CHECK-LABEL: vdivswzx_vvsmvl:
946 ; CHECK:       # %bb.0:
947 ; CHECK-NEXT:    and %s0, %s0, (32)0
948 ; CHECK-NEXT:    lea %s1, 128
949 ; CHECK-NEXT:    lvl %s1
950 ; CHECK-NEXT:    vdivs.w.zx %v1, %v0, %s0, %vm1
951 ; CHECK-NEXT:    lea %s16, 256
952 ; CHECK-NEXT:    lvl %s16
953 ; CHECK-NEXT:    vor %v0, (0)1, %v1
954 ; CHECK-NEXT:    b.l.t (, %s10)
955   %5 = tail call fast <256 x double> @llvm.ve.vl.vdivswzx.vvsmvl(<256 x double> %0, i32 %1, <256 x i1> %2, <256 x double> %3, i32 128)
956   ret <256 x double> %5
959 ; Function Attrs: nounwind readnone
960 declare <256 x double> @llvm.ve.vl.vdivswzx.vvsmvl(<256 x double>, i32, <256 x i1>, <256 x double>, i32)
962 ; Function Attrs: nounwind readnone
963 define fastcc <256 x double> @vdivswzx_vvsmvl_imm(<256 x double> %0, <256 x i1> %1, <256 x double> %2) {
964 ; CHECK-LABEL: vdivswzx_vvsmvl_imm:
965 ; CHECK:       # %bb.0:
966 ; CHECK-NEXT:    lea %s0, 128
967 ; CHECK-NEXT:    lvl %s0
968 ; CHECK-NEXT:    vdivs.w.zx %v1, %v0, 8, %vm1
969 ; CHECK-NEXT:    lea %s16, 256
970 ; CHECK-NEXT:    lvl %s16
971 ; CHECK-NEXT:    vor %v0, (0)1, %v1
972 ; CHECK-NEXT:    b.l.t (, %s10)
973   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivswzx.vvsmvl(<256 x double> %0, i32 8, <256 x i1> %1, <256 x double> %2, i32 128)
974   ret <256 x double> %4
977 ; Function Attrs: nounwind readnone
978 define fastcc <256 x double> @vdivsl_vvvl(<256 x double> %0, <256 x double> %1) {
979 ; CHECK-LABEL: vdivsl_vvvl:
980 ; CHECK:       # %bb.0:
981 ; CHECK-NEXT:    lea %s0, 256
982 ; CHECK-NEXT:    lvl %s0
983 ; CHECK-NEXT:    vdivs.l %v0, %v0, %v1
984 ; CHECK-NEXT:    b.l.t (, %s10)
985   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivsl.vvvl(<256 x double> %0, <256 x double> %1, i32 256)
986   ret <256 x double> %3
989 ; Function Attrs: nounwind readnone
990 declare <256 x double> @llvm.ve.vl.vdivsl.vvvl(<256 x double>, <256 x double>, i32)
992 ; Function Attrs: nounwind readnone
993 define fastcc <256 x double> @vdivsl_vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2) {
994 ; CHECK-LABEL: vdivsl_vvvvl:
995 ; CHECK:       # %bb.0:
996 ; CHECK-NEXT:    lea %s0, 128
997 ; CHECK-NEXT:    lvl %s0
998 ; CHECK-NEXT:    vdivs.l %v2, %v0, %v1
999 ; CHECK-NEXT:    lea %s16, 256
1000 ; CHECK-NEXT:    lvl %s16
1001 ; CHECK-NEXT:    vor %v0, (0)1, %v2
1002 ; CHECK-NEXT:    b.l.t (, %s10)
1003   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivsl.vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, i32 128)
1004   ret <256 x double> %4
1007 ; Function Attrs: nounwind readnone
1008 declare <256 x double> @llvm.ve.vl.vdivsl.vvvvl(<256 x double>, <256 x double>, <256 x double>, i32)
1010 ; Function Attrs: nounwind readnone
1011 define fastcc <256 x double> @vdivsl_vsvl(i64 %0, <256 x double> %1) {
1012 ; CHECK-LABEL: vdivsl_vsvl:
1013 ; CHECK:       # %bb.0:
1014 ; CHECK-NEXT:    lea %s1, 256
1015 ; CHECK-NEXT:    lvl %s1
1016 ; CHECK-NEXT:    vdivs.l %v0, %s0, %v0
1017 ; CHECK-NEXT:    b.l.t (, %s10)
1018   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivsl.vsvl(i64 %0, <256 x double> %1, i32 256)
1019   ret <256 x double> %3
1022 ; Function Attrs: nounwind readnone
1023 declare <256 x double> @llvm.ve.vl.vdivsl.vsvl(i64, <256 x double>, i32)
1025 ; Function Attrs: nounwind readnone
1026 define fastcc <256 x double> @vdivsl_vsvvl(i64 %0, <256 x double> %1, <256 x double> %2) {
1027 ; CHECK-LABEL: vdivsl_vsvvl:
1028 ; CHECK:       # %bb.0:
1029 ; CHECK-NEXT:    lea %s1, 128
1030 ; CHECK-NEXT:    lvl %s1
1031 ; CHECK-NEXT:    vdivs.l %v1, %s0, %v0
1032 ; CHECK-NEXT:    lea %s16, 256
1033 ; CHECK-NEXT:    lvl %s16
1034 ; CHECK-NEXT:    vor %v0, (0)1, %v1
1035 ; CHECK-NEXT:    b.l.t (, %s10)
1036   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivsl.vsvvl(i64 %0, <256 x double> %1, <256 x double> %2, i32 128)
1037   ret <256 x double> %4
1040 ; Function Attrs: nounwind readnone
1041 declare <256 x double> @llvm.ve.vl.vdivsl.vsvvl(i64, <256 x double>, <256 x double>, i32)
1043 ; Function Attrs: nounwind readnone
1044 define fastcc <256 x double> @vdivsl_vsvl_imm(<256 x double> %0) {
1045 ; CHECK-LABEL: vdivsl_vsvl_imm:
1046 ; CHECK:       # %bb.0:
1047 ; CHECK-NEXT:    lea %s0, 256
1048 ; CHECK-NEXT:    lvl %s0
1049 ; CHECK-NEXT:    vdivs.l %v0, 8, %v0
1050 ; CHECK-NEXT:    b.l.t (, %s10)
1051   %2 = tail call fast <256 x double> @llvm.ve.vl.vdivsl.vsvl(i64 8, <256 x double> %0, i32 256)
1052   ret <256 x double> %2
1055 ; Function Attrs: nounwind readnone
1056 define fastcc <256 x double> @vdivsl_vsvvl_imm(<256 x double> %0, <256 x double> %1) {
1057 ; CHECK-LABEL: vdivsl_vsvvl_imm:
1058 ; CHECK:       # %bb.0:
1059 ; CHECK-NEXT:    lea %s0, 128
1060 ; CHECK-NEXT:    lvl %s0
1061 ; CHECK-NEXT:    vdivs.l %v1, 8, %v0
1062 ; CHECK-NEXT:    lea %s16, 256
1063 ; CHECK-NEXT:    lvl %s16
1064 ; CHECK-NEXT:    vor %v0, (0)1, %v1
1065 ; CHECK-NEXT:    b.l.t (, %s10)
1066   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivsl.vsvvl(i64 8, <256 x double> %0, <256 x double> %1, i32 128)
1067   ret <256 x double> %3
1070 ; Function Attrs: nounwind readnone
1071 define fastcc <256 x double> @vdivsl_vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3) {
1072 ; CHECK-LABEL: vdivsl_vvvmvl:
1073 ; CHECK:       # %bb.0:
1074 ; CHECK-NEXT:    lea %s0, 128
1075 ; CHECK-NEXT:    lvl %s0
1076 ; CHECK-NEXT:    vdivs.l %v2, %v0, %v1, %vm1
1077 ; CHECK-NEXT:    lea %s16, 256
1078 ; CHECK-NEXT:    lvl %s16
1079 ; CHECK-NEXT:    vor %v0, (0)1, %v2
1080 ; CHECK-NEXT:    b.l.t (, %s10)
1081   %5 = tail call fast <256 x double> @llvm.ve.vl.vdivsl.vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3, i32 128)
1082   ret <256 x double> %5
1085 ; Function Attrs: nounwind readnone
1086 declare <256 x double> @llvm.ve.vl.vdivsl.vvvmvl(<256 x double>, <256 x double>, <256 x i1>, <256 x double>, i32)
1088 ; Function Attrs: nounwind readnone
1089 define fastcc <256 x double> @vdivsl_vsvmvl(i64 %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3) {
1090 ; CHECK-LABEL: vdivsl_vsvmvl:
1091 ; CHECK:       # %bb.0:
1092 ; CHECK-NEXT:    lea %s1, 128
1093 ; CHECK-NEXT:    lvl %s1
1094 ; CHECK-NEXT:    vdivs.l %v1, %s0, %v0, %vm1
1095 ; CHECK-NEXT:    lea %s16, 256
1096 ; CHECK-NEXT:    lvl %s16
1097 ; CHECK-NEXT:    vor %v0, (0)1, %v1
1098 ; CHECK-NEXT:    b.l.t (, %s10)
1099   %5 = tail call fast <256 x double> @llvm.ve.vl.vdivsl.vsvmvl(i64 %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3, i32 128)
1100   ret <256 x double> %5
1103 ; Function Attrs: nounwind readnone
1104 declare <256 x double> @llvm.ve.vl.vdivsl.vsvmvl(i64, <256 x double>, <256 x i1>, <256 x double>, i32)
1106 ; Function Attrs: nounwind readnone
1107 define fastcc <256 x double> @vdivsl_vsvmvl_imm(<256 x double> %0, <256 x i1> %1, <256 x double> %2) {
1108 ; CHECK-LABEL: vdivsl_vsvmvl_imm:
1109 ; CHECK:       # %bb.0:
1110 ; CHECK-NEXT:    lea %s0, 128
1111 ; CHECK-NEXT:    lvl %s0
1112 ; CHECK-NEXT:    vdivs.l %v1, 8, %v0, %vm1
1113 ; CHECK-NEXT:    lea %s16, 256
1114 ; CHECK-NEXT:    lvl %s16
1115 ; CHECK-NEXT:    vor %v0, (0)1, %v1
1116 ; CHECK-NEXT:    b.l.t (, %s10)
1117   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivsl.vsvmvl(i64 8, <256 x double> %0, <256 x i1> %1, <256 x double> %2, i32 128)
1118   ret <256 x double> %4
1121 ; Function Attrs: nounwind readnone
1122 define fastcc <256 x double> @vdivsl_vvsl(<256 x double> %0, i64 %1) {
1123 ; CHECK-LABEL: vdivsl_vvsl:
1124 ; CHECK:       # %bb.0:
1125 ; CHECK-NEXT:    lea %s1, 256
1126 ; CHECK-NEXT:    lvl %s1
1127 ; CHECK-NEXT:    vdivs.l %v0, %v0, %s0
1128 ; CHECK-NEXT:    b.l.t (, %s10)
1129   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivsl.vvsl(<256 x double> %0, i64 %1, i32 256)
1130   ret <256 x double> %3
1133 ; Function Attrs: nounwind readnone
1134 declare <256 x double> @llvm.ve.vl.vdivsl.vvsl(<256 x double>, i64, i32)
1136 ; Function Attrs: nounwind readnone
1137 define fastcc <256 x double> @vdivsl_vvsvl(<256 x double> %0, i64 %1, <256 x double> %2) {
1138 ; CHECK-LABEL: vdivsl_vvsvl:
1139 ; CHECK:       # %bb.0:
1140 ; CHECK-NEXT:    lea %s1, 128
1141 ; CHECK-NEXT:    lvl %s1
1142 ; CHECK-NEXT:    vdivs.l %v1, %v0, %s0
1143 ; CHECK-NEXT:    lea %s16, 256
1144 ; CHECK-NEXT:    lvl %s16
1145 ; CHECK-NEXT:    vor %v0, (0)1, %v1
1146 ; CHECK-NEXT:    b.l.t (, %s10)
1147   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivsl.vvsvl(<256 x double> %0, i64 %1, <256 x double> %2, i32 128)
1148   ret <256 x double> %4
1151 ; Function Attrs: nounwind readnone
1152 declare <256 x double> @llvm.ve.vl.vdivsl.vvsvl(<256 x double>, i64, <256 x double>, i32)
1154 ; Function Attrs: nounwind readnone
1155 define fastcc <256 x double> @vdivsl_vvsl_imm(<256 x double> %0) {
1156 ; CHECK-LABEL: vdivsl_vvsl_imm:
1157 ; CHECK:       # %bb.0:
1158 ; CHECK-NEXT:    lea %s0, 256
1159 ; CHECK-NEXT:    lvl %s0
1160 ; CHECK-NEXT:    vdivs.l %v0, %v0, 8
1161 ; CHECK-NEXT:    b.l.t (, %s10)
1162   %2 = tail call fast <256 x double> @llvm.ve.vl.vdivsl.vvsl(<256 x double> %0, i64 8, i32 256)
1163   ret <256 x double> %2
1166 ; Function Attrs: nounwind readnone
1167 define fastcc <256 x double> @vdivsl_vvsvl_imm(<256 x double> %0, <256 x double> %1) {
1168 ; CHECK-LABEL: vdivsl_vvsvl_imm:
1169 ; CHECK:       # %bb.0:
1170 ; CHECK-NEXT:    lea %s0, 128
1171 ; CHECK-NEXT:    lvl %s0
1172 ; CHECK-NEXT:    vdivs.l %v1, %v0, 8
1173 ; CHECK-NEXT:    lea %s16, 256
1174 ; CHECK-NEXT:    lvl %s16
1175 ; CHECK-NEXT:    vor %v0, (0)1, %v1
1176 ; CHECK-NEXT:    b.l.t (, %s10)
1177   %3 = tail call fast <256 x double> @llvm.ve.vl.vdivsl.vvsvl(<256 x double> %0, i64 8, <256 x double> %1, i32 128)
1178   ret <256 x double> %3
1181 ; Function Attrs: nounwind readnone
1182 define fastcc <256 x double> @vdivsl_vvsmvl(<256 x double> %0, i64 %1, <256 x i1> %2, <256 x double> %3) {
1183 ; CHECK-LABEL: vdivsl_vvsmvl:
1184 ; CHECK:       # %bb.0:
1185 ; CHECK-NEXT:    lea %s1, 128
1186 ; CHECK-NEXT:    lvl %s1
1187 ; CHECK-NEXT:    vdivs.l %v1, %v0, %s0, %vm1
1188 ; CHECK-NEXT:    lea %s16, 256
1189 ; CHECK-NEXT:    lvl %s16
1190 ; CHECK-NEXT:    vor %v0, (0)1, %v1
1191 ; CHECK-NEXT:    b.l.t (, %s10)
1192   %5 = tail call fast <256 x double> @llvm.ve.vl.vdivsl.vvsmvl(<256 x double> %0, i64 %1, <256 x i1> %2, <256 x double> %3, i32 128)
1193   ret <256 x double> %5
1196 ; Function Attrs: nounwind readnone
1197 declare <256 x double> @llvm.ve.vl.vdivsl.vvsmvl(<256 x double>, i64, <256 x i1>, <256 x double>, i32)
1199 ; Function Attrs: nounwind readnone
1200 define fastcc <256 x double> @vdivsl_vvsmvl_imm(<256 x double> %0, <256 x i1> %1, <256 x double> %2) {
1201 ; CHECK-LABEL: vdivsl_vvsmvl_imm:
1202 ; CHECK:       # %bb.0:
1203 ; CHECK-NEXT:    lea %s0, 128
1204 ; CHECK-NEXT:    lvl %s0
1205 ; CHECK-NEXT:    vdivs.l %v1, %v0, 8, %vm1
1206 ; CHECK-NEXT:    lea %s16, 256
1207 ; CHECK-NEXT:    lvl %s16
1208 ; CHECK-NEXT:    vor %v0, (0)1, %v1
1209 ; CHECK-NEXT:    b.l.t (, %s10)
1210   %4 = tail call fast <256 x double> @llvm.ve.vl.vdivsl.vvsmvl(<256 x double> %0, i64 8, <256 x i1> %1, <256 x double> %2, i32 128)
1211   ret <256 x double> %4