Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / VE / VELIntrinsics / vmin.ll
blob56286f03c56eec77e16e46db5b9f7bbe5306119a
1 ; RUN: llc < %s -mtriple=ve -mattr=+vpu | FileCheck %s
3 ;;; Test vector compare and select minimum intrinsic instructions
4 ;;;
5 ;;; Note:
6 ;;;   We test VMIN*vvl, VMIN*vvl_v, VMIN*rvl, VMIN*rvl_v, VMIN*ivl, VMIN*ivl_v,
7 ;;;   VMIN*vvml_v, VMIN*rvml_v, VMIN*ivml_v, PVMIN*vvl, PVMIN*vvl_v, PVMIN*rvl,
8 ;;;   PVMIN*rvl_v, PVMIN*vvml_v, and PVMIN*rvml_v instructions.
10 ; Function Attrs: nounwind readnone
11 define fastcc <256 x double> @vminswsx_vvvl(<256 x double> %0, <256 x double> %1) {
12 ; CHECK-LABEL: vminswsx_vvvl:
13 ; CHECK:       # %bb.0:
14 ; CHECK-NEXT:    lea %s0, 256
15 ; CHECK-NEXT:    lvl %s0
16 ; CHECK-NEXT:    vmins.w.sx %v0, %v0, %v1
17 ; CHECK-NEXT:    b.l.t (, %s10)
18   %3 = tail call fast <256 x double> @llvm.ve.vl.vminswsx.vvvl(<256 x double> %0, <256 x double> %1, i32 256)
19   ret <256 x double> %3
22 ; Function Attrs: nounwind readnone
23 declare <256 x double> @llvm.ve.vl.vminswsx.vvvl(<256 x double>, <256 x double>, i32)
25 ; Function Attrs: nounwind readnone
26 define fastcc <256 x double> @vminswsx_vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2) {
27 ; CHECK-LABEL: vminswsx_vvvvl:
28 ; CHECK:       # %bb.0:
29 ; CHECK-NEXT:    lea %s0, 128
30 ; CHECK-NEXT:    lvl %s0
31 ; CHECK-NEXT:    vmins.w.sx %v2, %v0, %v1
32 ; CHECK-NEXT:    lea %s16, 256
33 ; CHECK-NEXT:    lvl %s16
34 ; CHECK-NEXT:    vor %v0, (0)1, %v2
35 ; CHECK-NEXT:    b.l.t (, %s10)
36   %4 = tail call fast <256 x double> @llvm.ve.vl.vminswsx.vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, i32 128)
37   ret <256 x double> %4
40 ; Function Attrs: nounwind readnone
41 declare <256 x double> @llvm.ve.vl.vminswsx.vvvvl(<256 x double>, <256 x double>, <256 x double>, i32)
43 ; Function Attrs: nounwind readnone
44 define fastcc <256 x double> @vminswsx_vsvl(i32 signext %0, <256 x double> %1) {
45 ; CHECK-LABEL: vminswsx_vsvl:
46 ; CHECK:       # %bb.0:
47 ; CHECK-NEXT:    and %s0, %s0, (32)0
48 ; CHECK-NEXT:    lea %s1, 256
49 ; CHECK-NEXT:    lvl %s1
50 ; CHECK-NEXT:    vmins.w.sx %v0, %s0, %v0
51 ; CHECK-NEXT:    b.l.t (, %s10)
52   %3 = tail call fast <256 x double> @llvm.ve.vl.vminswsx.vsvl(i32 %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.vminswsx.vsvl(i32, <256 x double>, i32)
59 ; Function Attrs: nounwind readnone
60 define fastcc <256 x double> @vminswsx_vsvvl(i32 signext %0, <256 x double> %1, <256 x double> %2) {
61 ; CHECK-LABEL: vminswsx_vsvvl:
62 ; CHECK:       # %bb.0:
63 ; CHECK-NEXT:    and %s0, %s0, (32)0
64 ; CHECK-NEXT:    lea %s1, 128
65 ; CHECK-NEXT:    lvl %s1
66 ; CHECK-NEXT:    vmins.w.sx %v1, %s0, %v0
67 ; CHECK-NEXT:    lea %s16, 256
68 ; CHECK-NEXT:    lvl %s16
69 ; CHECK-NEXT:    vor %v0, (0)1, %v1
70 ; CHECK-NEXT:    b.l.t (, %s10)
71   %4 = tail call fast <256 x double> @llvm.ve.vl.vminswsx.vsvvl(i32 %0, <256 x double> %1, <256 x double> %2, i32 128)
72   ret <256 x double> %4
75 ; Function Attrs: nounwind readnone
76 declare <256 x double> @llvm.ve.vl.vminswsx.vsvvl(i32, <256 x double>, <256 x double>, i32)
78 ; Function Attrs: nounwind readnone
79 define fastcc <256 x double> @vminswsx_vsvl_imm(<256 x double> %0) {
80 ; CHECK-LABEL: vminswsx_vsvl_imm:
81 ; CHECK:       # %bb.0:
82 ; CHECK-NEXT:    lea %s0, 256
83 ; CHECK-NEXT:    lvl %s0
84 ; CHECK-NEXT:    vmins.w.sx %v0, 8, %v0
85 ; CHECK-NEXT:    b.l.t (, %s10)
86   %2 = tail call fast <256 x double> @llvm.ve.vl.vminswsx.vsvl(i32 8, <256 x double> %0, i32 256)
87   ret <256 x double> %2
90 ; Function Attrs: nounwind readnone
91 define fastcc <256 x double> @vminswsx_vsvvl_imm(<256 x double> %0, <256 x double> %1) {
92 ; CHECK-LABEL: vminswsx_vsvvl_imm:
93 ; CHECK:       # %bb.0:
94 ; CHECK-NEXT:    lea %s0, 128
95 ; CHECK-NEXT:    lvl %s0
96 ; CHECK-NEXT:    vmins.w.sx %v1, 8, %v0
97 ; CHECK-NEXT:    lea %s16, 256
98 ; CHECK-NEXT:    lvl %s16
99 ; CHECK-NEXT:    vor %v0, (0)1, %v1
100 ; CHECK-NEXT:    b.l.t (, %s10)
101   %3 = tail call fast <256 x double> @llvm.ve.vl.vminswsx.vsvvl(i32 8, <256 x double> %0, <256 x double> %1, i32 128)
102   ret <256 x double> %3
105 ; Function Attrs: nounwind readnone
106 define fastcc <256 x double> @vminswsx_vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3) {
107 ; CHECK-LABEL: vminswsx_vvvmvl:
108 ; CHECK:       # %bb.0:
109 ; CHECK-NEXT:    lea %s0, 128
110 ; CHECK-NEXT:    lvl %s0
111 ; CHECK-NEXT:    vmins.w.sx %v2, %v0, %v1, %vm1
112 ; CHECK-NEXT:    lea %s16, 256
113 ; CHECK-NEXT:    lvl %s16
114 ; CHECK-NEXT:    vor %v0, (0)1, %v2
115 ; CHECK-NEXT:    b.l.t (, %s10)
116   %5 = tail call fast <256 x double> @llvm.ve.vl.vminswsx.vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3, i32 128)
117   ret <256 x double> %5
120 ; Function Attrs: nounwind readnone
121 declare <256 x double> @llvm.ve.vl.vminswsx.vvvmvl(<256 x double>, <256 x double>, <256 x i1>, <256 x double>, i32)
123 ; Function Attrs: nounwind readnone
124 define fastcc <256 x double> @vminswsx_vsvmvl(i32 signext %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3) {
125 ; CHECK-LABEL: vminswsx_vsvmvl:
126 ; CHECK:       # %bb.0:
127 ; CHECK-NEXT:    and %s0, %s0, (32)0
128 ; CHECK-NEXT:    lea %s1, 128
129 ; CHECK-NEXT:    lvl %s1
130 ; CHECK-NEXT:    vmins.w.sx %v1, %s0, %v0, %vm1
131 ; CHECK-NEXT:    lea %s16, 256
132 ; CHECK-NEXT:    lvl %s16
133 ; CHECK-NEXT:    vor %v0, (0)1, %v1
134 ; CHECK-NEXT:    b.l.t (, %s10)
135   %5 = tail call fast <256 x double> @llvm.ve.vl.vminswsx.vsvmvl(i32 %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3, i32 128)
136   ret <256 x double> %5
139 ; Function Attrs: nounwind readnone
140 declare <256 x double> @llvm.ve.vl.vminswsx.vsvmvl(i32, <256 x double>, <256 x i1>, <256 x double>, i32)
142 ; Function Attrs: nounwind readnone
143 define fastcc <256 x double> @vminswsx_vsvmvl_imm(<256 x double> %0, <256 x i1> %1, <256 x double> %2) {
144 ; CHECK-LABEL: vminswsx_vsvmvl_imm:
145 ; CHECK:       # %bb.0:
146 ; CHECK-NEXT:    lea %s0, 128
147 ; CHECK-NEXT:    lvl %s0
148 ; CHECK-NEXT:    vmins.w.sx %v1, 8, %v0, %vm1
149 ; CHECK-NEXT:    lea %s16, 256
150 ; CHECK-NEXT:    lvl %s16
151 ; CHECK-NEXT:    vor %v0, (0)1, %v1
152 ; CHECK-NEXT:    b.l.t (, %s10)
153   %4 = tail call fast <256 x double> @llvm.ve.vl.vminswsx.vsvmvl(i32 8, <256 x double> %0, <256 x i1> %1, <256 x double> %2, i32 128)
154   ret <256 x double> %4
157 ; Function Attrs: nounwind readnone
158 define fastcc <256 x double> @vminswzx_vvvl(<256 x double> %0, <256 x double> %1) {
159 ; CHECK-LABEL: vminswzx_vvvl:
160 ; CHECK:       # %bb.0:
161 ; CHECK-NEXT:    lea %s0, 256
162 ; CHECK-NEXT:    lvl %s0
163 ; CHECK-NEXT:    vmins.w.zx %v0, %v0, %v1
164 ; CHECK-NEXT:    b.l.t (, %s10)
165   %3 = tail call fast <256 x double> @llvm.ve.vl.vminswzx.vvvl(<256 x double> %0, <256 x double> %1, i32 256)
166   ret <256 x double> %3
169 ; Function Attrs: nounwind readnone
170 declare <256 x double> @llvm.ve.vl.vminswzx.vvvl(<256 x double>, <256 x double>, i32)
172 ; Function Attrs: nounwind readnone
173 define fastcc <256 x double> @vminswzx_vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2) {
174 ; CHECK-LABEL: vminswzx_vvvvl:
175 ; CHECK:       # %bb.0:
176 ; CHECK-NEXT:    lea %s0, 128
177 ; CHECK-NEXT:    lvl %s0
178 ; CHECK-NEXT:    vmins.w.zx %v2, %v0, %v1
179 ; CHECK-NEXT:    lea %s16, 256
180 ; CHECK-NEXT:    lvl %s16
181 ; CHECK-NEXT:    vor %v0, (0)1, %v2
182 ; CHECK-NEXT:    b.l.t (, %s10)
183   %4 = tail call fast <256 x double> @llvm.ve.vl.vminswzx.vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, i32 128)
184   ret <256 x double> %4
187 ; Function Attrs: nounwind readnone
188 declare <256 x double> @llvm.ve.vl.vminswzx.vvvvl(<256 x double>, <256 x double>, <256 x double>, i32)
190 ; Function Attrs: nounwind readnone
191 define fastcc <256 x double> @vminswzx_vsvl(i32 signext %0, <256 x double> %1) {
192 ; CHECK-LABEL: vminswzx_vsvl:
193 ; CHECK:       # %bb.0:
194 ; CHECK-NEXT:    and %s0, %s0, (32)0
195 ; CHECK-NEXT:    lea %s1, 256
196 ; CHECK-NEXT:    lvl %s1
197 ; CHECK-NEXT:    vmins.w.zx %v0, %s0, %v0
198 ; CHECK-NEXT:    b.l.t (, %s10)
199   %3 = tail call fast <256 x double> @llvm.ve.vl.vminswzx.vsvl(i32 %0, <256 x double> %1, i32 256)
200   ret <256 x double> %3
203 ; Function Attrs: nounwind readnone
204 declare <256 x double> @llvm.ve.vl.vminswzx.vsvl(i32, <256 x double>, i32)
206 ; Function Attrs: nounwind readnone
207 define fastcc <256 x double> @vminswzx_vsvvl(i32 signext %0, <256 x double> %1, <256 x double> %2) {
208 ; CHECK-LABEL: vminswzx_vsvvl:
209 ; CHECK:       # %bb.0:
210 ; CHECK-NEXT:    and %s0, %s0, (32)0
211 ; CHECK-NEXT:    lea %s1, 128
212 ; CHECK-NEXT:    lvl %s1
213 ; CHECK-NEXT:    vmins.w.zx %v1, %s0, %v0
214 ; CHECK-NEXT:    lea %s16, 256
215 ; CHECK-NEXT:    lvl %s16
216 ; CHECK-NEXT:    vor %v0, (0)1, %v1
217 ; CHECK-NEXT:    b.l.t (, %s10)
218   %4 = tail call fast <256 x double> @llvm.ve.vl.vminswzx.vsvvl(i32 %0, <256 x double> %1, <256 x double> %2, i32 128)
219   ret <256 x double> %4
222 ; Function Attrs: nounwind readnone
223 declare <256 x double> @llvm.ve.vl.vminswzx.vsvvl(i32, <256 x double>, <256 x double>, i32)
225 ; Function Attrs: nounwind readnone
226 define fastcc <256 x double> @vminswzx_vsvl_imm(<256 x double> %0) {
227 ; CHECK-LABEL: vminswzx_vsvl_imm:
228 ; CHECK:       # %bb.0:
229 ; CHECK-NEXT:    lea %s0, 256
230 ; CHECK-NEXT:    lvl %s0
231 ; CHECK-NEXT:    vmins.w.zx %v0, 8, %v0
232 ; CHECK-NEXT:    b.l.t (, %s10)
233   %2 = tail call fast <256 x double> @llvm.ve.vl.vminswzx.vsvl(i32 8, <256 x double> %0, i32 256)
234   ret <256 x double> %2
237 ; Function Attrs: nounwind readnone
238 define fastcc <256 x double> @vminswzx_vsvvl_imm(<256 x double> %0, <256 x double> %1) {
239 ; CHECK-LABEL: vminswzx_vsvvl_imm:
240 ; CHECK:       # %bb.0:
241 ; CHECK-NEXT:    lea %s0, 128
242 ; CHECK-NEXT:    lvl %s0
243 ; CHECK-NEXT:    vmins.w.zx %v1, 8, %v0
244 ; CHECK-NEXT:    lea %s16, 256
245 ; CHECK-NEXT:    lvl %s16
246 ; CHECK-NEXT:    vor %v0, (0)1, %v1
247 ; CHECK-NEXT:    b.l.t (, %s10)
248   %3 = tail call fast <256 x double> @llvm.ve.vl.vminswzx.vsvvl(i32 8, <256 x double> %0, <256 x double> %1, i32 128)
249   ret <256 x double> %3
252 ; Function Attrs: nounwind readnone
253 define fastcc <256 x double> @vminswzx_vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3) {
254 ; CHECK-LABEL: vminswzx_vvvmvl:
255 ; CHECK:       # %bb.0:
256 ; CHECK-NEXT:    lea %s0, 128
257 ; CHECK-NEXT:    lvl %s0
258 ; CHECK-NEXT:    vmins.w.zx %v2, %v0, %v1, %vm1
259 ; CHECK-NEXT:    lea %s16, 256
260 ; CHECK-NEXT:    lvl %s16
261 ; CHECK-NEXT:    vor %v0, (0)1, %v2
262 ; CHECK-NEXT:    b.l.t (, %s10)
263   %5 = tail call fast <256 x double> @llvm.ve.vl.vminswzx.vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3, i32 128)
264   ret <256 x double> %5
267 ; Function Attrs: nounwind readnone
268 declare <256 x double> @llvm.ve.vl.vminswzx.vvvmvl(<256 x double>, <256 x double>, <256 x i1>, <256 x double>, i32)
270 ; Function Attrs: nounwind readnone
271 define fastcc <256 x double> @vminswzx_vsvmvl(i32 signext %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3) {
272 ; CHECK-LABEL: vminswzx_vsvmvl:
273 ; CHECK:       # %bb.0:
274 ; CHECK-NEXT:    and %s0, %s0, (32)0
275 ; CHECK-NEXT:    lea %s1, 128
276 ; CHECK-NEXT:    lvl %s1
277 ; CHECK-NEXT:    vmins.w.zx %v1, %s0, %v0, %vm1
278 ; CHECK-NEXT:    lea %s16, 256
279 ; CHECK-NEXT:    lvl %s16
280 ; CHECK-NEXT:    vor %v0, (0)1, %v1
281 ; CHECK-NEXT:    b.l.t (, %s10)
282   %5 = tail call fast <256 x double> @llvm.ve.vl.vminswzx.vsvmvl(i32 %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3, i32 128)
283   ret <256 x double> %5
286 ; Function Attrs: nounwind readnone
287 declare <256 x double> @llvm.ve.vl.vminswzx.vsvmvl(i32, <256 x double>, <256 x i1>, <256 x double>, i32)
289 ; Function Attrs: nounwind readnone
290 define fastcc <256 x double> @vminswzx_vsvmvl_imm(<256 x double> %0, <256 x i1> %1, <256 x double> %2) {
291 ; CHECK-LABEL: vminswzx_vsvmvl_imm:
292 ; CHECK:       # %bb.0:
293 ; CHECK-NEXT:    lea %s0, 128
294 ; CHECK-NEXT:    lvl %s0
295 ; CHECK-NEXT:    vmins.w.zx %v1, 8, %v0, %vm1
296 ; CHECK-NEXT:    lea %s16, 256
297 ; CHECK-NEXT:    lvl %s16
298 ; CHECK-NEXT:    vor %v0, (0)1, %v1
299 ; CHECK-NEXT:    b.l.t (, %s10)
300   %4 = tail call fast <256 x double> @llvm.ve.vl.vminswzx.vsvmvl(i32 8, <256 x double> %0, <256 x i1> %1, <256 x double> %2, i32 128)
301   ret <256 x double> %4
304 ; Function Attrs: nounwind readnone
305 define fastcc <256 x double> @vminsl_vvvl(<256 x double> %0, <256 x double> %1) {
306 ; CHECK-LABEL: vminsl_vvvl:
307 ; CHECK:       # %bb.0:
308 ; CHECK-NEXT:    lea %s0, 256
309 ; CHECK-NEXT:    lvl %s0
310 ; CHECK-NEXT:    vmins.l %v0, %v0, %v1
311 ; CHECK-NEXT:    b.l.t (, %s10)
312   %3 = tail call fast <256 x double> @llvm.ve.vl.vminsl.vvvl(<256 x double> %0, <256 x double> %1, i32 256)
313   ret <256 x double> %3
316 ; Function Attrs: nounwind readnone
317 declare <256 x double> @llvm.ve.vl.vminsl.vvvl(<256 x double>, <256 x double>, i32)
319 ; Function Attrs: nounwind readnone
320 define fastcc <256 x double> @vminsl_vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2) {
321 ; CHECK-LABEL: vminsl_vvvvl:
322 ; CHECK:       # %bb.0:
323 ; CHECK-NEXT:    lea %s0, 128
324 ; CHECK-NEXT:    lvl %s0
325 ; CHECK-NEXT:    vmins.l %v2, %v0, %v1
326 ; CHECK-NEXT:    lea %s16, 256
327 ; CHECK-NEXT:    lvl %s16
328 ; CHECK-NEXT:    vor %v0, (0)1, %v2
329 ; CHECK-NEXT:    b.l.t (, %s10)
330   %4 = tail call fast <256 x double> @llvm.ve.vl.vminsl.vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, i32 128)
331   ret <256 x double> %4
334 ; Function Attrs: nounwind readnone
335 declare <256 x double> @llvm.ve.vl.vminsl.vvvvl(<256 x double>, <256 x double>, <256 x double>, i32)
337 ; Function Attrs: nounwind readnone
338 define fastcc <256 x double> @vminsl_vsvl(i64 %0, <256 x double> %1) {
339 ; CHECK-LABEL: vminsl_vsvl:
340 ; CHECK:       # %bb.0:
341 ; CHECK-NEXT:    lea %s1, 256
342 ; CHECK-NEXT:    lvl %s1
343 ; CHECK-NEXT:    vmins.l %v0, %s0, %v0
344 ; CHECK-NEXT:    b.l.t (, %s10)
345   %3 = tail call fast <256 x double> @llvm.ve.vl.vminsl.vsvl(i64 %0, <256 x double> %1, i32 256)
346   ret <256 x double> %3
349 ; Function Attrs: nounwind readnone
350 declare <256 x double> @llvm.ve.vl.vminsl.vsvl(i64, <256 x double>, i32)
352 ; Function Attrs: nounwind readnone
353 define fastcc <256 x double> @vminsl_vsvvl(i64 %0, <256 x double> %1, <256 x double> %2) {
354 ; CHECK-LABEL: vminsl_vsvvl:
355 ; CHECK:       # %bb.0:
356 ; CHECK-NEXT:    lea %s1, 128
357 ; CHECK-NEXT:    lvl %s1
358 ; CHECK-NEXT:    vmins.l %v1, %s0, %v0
359 ; CHECK-NEXT:    lea %s16, 256
360 ; CHECK-NEXT:    lvl %s16
361 ; CHECK-NEXT:    vor %v0, (0)1, %v1
362 ; CHECK-NEXT:    b.l.t (, %s10)
363   %4 = tail call fast <256 x double> @llvm.ve.vl.vminsl.vsvvl(i64 %0, <256 x double> %1, <256 x double> %2, i32 128)
364   ret <256 x double> %4
367 ; Function Attrs: nounwind readnone
368 declare <256 x double> @llvm.ve.vl.vminsl.vsvvl(i64, <256 x double>, <256 x double>, i32)
370 ; Function Attrs: nounwind readnone
371 define fastcc <256 x double> @vminsl_vsvl_imm(<256 x double> %0) {
372 ; CHECK-LABEL: vminsl_vsvl_imm:
373 ; CHECK:       # %bb.0:
374 ; CHECK-NEXT:    lea %s0, 256
375 ; CHECK-NEXT:    lvl %s0
376 ; CHECK-NEXT:    vmins.l %v0, 8, %v0
377 ; CHECK-NEXT:    b.l.t (, %s10)
378   %2 = tail call fast <256 x double> @llvm.ve.vl.vminsl.vsvl(i64 8, <256 x double> %0, i32 256)
379   ret <256 x double> %2
382 ; Function Attrs: nounwind readnone
383 define fastcc <256 x double> @vminsl_vsvvl_imm(<256 x double> %0, <256 x double> %1) {
384 ; CHECK-LABEL: vminsl_vsvvl_imm:
385 ; CHECK:       # %bb.0:
386 ; CHECK-NEXT:    lea %s0, 128
387 ; CHECK-NEXT:    lvl %s0
388 ; CHECK-NEXT:    vmins.l %v1, 8, %v0
389 ; CHECK-NEXT:    lea %s16, 256
390 ; CHECK-NEXT:    lvl %s16
391 ; CHECK-NEXT:    vor %v0, (0)1, %v1
392 ; CHECK-NEXT:    b.l.t (, %s10)
393   %3 = tail call fast <256 x double> @llvm.ve.vl.vminsl.vsvvl(i64 8, <256 x double> %0, <256 x double> %1, i32 128)
394   ret <256 x double> %3
397 ; Function Attrs: nounwind readnone
398 define fastcc <256 x double> @vminsl_vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3) {
399 ; CHECK-LABEL: vminsl_vvvmvl:
400 ; CHECK:       # %bb.0:
401 ; CHECK-NEXT:    lea %s0, 128
402 ; CHECK-NEXT:    lvl %s0
403 ; CHECK-NEXT:    vmins.l %v2, %v0, %v1, %vm1
404 ; CHECK-NEXT:    lea %s16, 256
405 ; CHECK-NEXT:    lvl %s16
406 ; CHECK-NEXT:    vor %v0, (0)1, %v2
407 ; CHECK-NEXT:    b.l.t (, %s10)
408   %5 = tail call fast <256 x double> @llvm.ve.vl.vminsl.vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3, i32 128)
409   ret <256 x double> %5
412 ; Function Attrs: nounwind readnone
413 declare <256 x double> @llvm.ve.vl.vminsl.vvvmvl(<256 x double>, <256 x double>, <256 x i1>, <256 x double>, i32)
415 ; Function Attrs: nounwind readnone
416 define fastcc <256 x double> @vminsl_vsvmvl(i64 %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3) {
417 ; CHECK-LABEL: vminsl_vsvmvl:
418 ; CHECK:       # %bb.0:
419 ; CHECK-NEXT:    lea %s1, 128
420 ; CHECK-NEXT:    lvl %s1
421 ; CHECK-NEXT:    vmins.l %v1, %s0, %v0, %vm1
422 ; CHECK-NEXT:    lea %s16, 256
423 ; CHECK-NEXT:    lvl %s16
424 ; CHECK-NEXT:    vor %v0, (0)1, %v1
425 ; CHECK-NEXT:    b.l.t (, %s10)
426   %5 = tail call fast <256 x double> @llvm.ve.vl.vminsl.vsvmvl(i64 %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3, i32 128)
427   ret <256 x double> %5
430 ; Function Attrs: nounwind readnone
431 declare <256 x double> @llvm.ve.vl.vminsl.vsvmvl(i64, <256 x double>, <256 x i1>, <256 x double>, i32)
433 ; Function Attrs: nounwind readnone
434 define fastcc <256 x double> @vminsl_vsvmvl_imm(<256 x double> %0, <256 x i1> %1, <256 x double> %2) {
435 ; CHECK-LABEL: vminsl_vsvmvl_imm:
436 ; CHECK:       # %bb.0:
437 ; CHECK-NEXT:    lea %s0, 128
438 ; CHECK-NEXT:    lvl %s0
439 ; CHECK-NEXT:    vmins.l %v1, 8, %v0, %vm1
440 ; CHECK-NEXT:    lea %s16, 256
441 ; CHECK-NEXT:    lvl %s16
442 ; CHECK-NEXT:    vor %v0, (0)1, %v1
443 ; CHECK-NEXT:    b.l.t (, %s10)
444   %4 = tail call fast <256 x double> @llvm.ve.vl.vminsl.vsvmvl(i64 8, <256 x double> %0, <256 x i1> %1, <256 x double> %2, i32 128)
445   ret <256 x double> %4
448 ; Function Attrs: nounwind readnone
449 define fastcc <256 x double> @pvmins_vvvl(<256 x double> %0, <256 x double> %1) {
450 ; CHECK-LABEL: pvmins_vvvl:
451 ; CHECK:       # %bb.0:
452 ; CHECK-NEXT:    lea %s0, 256
453 ; CHECK-NEXT:    lvl %s0
454 ; CHECK-NEXT:    pvmins %v0, %v0, %v1
455 ; CHECK-NEXT:    b.l.t (, %s10)
456   %3 = tail call fast <256 x double> @llvm.ve.vl.pvmins.vvvl(<256 x double> %0, <256 x double> %1, i32 256)
457   ret <256 x double> %3
460 ; Function Attrs: nounwind readnone
461 declare <256 x double> @llvm.ve.vl.pvmins.vvvl(<256 x double>, <256 x double>, i32)
463 ; Function Attrs: nounwind readnone
464 define fastcc <256 x double> @pvmins_vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2) {
465 ; CHECK-LABEL: pvmins_vvvvl:
466 ; CHECK:       # %bb.0:
467 ; CHECK-NEXT:    lea %s0, 128
468 ; CHECK-NEXT:    lvl %s0
469 ; CHECK-NEXT:    pvmins %v2, %v0, %v1
470 ; CHECK-NEXT:    lea %s16, 256
471 ; CHECK-NEXT:    lvl %s16
472 ; CHECK-NEXT:    vor %v0, (0)1, %v2
473 ; CHECK-NEXT:    b.l.t (, %s10)
474   %4 = tail call fast <256 x double> @llvm.ve.vl.pvmins.vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, i32 128)
475   ret <256 x double> %4
478 ; Function Attrs: nounwind readnone
479 declare <256 x double> @llvm.ve.vl.pvmins.vvvvl(<256 x double>, <256 x double>, <256 x double>, i32)
481 ; Function Attrs: nounwind readnone
482 define fastcc <256 x double> @pvmins_vsvl(i64 %0, <256 x double> %1) {
483 ; CHECK-LABEL: pvmins_vsvl:
484 ; CHECK:       # %bb.0:
485 ; CHECK-NEXT:    lea %s1, 256
486 ; CHECK-NEXT:    lvl %s1
487 ; CHECK-NEXT:    pvmins %v0, %s0, %v0
488 ; CHECK-NEXT:    b.l.t (, %s10)
489   %3 = tail call fast <256 x double> @llvm.ve.vl.pvmins.vsvl(i64 %0, <256 x double> %1, i32 256)
490   ret <256 x double> %3
493 ; Function Attrs: nounwind readnone
494 declare <256 x double> @llvm.ve.vl.pvmins.vsvl(i64, <256 x double>, i32)
496 ; Function Attrs: nounwind readnone
497 define fastcc <256 x double> @pvmins_vsvvl(i64 %0, <256 x double> %1, <256 x double> %2) {
498 ; CHECK-LABEL: pvmins_vsvvl:
499 ; CHECK:       # %bb.0:
500 ; CHECK-NEXT:    lea %s1, 128
501 ; CHECK-NEXT:    lvl %s1
502 ; CHECK-NEXT:    pvmins %v1, %s0, %v0
503 ; CHECK-NEXT:    lea %s16, 256
504 ; CHECK-NEXT:    lvl %s16
505 ; CHECK-NEXT:    vor %v0, (0)1, %v1
506 ; CHECK-NEXT:    b.l.t (, %s10)
507   %4 = tail call fast <256 x double> @llvm.ve.vl.pvmins.vsvvl(i64 %0, <256 x double> %1, <256 x double> %2, i32 128)
508   ret <256 x double> %4
511 ; Function Attrs: nounwind readnone
512 declare <256 x double> @llvm.ve.vl.pvmins.vsvvl(i64, <256 x double>, <256 x double>, i32)
514 ; Function Attrs: nounwind readnone
515 define fastcc <256 x double> @pvmins_vvvMvl(<256 x double> %0, <256 x double> %1, <512 x i1> %2, <256 x double> %3) {
516 ; CHECK-LABEL: pvmins_vvvMvl:
517 ; CHECK:       # %bb.0:
518 ; CHECK-NEXT:    lea %s0, 128
519 ; CHECK-NEXT:    lvl %s0
520 ; CHECK-NEXT:    pvmins %v2, %v0, %v1, %vm2
521 ; CHECK-NEXT:    lea %s16, 256
522 ; CHECK-NEXT:    lvl %s16
523 ; CHECK-NEXT:    vor %v0, (0)1, %v2
524 ; CHECK-NEXT:    b.l.t (, %s10)
525   %5 = tail call fast <256 x double> @llvm.ve.vl.pvmins.vvvMvl(<256 x double> %0, <256 x double> %1, <512 x i1> %2, <256 x double> %3, i32 128)
526   ret <256 x double> %5
529 ; Function Attrs: nounwind readnone
530 declare <256 x double> @llvm.ve.vl.pvmins.vvvMvl(<256 x double>, <256 x double>, <512 x i1>, <256 x double>, i32)
532 ; Function Attrs: nounwind readnone
533 define fastcc <256 x double> @pvmins_vsvMvl(i64 %0, <256 x double> %1, <512 x i1> %2, <256 x double> %3) {
534 ; CHECK-LABEL: pvmins_vsvMvl:
535 ; CHECK:       # %bb.0:
536 ; CHECK-NEXT:    lea %s1, 128
537 ; CHECK-NEXT:    lvl %s1
538 ; CHECK-NEXT:    pvmins %v1, %s0, %v0, %vm2
539 ; CHECK-NEXT:    lea %s16, 256
540 ; CHECK-NEXT:    lvl %s16
541 ; CHECK-NEXT:    vor %v0, (0)1, %v1
542 ; CHECK-NEXT:    b.l.t (, %s10)
543   %5 = tail call fast <256 x double> @llvm.ve.vl.pvmins.vsvMvl(i64 %0, <256 x double> %1, <512 x i1> %2, <256 x double> %3, i32 128)
544   ret <256 x double> %5
547 ; Function Attrs: nounwind readnone
548 declare <256 x double> @llvm.ve.vl.pvmins.vsvMvl(i64, <256 x double>, <512 x i1>, <256 x double>, i32)