Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / VE / VELIntrinsics / vfmsb.ll
blobc5f3ca609fbee2e4953befea2bd6dcec192236c0
1 ; RUN: llc < %s -mtriple=ve -mattr=+vpu | FileCheck %s
3 ;;; Test vector floating fused multiply subtract intrinsic instructions
4 ;;;
5 ;;; Note:
6 ;;;   We test VFMSB*vvvl, VFMSB*vvvl_v, VFMSB*rvvl, VFMSB*rvvl_v, VFMSB*vrvl,
7 ;;;   VFMSB*vrvl_v, VFMSB*vvvml_v, VFMSB*rvvml_v, VFMSB*vrvml_v, PVFMSB*vvvl,
8 ;;;   PVFMSB*vvvl_v, PVFMSB*rvvl, PVFMSB*rvvl_v, PVFMSB*vrvl, PVFMSB*vrvl_v,
9 ;;;   PVFMSB*vvvml_v, PVFMSB*rvvml_v, and PVFMSB*vrvml_v instructions.
11 ; Function Attrs: nounwind readnone
12 define fastcc <256 x double> @vfmsbd_vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2) {
13 ; CHECK-LABEL: vfmsbd_vvvvl:
14 ; CHECK:       # %bb.0:
15 ; CHECK-NEXT:    lea %s0, 256
16 ; CHECK-NEXT:    lvl %s0
17 ; CHECK-NEXT:    vfmsb.d %v0, %v0, %v1, %v2
18 ; CHECK-NEXT:    b.l.t (, %s10)
19   %4 = tail call fast <256 x double> @llvm.ve.vl.vfmsbd.vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, i32 256)
20   ret <256 x double> %4
23 ; Function Attrs: nounwind readnone
24 declare <256 x double> @llvm.ve.vl.vfmsbd.vvvvl(<256 x double>, <256 x double>, <256 x double>, i32)
26 ; Function Attrs: nounwind readnone
27 define fastcc <256 x double> @vfmsbd_vvvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, <256 x double> %3) {
28 ; CHECK-LABEL: vfmsbd_vvvvvl:
29 ; CHECK:       # %bb.0:
30 ; CHECK-NEXT:    lea %s0, 128
31 ; CHECK-NEXT:    lvl %s0
32 ; CHECK-NEXT:    vfmsb.d %v3, %v0, %v1, %v2
33 ; CHECK-NEXT:    lea %s16, 256
34 ; CHECK-NEXT:    lvl %s16
35 ; CHECK-NEXT:    vor %v0, (0)1, %v3
36 ; CHECK-NEXT:    b.l.t (, %s10)
37   %5 = tail call fast <256 x double> @llvm.ve.vl.vfmsbd.vvvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, <256 x double> %3, i32 128)
38   ret <256 x double> %5
41 ; Function Attrs: nounwind readnone
42 declare <256 x double> @llvm.ve.vl.vfmsbd.vvvvvl(<256 x double>, <256 x double>, <256 x double>, <256 x double>, i32)
44 ; Function Attrs: nounwind readnone
45 define fastcc <256 x double> @vfmsbd_vsvvl(double %0, <256 x double> %1, <256 x double> %2) {
46 ; CHECK-LABEL: vfmsbd_vsvvl:
47 ; CHECK:       # %bb.0:
48 ; CHECK-NEXT:    lea %s1, 256
49 ; CHECK-NEXT:    lvl %s1
50 ; CHECK-NEXT:    vfmsb.d %v0, %s0, %v0, %v1
51 ; CHECK-NEXT:    b.l.t (, %s10)
52   %4 = tail call fast <256 x double> @llvm.ve.vl.vfmsbd.vsvvl(double %0, <256 x double> %1, <256 x double> %2, i32 256)
53   ret <256 x double> %4
56 ; Function Attrs: nounwind readnone
57 declare <256 x double> @llvm.ve.vl.vfmsbd.vsvvl(double, <256 x double>, <256 x double>, i32)
59 ; Function Attrs: nounwind readnone
60 define fastcc <256 x double> @vfmsbd_vsvvvl(double %0, <256 x double> %1, <256 x double> %2, <256 x double> %3) {
61 ; CHECK-LABEL: vfmsbd_vsvvvl:
62 ; CHECK:       # %bb.0:
63 ; CHECK-NEXT:    lea %s1, 128
64 ; CHECK-NEXT:    lvl %s1
65 ; CHECK-NEXT:    vfmsb.d %v2, %s0, %v0, %v1
66 ; CHECK-NEXT:    lea %s16, 256
67 ; CHECK-NEXT:    lvl %s16
68 ; CHECK-NEXT:    vor %v0, (0)1, %v2
69 ; CHECK-NEXT:    b.l.t (, %s10)
70   %5 = tail call fast <256 x double> @llvm.ve.vl.vfmsbd.vsvvvl(double %0, <256 x double> %1, <256 x double> %2, <256 x double> %3, i32 128)
71   ret <256 x double> %5
74 ; Function Attrs: nounwind readnone
75 declare <256 x double> @llvm.ve.vl.vfmsbd.vsvvvl(double, <256 x double>, <256 x double>, <256 x double>, i32)
77 ; Function Attrs: nounwind readnone
78 define fastcc <256 x double> @vfmsbd_vvsvl(<256 x double> %0, double %1, <256 x double> %2) {
79 ; CHECK-LABEL: vfmsbd_vvsvl:
80 ; CHECK:       # %bb.0:
81 ; CHECK-NEXT:    lea %s1, 256
82 ; CHECK-NEXT:    lvl %s1
83 ; CHECK-NEXT:    vfmsb.d %v0, %v0, %s0, %v1
84 ; CHECK-NEXT:    b.l.t (, %s10)
85   %4 = tail call fast <256 x double> @llvm.ve.vl.vfmsbd.vvsvl(<256 x double> %0, double %1, <256 x double> %2, i32 256)
86   ret <256 x double> %4
89 ; Function Attrs: nounwind readnone
90 declare <256 x double> @llvm.ve.vl.vfmsbd.vvsvl(<256 x double>, double, <256 x double>, i32)
92 ; Function Attrs: nounwind readnone
93 define fastcc <256 x double> @vfmsbd_vvsvvl(<256 x double> %0, double %1, <256 x double> %2, <256 x double> %3) {
94 ; CHECK-LABEL: vfmsbd_vvsvvl:
95 ; CHECK:       # %bb.0:
96 ; CHECK-NEXT:    lea %s1, 128
97 ; CHECK-NEXT:    lvl %s1
98 ; CHECK-NEXT:    vfmsb.d %v2, %v0, %s0, %v1
99 ; CHECK-NEXT:    lea %s16, 256
100 ; CHECK-NEXT:    lvl %s16
101 ; CHECK-NEXT:    vor %v0, (0)1, %v2
102 ; CHECK-NEXT:    b.l.t (, %s10)
103   %5 = tail call fast <256 x double> @llvm.ve.vl.vfmsbd.vvsvvl(<256 x double> %0, double %1, <256 x double> %2, <256 x double> %3, i32 128)
104   ret <256 x double> %5
107 ; Function Attrs: nounwind readnone
108 declare <256 x double> @llvm.ve.vl.vfmsbd.vvsvvl(<256 x double>, double, <256 x double>, <256 x double>, i32)
110 ; Function Attrs: nounwind readnone
111 define fastcc <256 x double> @vfmsbd_vvvvmvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, <256 x i1> %3, <256 x double> %4) {
112 ; CHECK-LABEL: vfmsbd_vvvvmvl:
113 ; CHECK:       # %bb.0:
114 ; CHECK-NEXT:    lea %s0, 128
115 ; CHECK-NEXT:    lvl %s0
116 ; CHECK-NEXT:    vfmsb.d %v3, %v0, %v1, %v2, %vm1
117 ; CHECK-NEXT:    lea %s16, 256
118 ; CHECK-NEXT:    lvl %s16
119 ; CHECK-NEXT:    vor %v0, (0)1, %v3
120 ; CHECK-NEXT:    b.l.t (, %s10)
121   %6 = tail call fast <256 x double> @llvm.ve.vl.vfmsbd.vvvvmvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, <256 x i1> %3, <256 x double> %4, i32 128)
122   ret <256 x double> %6
125 ; Function Attrs: nounwind readnone
126 declare <256 x double> @llvm.ve.vl.vfmsbd.vvvvmvl(<256 x double>, <256 x double>, <256 x double>, <256 x i1>, <256 x double>, i32)
128 ; Function Attrs: nounwind readnone
129 define fastcc <256 x double> @vfmsbd_vsvvmvl(double %0, <256 x double> %1, <256 x double> %2, <256 x i1> %3, <256 x double> %4) {
130 ; CHECK-LABEL: vfmsbd_vsvvmvl:
131 ; CHECK:       # %bb.0:
132 ; CHECK-NEXT:    lea %s1, 128
133 ; CHECK-NEXT:    lvl %s1
134 ; CHECK-NEXT:    vfmsb.d %v2, %s0, %v0, %v1, %vm1
135 ; CHECK-NEXT:    lea %s16, 256
136 ; CHECK-NEXT:    lvl %s16
137 ; CHECK-NEXT:    vor %v0, (0)1, %v2
138 ; CHECK-NEXT:    b.l.t (, %s10)
139   %6 = tail call fast <256 x double> @llvm.ve.vl.vfmsbd.vsvvmvl(double %0, <256 x double> %1, <256 x double> %2, <256 x i1> %3, <256 x double> %4, i32 128)
140   ret <256 x double> %6
143 ; Function Attrs: nounwind readnone
144 declare <256 x double> @llvm.ve.vl.vfmsbd.vsvvmvl(double, <256 x double>, <256 x double>, <256 x i1>, <256 x double>, i32)
146 ; Function Attrs: nounwind readnone
147 define fastcc <256 x double> @vfmsbd_vvsvmvl(<256 x double> %0, double %1, <256 x double> %2, <256 x i1> %3, <256 x double> %4) {
148 ; CHECK-LABEL: vfmsbd_vvsvmvl:
149 ; CHECK:       # %bb.0:
150 ; CHECK-NEXT:    lea %s1, 128
151 ; CHECK-NEXT:    lvl %s1
152 ; CHECK-NEXT:    vfmsb.d %v2, %v0, %s0, %v1, %vm1
153 ; CHECK-NEXT:    lea %s16, 256
154 ; CHECK-NEXT:    lvl %s16
155 ; CHECK-NEXT:    vor %v0, (0)1, %v2
156 ; CHECK-NEXT:    b.l.t (, %s10)
157   %6 = tail call fast <256 x double> @llvm.ve.vl.vfmsbd.vvsvmvl(<256 x double> %0, double %1, <256 x double> %2, <256 x i1> %3, <256 x double> %4, i32 128)
158   ret <256 x double> %6
161 ; Function Attrs: nounwind readnone
162 declare <256 x double> @llvm.ve.vl.vfmsbd.vvsvmvl(<256 x double>, double, <256 x double>, <256 x i1>, <256 x double>, i32)
164 ; Function Attrs: nounwind readnone
165 define fastcc <256 x double> @vfmsbs_vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2) {
166 ; CHECK-LABEL: vfmsbs_vvvvl:
167 ; CHECK:       # %bb.0:
168 ; CHECK-NEXT:    lea %s0, 256
169 ; CHECK-NEXT:    lvl %s0
170 ; CHECK-NEXT:    vfmsb.s %v0, %v0, %v1, %v2
171 ; CHECK-NEXT:    b.l.t (, %s10)
172   %4 = tail call fast <256 x double> @llvm.ve.vl.vfmsbs.vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, i32 256)
173   ret <256 x double> %4
176 ; Function Attrs: nounwind readnone
177 declare <256 x double> @llvm.ve.vl.vfmsbs.vvvvl(<256 x double>, <256 x double>, <256 x double>, i32)
179 ; Function Attrs: nounwind readnone
180 define fastcc <256 x double> @vfmsbs_vvvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, <256 x double> %3) {
181 ; CHECK-LABEL: vfmsbs_vvvvvl:
182 ; CHECK:       # %bb.0:
183 ; CHECK-NEXT:    lea %s0, 128
184 ; CHECK-NEXT:    lvl %s0
185 ; CHECK-NEXT:    vfmsb.s %v3, %v0, %v1, %v2
186 ; CHECK-NEXT:    lea %s16, 256
187 ; CHECK-NEXT:    lvl %s16
188 ; CHECK-NEXT:    vor %v0, (0)1, %v3
189 ; CHECK-NEXT:    b.l.t (, %s10)
190   %5 = tail call fast <256 x double> @llvm.ve.vl.vfmsbs.vvvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, <256 x double> %3, i32 128)
191   ret <256 x double> %5
194 ; Function Attrs: nounwind readnone
195 declare <256 x double> @llvm.ve.vl.vfmsbs.vvvvvl(<256 x double>, <256 x double>, <256 x double>, <256 x double>, i32)
197 ; Function Attrs: nounwind readnone
198 define fastcc <256 x double> @vfmsbs_vsvvl(float %0, <256 x double> %1, <256 x double> %2) {
199 ; CHECK-LABEL: vfmsbs_vsvvl:
200 ; CHECK:       # %bb.0:
201 ; CHECK-NEXT:    lea %s1, 256
202 ; CHECK-NEXT:    lvl %s1
203 ; CHECK-NEXT:    vfmsb.s %v0, %s0, %v0, %v1
204 ; CHECK-NEXT:    b.l.t (, %s10)
205   %4 = tail call fast <256 x double> @llvm.ve.vl.vfmsbs.vsvvl(float %0, <256 x double> %1, <256 x double> %2, i32 256)
206   ret <256 x double> %4
209 ; Function Attrs: nounwind readnone
210 declare <256 x double> @llvm.ve.vl.vfmsbs.vsvvl(float, <256 x double>, <256 x double>, i32)
212 ; Function Attrs: nounwind readnone
213 define fastcc <256 x double> @vfmsbs_vsvvvl(float %0, <256 x double> %1, <256 x double> %2, <256 x double> %3) {
214 ; CHECK-LABEL: vfmsbs_vsvvvl:
215 ; CHECK:       # %bb.0:
216 ; CHECK-NEXT:    lea %s1, 128
217 ; CHECK-NEXT:    lvl %s1
218 ; CHECK-NEXT:    vfmsb.s %v2, %s0, %v0, %v1
219 ; CHECK-NEXT:    lea %s16, 256
220 ; CHECK-NEXT:    lvl %s16
221 ; CHECK-NEXT:    vor %v0, (0)1, %v2
222 ; CHECK-NEXT:    b.l.t (, %s10)
223   %5 = tail call fast <256 x double> @llvm.ve.vl.vfmsbs.vsvvvl(float %0, <256 x double> %1, <256 x double> %2, <256 x double> %3, i32 128)
224   ret <256 x double> %5
227 ; Function Attrs: nounwind readnone
228 declare <256 x double> @llvm.ve.vl.vfmsbs.vsvvvl(float, <256 x double>, <256 x double>, <256 x double>, i32)
230 ; Function Attrs: nounwind readnone
231 define fastcc <256 x double> @vfmsbs_vvsvl(<256 x double> %0, float %1, <256 x double> %2) {
232 ; CHECK-LABEL: vfmsbs_vvsvl:
233 ; CHECK:       # %bb.0:
234 ; CHECK-NEXT:    lea %s1, 256
235 ; CHECK-NEXT:    lvl %s1
236 ; CHECK-NEXT:    vfmsb.s %v0, %v0, %s0, %v1
237 ; CHECK-NEXT:    b.l.t (, %s10)
238   %4 = tail call fast <256 x double> @llvm.ve.vl.vfmsbs.vvsvl(<256 x double> %0, float %1, <256 x double> %2, i32 256)
239   ret <256 x double> %4
242 ; Function Attrs: nounwind readnone
243 declare <256 x double> @llvm.ve.vl.vfmsbs.vvsvl(<256 x double>, float, <256 x double>, i32)
245 ; Function Attrs: nounwind readnone
246 define fastcc <256 x double> @vfmsbs_vvsvvl(<256 x double> %0, float %1, <256 x double> %2, <256 x double> %3) {
247 ; CHECK-LABEL: vfmsbs_vvsvvl:
248 ; CHECK:       # %bb.0:
249 ; CHECK-NEXT:    lea %s1, 128
250 ; CHECK-NEXT:    lvl %s1
251 ; CHECK-NEXT:    vfmsb.s %v2, %v0, %s0, %v1
252 ; CHECK-NEXT:    lea %s16, 256
253 ; CHECK-NEXT:    lvl %s16
254 ; CHECK-NEXT:    vor %v0, (0)1, %v2
255 ; CHECK-NEXT:    b.l.t (, %s10)
256   %5 = tail call fast <256 x double> @llvm.ve.vl.vfmsbs.vvsvvl(<256 x double> %0, float %1, <256 x double> %2, <256 x double> %3, i32 128)
257   ret <256 x double> %5
260 ; Function Attrs: nounwind readnone
261 declare <256 x double> @llvm.ve.vl.vfmsbs.vvsvvl(<256 x double>, float, <256 x double>, <256 x double>, i32)
263 ; Function Attrs: nounwind readnone
264 define fastcc <256 x double> @vfmsbs_vvvvmvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, <256 x i1> %3, <256 x double> %4) {
265 ; CHECK-LABEL: vfmsbs_vvvvmvl:
266 ; CHECK:       # %bb.0:
267 ; CHECK-NEXT:    lea %s0, 128
268 ; CHECK-NEXT:    lvl %s0
269 ; CHECK-NEXT:    vfmsb.s %v3, %v0, %v1, %v2, %vm1
270 ; CHECK-NEXT:    lea %s16, 256
271 ; CHECK-NEXT:    lvl %s16
272 ; CHECK-NEXT:    vor %v0, (0)1, %v3
273 ; CHECK-NEXT:    b.l.t (, %s10)
274   %6 = tail call fast <256 x double> @llvm.ve.vl.vfmsbs.vvvvmvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, <256 x i1> %3, <256 x double> %4, i32 128)
275   ret <256 x double> %6
278 ; Function Attrs: nounwind readnone
279 declare <256 x double> @llvm.ve.vl.vfmsbs.vvvvmvl(<256 x double>, <256 x double>, <256 x double>, <256 x i1>, <256 x double>, i32)
281 ; Function Attrs: nounwind readnone
282 define fastcc <256 x double> @vfmsbs_vsvvmvl(float %0, <256 x double> %1, <256 x double> %2, <256 x i1> %3, <256 x double> %4) {
283 ; CHECK-LABEL: vfmsbs_vsvvmvl:
284 ; CHECK:       # %bb.0:
285 ; CHECK-NEXT:    lea %s1, 128
286 ; CHECK-NEXT:    lvl %s1
287 ; CHECK-NEXT:    vfmsb.s %v2, %s0, %v0, %v1, %vm1
288 ; CHECK-NEXT:    lea %s16, 256
289 ; CHECK-NEXT:    lvl %s16
290 ; CHECK-NEXT:    vor %v0, (0)1, %v2
291 ; CHECK-NEXT:    b.l.t (, %s10)
292   %6 = tail call fast <256 x double> @llvm.ve.vl.vfmsbs.vsvvmvl(float %0, <256 x double> %1, <256 x double> %2, <256 x i1> %3, <256 x double> %4, i32 128)
293   ret <256 x double> %6
296 ; Function Attrs: nounwind readnone
297 declare <256 x double> @llvm.ve.vl.vfmsbs.vsvvmvl(float, <256 x double>, <256 x double>, <256 x i1>, <256 x double>, i32)
299 ; Function Attrs: nounwind readnone
300 define fastcc <256 x double> @vfmsbs_vvsvmvl(<256 x double> %0, float %1, <256 x double> %2, <256 x i1> %3, <256 x double> %4) {
301 ; CHECK-LABEL: vfmsbs_vvsvmvl:
302 ; CHECK:       # %bb.0:
303 ; CHECK-NEXT:    lea %s1, 128
304 ; CHECK-NEXT:    lvl %s1
305 ; CHECK-NEXT:    vfmsb.s %v2, %v0, %s0, %v1, %vm1
306 ; CHECK-NEXT:    lea %s16, 256
307 ; CHECK-NEXT:    lvl %s16
308 ; CHECK-NEXT:    vor %v0, (0)1, %v2
309 ; CHECK-NEXT:    b.l.t (, %s10)
310   %6 = tail call fast <256 x double> @llvm.ve.vl.vfmsbs.vvsvmvl(<256 x double> %0, float %1, <256 x double> %2, <256 x i1> %3, <256 x double> %4, i32 128)
311   ret <256 x double> %6
314 ; Function Attrs: nounwind readnone
315 declare <256 x double> @llvm.ve.vl.vfmsbs.vvsvmvl(<256 x double>, float, <256 x double>, <256 x i1>, <256 x double>, i32)
317 ; Function Attrs: nounwind readnone
318 define fastcc <256 x double> @pvfmsb_vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2) {
319 ; CHECK-LABEL: pvfmsb_vvvvl:
320 ; CHECK:       # %bb.0:
321 ; CHECK-NEXT:    lea %s0, 256
322 ; CHECK-NEXT:    lvl %s0
323 ; CHECK-NEXT:    pvfmsb %v0, %v0, %v1, %v2
324 ; CHECK-NEXT:    b.l.t (, %s10)
325   %4 = tail call fast <256 x double> @llvm.ve.vl.pvfmsb.vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, i32 256)
326   ret <256 x double> %4
329 ; Function Attrs: nounwind readnone
330 declare <256 x double> @llvm.ve.vl.pvfmsb.vvvvl(<256 x double>, <256 x double>, <256 x double>, i32)
332 ; Function Attrs: nounwind readnone
333 define fastcc <256 x double> @pvfmsb_vvvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, <256 x double> %3) {
334 ; CHECK-LABEL: pvfmsb_vvvvvl:
335 ; CHECK:       # %bb.0:
336 ; CHECK-NEXT:    lea %s0, 128
337 ; CHECK-NEXT:    lvl %s0
338 ; CHECK-NEXT:    pvfmsb %v3, %v0, %v1, %v2
339 ; CHECK-NEXT:    lea %s16, 256
340 ; CHECK-NEXT:    lvl %s16
341 ; CHECK-NEXT:    vor %v0, (0)1, %v3
342 ; CHECK-NEXT:    b.l.t (, %s10)
343   %5 = tail call fast <256 x double> @llvm.ve.vl.pvfmsb.vvvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, <256 x double> %3, i32 128)
344   ret <256 x double> %5
347 ; Function Attrs: nounwind readnone
348 declare <256 x double> @llvm.ve.vl.pvfmsb.vvvvvl(<256 x double>, <256 x double>, <256 x double>, <256 x double>, i32)
350 ; Function Attrs: nounwind readnone
351 define fastcc <256 x double> @pvfmsb_vsvvl(i64 %0, <256 x double> %1, <256 x double> %2) {
352 ; CHECK-LABEL: pvfmsb_vsvvl:
353 ; CHECK:       # %bb.0:
354 ; CHECK-NEXT:    lea %s1, 256
355 ; CHECK-NEXT:    lvl %s1
356 ; CHECK-NEXT:    pvfmsb %v0, %s0, %v0, %v1
357 ; CHECK-NEXT:    b.l.t (, %s10)
358   %4 = tail call fast <256 x double> @llvm.ve.vl.pvfmsb.vsvvl(i64 %0, <256 x double> %1, <256 x double> %2, i32 256)
359   ret <256 x double> %4
362 ; Function Attrs: nounwind readnone
363 declare <256 x double> @llvm.ve.vl.pvfmsb.vsvvl(i64, <256 x double>, <256 x double>, i32)
365 ; Function Attrs: nounwind readnone
366 define fastcc <256 x double> @pvfmsb_vsvvvl(i64 %0, <256 x double> %1, <256 x double> %2, <256 x double> %3) {
367 ; CHECK-LABEL: pvfmsb_vsvvvl:
368 ; CHECK:       # %bb.0:
369 ; CHECK-NEXT:    lea %s1, 128
370 ; CHECK-NEXT:    lvl %s1
371 ; CHECK-NEXT:    pvfmsb %v2, %s0, %v0, %v1
372 ; CHECK-NEXT:    lea %s16, 256
373 ; CHECK-NEXT:    lvl %s16
374 ; CHECK-NEXT:    vor %v0, (0)1, %v2
375 ; CHECK-NEXT:    b.l.t (, %s10)
376   %5 = tail call fast <256 x double> @llvm.ve.vl.pvfmsb.vsvvvl(i64 %0, <256 x double> %1, <256 x double> %2, <256 x double> %3, i32 128)
377   ret <256 x double> %5
380 ; Function Attrs: nounwind readnone
381 declare <256 x double> @llvm.ve.vl.pvfmsb.vsvvvl(i64, <256 x double>, <256 x double>, <256 x double>, i32)
383 ; Function Attrs: nounwind readnone
384 define fastcc <256 x double> @pvfmsb_vvsvl(<256 x double> %0, i64 %1, <256 x double> %2) {
385 ; CHECK-LABEL: pvfmsb_vvsvl:
386 ; CHECK:       # %bb.0:
387 ; CHECK-NEXT:    lea %s1, 256
388 ; CHECK-NEXT:    lvl %s1
389 ; CHECK-NEXT:    pvfmsb %v0, %v0, %s0, %v1
390 ; CHECK-NEXT:    b.l.t (, %s10)
391   %4 = tail call fast <256 x double> @llvm.ve.vl.pvfmsb.vvsvl(<256 x double> %0, i64 %1, <256 x double> %2, i32 256)
392   ret <256 x double> %4
395 ; Function Attrs: nounwind readnone
396 declare <256 x double> @llvm.ve.vl.pvfmsb.vvsvl(<256 x double>, i64, <256 x double>, i32)
398 ; Function Attrs: nounwind readnone
399 define fastcc <256 x double> @pvfmsb_vvsvvl(<256 x double> %0, i64 %1, <256 x double> %2, <256 x double> %3) {
400 ; CHECK-LABEL: pvfmsb_vvsvvl:
401 ; CHECK:       # %bb.0:
402 ; CHECK-NEXT:    lea %s1, 128
403 ; CHECK-NEXT:    lvl %s1
404 ; CHECK-NEXT:    pvfmsb %v2, %v0, %s0, %v1
405 ; CHECK-NEXT:    lea %s16, 256
406 ; CHECK-NEXT:    lvl %s16
407 ; CHECK-NEXT:    vor %v0, (0)1, %v2
408 ; CHECK-NEXT:    b.l.t (, %s10)
409   %5 = tail call fast <256 x double> @llvm.ve.vl.pvfmsb.vvsvvl(<256 x double> %0, i64 %1, <256 x double> %2, <256 x double> %3, i32 128)
410   ret <256 x double> %5
413 ; Function Attrs: nounwind readnone
414 declare <256 x double> @llvm.ve.vl.pvfmsb.vvsvvl(<256 x double>, i64, <256 x double>, <256 x double>, i32)
416 ; Function Attrs: nounwind readnone
417 define fastcc <256 x double> @pvfmsb_vvvvMvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, <512 x i1> %3, <256 x double> %4) {
418 ; CHECK-LABEL: pvfmsb_vvvvMvl:
419 ; CHECK:       # %bb.0:
420 ; CHECK-NEXT:    lea %s0, 128
421 ; CHECK-NEXT:    lvl %s0
422 ; CHECK-NEXT:    pvfmsb %v3, %v0, %v1, %v2, %vm2
423 ; CHECK-NEXT:    lea %s16, 256
424 ; CHECK-NEXT:    lvl %s16
425 ; CHECK-NEXT:    vor %v0, (0)1, %v3
426 ; CHECK-NEXT:    b.l.t (, %s10)
427   %6 = tail call fast <256 x double> @llvm.ve.vl.pvfmsb.vvvvMvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, <512 x i1> %3, <256 x double> %4, i32 128)
428   ret <256 x double> %6
431 ; Function Attrs: nounwind readnone
432 declare <256 x double> @llvm.ve.vl.pvfmsb.vvvvMvl(<256 x double>, <256 x double>, <256 x double>, <512 x i1>, <256 x double>, i32)
434 ; Function Attrs: nounwind readnone
435 define fastcc <256 x double> @pvfmsb_vsvvMvl(i64 %0, <256 x double> %1, <256 x double> %2, <512 x i1> %3, <256 x double> %4) {
436 ; CHECK-LABEL: pvfmsb_vsvvMvl:
437 ; CHECK:       # %bb.0:
438 ; CHECK-NEXT:    lea %s1, 128
439 ; CHECK-NEXT:    lvl %s1
440 ; CHECK-NEXT:    pvfmsb %v2, %s0, %v0, %v1, %vm2
441 ; CHECK-NEXT:    lea %s16, 256
442 ; CHECK-NEXT:    lvl %s16
443 ; CHECK-NEXT:    vor %v0, (0)1, %v2
444 ; CHECK-NEXT:    b.l.t (, %s10)
445   %6 = tail call fast <256 x double> @llvm.ve.vl.pvfmsb.vsvvMvl(i64 %0, <256 x double> %1, <256 x double> %2, <512 x i1> %3, <256 x double> %4, i32 128)
446   ret <256 x double> %6
449 ; Function Attrs: nounwind readnone
450 declare <256 x double> @llvm.ve.vl.pvfmsb.vsvvMvl(i64, <256 x double>, <256 x double>, <512 x i1>, <256 x double>, i32)
452 ; Function Attrs: nounwind readnone
453 define fastcc <256 x double> @pvfmsb_vvsvMvl(<256 x double> %0, i64 %1, <256 x double> %2, <512 x i1> %3, <256 x double> %4) {
454 ; CHECK-LABEL: pvfmsb_vvsvMvl:
455 ; CHECK:       # %bb.0:
456 ; CHECK-NEXT:    lea %s1, 128
457 ; CHECK-NEXT:    lvl %s1
458 ; CHECK-NEXT:    pvfmsb %v2, %v0, %s0, %v1, %vm2
459 ; CHECK-NEXT:    lea %s16, 256
460 ; CHECK-NEXT:    lvl %s16
461 ; CHECK-NEXT:    vor %v0, (0)1, %v2
462 ; CHECK-NEXT:    b.l.t (, %s10)
463   %6 = tail call fast <256 x double> @llvm.ve.vl.pvfmsb.vvsvMvl(<256 x double> %0, i64 %1, <256 x double> %2, <512 x i1> %3, <256 x double> %4, i32 128)
464   ret <256 x double> %6
467 ; Function Attrs: nounwind readnone
468 declare <256 x double> @llvm.ve.vl.pvfmsb.vvsvMvl(<256 x double>, i64, <256 x double>, <512 x i1>, <256 x double>, i32)