Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / RISCV / rvv / vfncvt-f-x.ll
blob7f2714b2fbfcd53789a693520ad30158f3d60058
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: sed 's/iXLen/i32/g' %s | llc -mtriple=riscv32 -mattr=+v,+zfh,+zvfh \
3 ; RUN:   -verify-machineinstrs -target-abi=ilp32d | FileCheck %s
4 ; RUN: sed 's/iXLen/i64/g' %s | llc -mtriple=riscv64 -mattr=+v,+zfh,+zvfh \
5 ; RUN:   -verify-machineinstrs -target-abi=lp64d | FileCheck %s
7 declare <vscale x 1 x half> @llvm.riscv.vfncvt.f.x.w.nxv1f16.nxv1i32(
8   <vscale x 1 x half>,
9   <vscale x 1 x i32>,
10   iXLen, iXLen);
12 define <vscale x 1 x half> @intrinsic_vfncvt_f.x.w_nxv1f16_nxv1i32(<vscale x 1 x i32> %0, iXLen %1) nounwind {
13 ; CHECK-LABEL: intrinsic_vfncvt_f.x.w_nxv1f16_nxv1i32:
14 ; CHECK:       # %bb.0: # %entry
15 ; CHECK-NEXT:    vsetvli zero, a0, e16, mf4, ta, ma
16 ; CHECK-NEXT:    fsrmi a0, 0
17 ; CHECK-NEXT:    vfncvt.f.x.w v9, v8
18 ; CHECK-NEXT:    fsrm a0
19 ; CHECK-NEXT:    vmv1r.v v8, v9
20 ; CHECK-NEXT:    ret
21 entry:
22   %a = call <vscale x 1 x half> @llvm.riscv.vfncvt.f.x.w.nxv1f16.nxv1i32(
23     <vscale x 1 x half> undef,
24     <vscale x 1 x i32> %0,
25     iXLen 0, iXLen %1)
27   ret <vscale x 1 x half> %a
30 declare <vscale x 1 x half> @llvm.riscv.vfncvt.f.x.w.mask.nxv1f16.nxv1i32(
31   <vscale x 1 x half>,
32   <vscale x 1 x i32>,
33   <vscale x 1 x i1>,
34   iXLen, iXLen, iXLen);
36 define <vscale x 1 x half> @intrinsic_vfncvt_mask_f.x.w_nxv1f16_nxv1i32(<vscale x 1 x half> %0, <vscale x 1 x i32> %1, <vscale x 1 x i1> %2, iXLen %3) nounwind {
37 ; CHECK-LABEL: intrinsic_vfncvt_mask_f.x.w_nxv1f16_nxv1i32:
38 ; CHECK:       # %bb.0: # %entry
39 ; CHECK-NEXT:    vsetvli zero, a0, e16, mf4, ta, mu
40 ; CHECK-NEXT:    fsrmi a0, 0
41 ; CHECK-NEXT:    vfncvt.f.x.w v8, v9, v0.t
42 ; CHECK-NEXT:    fsrm a0
43 ; CHECK-NEXT:    ret
44 entry:
45   %a = call <vscale x 1 x half> @llvm.riscv.vfncvt.f.x.w.mask.nxv1f16.nxv1i32(
46     <vscale x 1 x half> %0,
47     <vscale x 1 x i32> %1,
48     <vscale x 1 x i1> %2,
49     iXLen 0, iXLen %3, iXLen 1)
51   ret <vscale x 1 x half> %a
54 declare <vscale x 2 x half> @llvm.riscv.vfncvt.f.x.w.nxv2f16.nxv2i32(
55   <vscale x 2 x half>,
56   <vscale x 2 x i32>,
57   iXLen, iXLen);
59 define <vscale x 2 x half> @intrinsic_vfncvt_f.x.w_nxv2f16_nxv2i32(<vscale x 2 x i32> %0, iXLen %1) nounwind {
60 ; CHECK-LABEL: intrinsic_vfncvt_f.x.w_nxv2f16_nxv2i32:
61 ; CHECK:       # %bb.0: # %entry
62 ; CHECK-NEXT:    vsetvli zero, a0, e16, mf2, ta, ma
63 ; CHECK-NEXT:    fsrmi a0, 0
64 ; CHECK-NEXT:    vfncvt.f.x.w v9, v8
65 ; CHECK-NEXT:    fsrm a0
66 ; CHECK-NEXT:    vmv1r.v v8, v9
67 ; CHECK-NEXT:    ret
68 entry:
69   %a = call <vscale x 2 x half> @llvm.riscv.vfncvt.f.x.w.nxv2f16.nxv2i32(
70     <vscale x 2 x half> undef,
71     <vscale x 2 x i32> %0,
72     iXLen 0, iXLen %1)
74   ret <vscale x 2 x half> %a
77 declare <vscale x 2 x half> @llvm.riscv.vfncvt.f.x.w.mask.nxv2f16.nxv2i32(
78   <vscale x 2 x half>,
79   <vscale x 2 x i32>,
80   <vscale x 2 x i1>,
81   iXLen, iXLen, iXLen);
83 define <vscale x 2 x half> @intrinsic_vfncvt_mask_f.x.w_nxv2f16_nxv2i32(<vscale x 2 x half> %0, <vscale x 2 x i32> %1, <vscale x 2 x i1> %2, iXLen %3) nounwind {
84 ; CHECK-LABEL: intrinsic_vfncvt_mask_f.x.w_nxv2f16_nxv2i32:
85 ; CHECK:       # %bb.0: # %entry
86 ; CHECK-NEXT:    vsetvli zero, a0, e16, mf2, ta, mu
87 ; CHECK-NEXT:    fsrmi a0, 0
88 ; CHECK-NEXT:    vfncvt.f.x.w v8, v9, v0.t
89 ; CHECK-NEXT:    fsrm a0
90 ; CHECK-NEXT:    ret
91 entry:
92   %a = call <vscale x 2 x half> @llvm.riscv.vfncvt.f.x.w.mask.nxv2f16.nxv2i32(
93     <vscale x 2 x half> %0,
94     <vscale x 2 x i32> %1,
95     <vscale x 2 x i1> %2,
96     iXLen 0, iXLen %3, iXLen 1)
98   ret <vscale x 2 x half> %a
101 declare <vscale x 4 x half> @llvm.riscv.vfncvt.f.x.w.nxv4f16.nxv4i32(
102   <vscale x 4 x half>,
103   <vscale x 4 x i32>,
104   iXLen, iXLen);
106 define <vscale x 4 x half> @intrinsic_vfncvt_f.x.w_nxv4f16_nxv4i32(<vscale x 4 x i32> %0, iXLen %1) nounwind {
107 ; CHECK-LABEL: intrinsic_vfncvt_f.x.w_nxv4f16_nxv4i32:
108 ; CHECK:       # %bb.0: # %entry
109 ; CHECK-NEXT:    vsetvli zero, a0, e16, m1, ta, ma
110 ; CHECK-NEXT:    fsrmi a0, 0
111 ; CHECK-NEXT:    vfncvt.f.x.w v10, v8
112 ; CHECK-NEXT:    fsrm a0
113 ; CHECK-NEXT:    vmv.v.v v8, v10
114 ; CHECK-NEXT:    ret
115 entry:
116   %a = call <vscale x 4 x half> @llvm.riscv.vfncvt.f.x.w.nxv4f16.nxv4i32(
117     <vscale x 4 x half> undef,
118     <vscale x 4 x i32> %0,
119     iXLen 0, iXLen %1)
121   ret <vscale x 4 x half> %a
124 declare <vscale x 4 x half> @llvm.riscv.vfncvt.f.x.w.mask.nxv4f16.nxv4i32(
125   <vscale x 4 x half>,
126   <vscale x 4 x i32>,
127   <vscale x 4 x i1>,
128   iXLen, iXLen, iXLen);
130 define <vscale x 4 x half> @intrinsic_vfncvt_mask_f.x.w_nxv4f16_nxv4i32(<vscale x 4 x half> %0, <vscale x 4 x i32> %1, <vscale x 4 x i1> %2, iXLen %3) nounwind {
131 ; CHECK-LABEL: intrinsic_vfncvt_mask_f.x.w_nxv4f16_nxv4i32:
132 ; CHECK:       # %bb.0: # %entry
133 ; CHECK-NEXT:    vsetvli zero, a0, e16, m1, ta, mu
134 ; CHECK-NEXT:    fsrmi a0, 0
135 ; CHECK-NEXT:    vfncvt.f.x.w v8, v10, v0.t
136 ; CHECK-NEXT:    fsrm a0
137 ; CHECK-NEXT:    ret
138 entry:
139   %a = call <vscale x 4 x half> @llvm.riscv.vfncvt.f.x.w.mask.nxv4f16.nxv4i32(
140     <vscale x 4 x half> %0,
141     <vscale x 4 x i32> %1,
142     <vscale x 4 x i1> %2,
143     iXLen 0, iXLen %3, iXLen 1)
145   ret <vscale x 4 x half> %a
148 declare <vscale x 8 x half> @llvm.riscv.vfncvt.f.x.w.nxv8f16.nxv8i32(
149   <vscale x 8 x half>,
150   <vscale x 8 x i32>,
151   iXLen, iXLen);
153 define <vscale x 8 x half> @intrinsic_vfncvt_f.x.w_nxv8f16_nxv8i32(<vscale x 8 x i32> %0, iXLen %1) nounwind {
154 ; CHECK-LABEL: intrinsic_vfncvt_f.x.w_nxv8f16_nxv8i32:
155 ; CHECK:       # %bb.0: # %entry
156 ; CHECK-NEXT:    vsetvli zero, a0, e16, m2, ta, ma
157 ; CHECK-NEXT:    fsrmi a0, 0
158 ; CHECK-NEXT:    vfncvt.f.x.w v12, v8
159 ; CHECK-NEXT:    fsrm a0
160 ; CHECK-NEXT:    vmv.v.v v8, v12
161 ; CHECK-NEXT:    ret
162 entry:
163   %a = call <vscale x 8 x half> @llvm.riscv.vfncvt.f.x.w.nxv8f16.nxv8i32(
164     <vscale x 8 x half> undef,
165     <vscale x 8 x i32> %0,
166     iXLen 0, iXLen %1)
168   ret <vscale x 8 x half> %a
171 declare <vscale x 8 x half> @llvm.riscv.vfncvt.f.x.w.mask.nxv8f16.nxv8i32(
172   <vscale x 8 x half>,
173   <vscale x 8 x i32>,
174   <vscale x 8 x i1>,
175   iXLen, iXLen, iXLen);
177 define <vscale x 8 x half> @intrinsic_vfncvt_mask_f.x.w_nxv8f16_nxv8i32(<vscale x 8 x half> %0, <vscale x 8 x i32> %1, <vscale x 8 x i1> %2, iXLen %3) nounwind {
178 ; CHECK-LABEL: intrinsic_vfncvt_mask_f.x.w_nxv8f16_nxv8i32:
179 ; CHECK:       # %bb.0: # %entry
180 ; CHECK-NEXT:    vsetvli zero, a0, e16, m2, ta, mu
181 ; CHECK-NEXT:    fsrmi a0, 0
182 ; CHECK-NEXT:    vfncvt.f.x.w v8, v12, v0.t
183 ; CHECK-NEXT:    fsrm a0
184 ; CHECK-NEXT:    ret
185 entry:
186   %a = call <vscale x 8 x half> @llvm.riscv.vfncvt.f.x.w.mask.nxv8f16.nxv8i32(
187     <vscale x 8 x half> %0,
188     <vscale x 8 x i32> %1,
189     <vscale x 8 x i1> %2,
190     iXLen 0, iXLen %3, iXLen 1)
192   ret <vscale x 8 x half> %a
195 declare <vscale x 16 x half> @llvm.riscv.vfncvt.f.x.w.nxv16f16.nxv16i32(
196   <vscale x 16 x half>,
197   <vscale x 16 x i32>,
198   iXLen, iXLen);
200 define <vscale x 16 x half> @intrinsic_vfncvt_f.x.w_nxv16f16_nxv16i32(<vscale x 16 x i32> %0, iXLen %1) nounwind {
201 ; CHECK-LABEL: intrinsic_vfncvt_f.x.w_nxv16f16_nxv16i32:
202 ; CHECK:       # %bb.0: # %entry
203 ; CHECK-NEXT:    vsetvli zero, a0, e16, m4, ta, ma
204 ; CHECK-NEXT:    fsrmi a0, 0
205 ; CHECK-NEXT:    vfncvt.f.x.w v16, v8
206 ; CHECK-NEXT:    fsrm a0
207 ; CHECK-NEXT:    vmv.v.v v8, v16
208 ; CHECK-NEXT:    ret
209 entry:
210   %a = call <vscale x 16 x half> @llvm.riscv.vfncvt.f.x.w.nxv16f16.nxv16i32(
211     <vscale x 16 x half> undef,
212     <vscale x 16 x i32> %0,
213     iXLen 0, iXLen %1)
215   ret <vscale x 16 x half> %a
218 declare <vscale x 16 x half> @llvm.riscv.vfncvt.f.x.w.mask.nxv16f16.nxv16i32(
219   <vscale x 16 x half>,
220   <vscale x 16 x i32>,
221   <vscale x 16 x i1>,
222   iXLen, iXLen, iXLen);
224 define <vscale x 16 x half> @intrinsic_vfncvt_mask_f.x.w_nxv16f16_nxv16i32(<vscale x 16 x half> %0, <vscale x 16 x i32> %1, <vscale x 16 x i1> %2, iXLen %3) nounwind {
225 ; CHECK-LABEL: intrinsic_vfncvt_mask_f.x.w_nxv16f16_nxv16i32:
226 ; CHECK:       # %bb.0: # %entry
227 ; CHECK-NEXT:    vsetvli zero, a0, e16, m4, ta, mu
228 ; CHECK-NEXT:    fsrmi a0, 0
229 ; CHECK-NEXT:    vfncvt.f.x.w v8, v16, v0.t
230 ; CHECK-NEXT:    fsrm a0
231 ; CHECK-NEXT:    ret
232 entry:
233   %a = call <vscale x 16 x half> @llvm.riscv.vfncvt.f.x.w.mask.nxv16f16.nxv16i32(
234     <vscale x 16 x half> %0,
235     <vscale x 16 x i32> %1,
236     <vscale x 16 x i1> %2,
237     iXLen 0, iXLen %3, iXLen 1)
239   ret <vscale x 16 x half> %a
242 declare <vscale x 1 x float> @llvm.riscv.vfncvt.f.x.w.nxv1f32.nxv1i64(
243   <vscale x 1 x float>,
244   <vscale x 1 x i64>,
245   iXLen, iXLen);
247 define <vscale x 1 x float> @intrinsic_vfncvt_f.x.w_nxv1f32_nxv1i64(<vscale x 1 x i64> %0, iXLen %1) nounwind {
248 ; CHECK-LABEL: intrinsic_vfncvt_f.x.w_nxv1f32_nxv1i64:
249 ; CHECK:       # %bb.0: # %entry
250 ; CHECK-NEXT:    vsetvli zero, a0, e32, mf2, ta, ma
251 ; CHECK-NEXT:    fsrmi a0, 0
252 ; CHECK-NEXT:    vfncvt.f.x.w v9, v8
253 ; CHECK-NEXT:    fsrm a0
254 ; CHECK-NEXT:    vmv1r.v v8, v9
255 ; CHECK-NEXT:    ret
256 entry:
257   %a = call <vscale x 1 x float> @llvm.riscv.vfncvt.f.x.w.nxv1f32.nxv1i64(
258     <vscale x 1 x float> undef,
259     <vscale x 1 x i64> %0,
260     iXLen 0, iXLen %1)
262   ret <vscale x 1 x float> %a
265 declare <vscale x 1 x float> @llvm.riscv.vfncvt.f.x.w.mask.nxv1f32.nxv1i64(
266   <vscale x 1 x float>,
267   <vscale x 1 x i64>,
268   <vscale x 1 x i1>,
269   iXLen, iXLen, iXLen);
271 define <vscale x 1 x float> @intrinsic_vfncvt_mask_f.x.w_nxv1f32_nxv1i64(<vscale x 1 x float> %0, <vscale x 1 x i64> %1, <vscale x 1 x i1> %2, iXLen %3) nounwind {
272 ; CHECK-LABEL: intrinsic_vfncvt_mask_f.x.w_nxv1f32_nxv1i64:
273 ; CHECK:       # %bb.0: # %entry
274 ; CHECK-NEXT:    vsetvli zero, a0, e32, mf2, ta, mu
275 ; CHECK-NEXT:    fsrmi a0, 0
276 ; CHECK-NEXT:    vfncvt.f.x.w v8, v9, v0.t
277 ; CHECK-NEXT:    fsrm a0
278 ; CHECK-NEXT:    ret
279 entry:
280   %a = call <vscale x 1 x float> @llvm.riscv.vfncvt.f.x.w.mask.nxv1f32.nxv1i64(
281     <vscale x 1 x float> %0,
282     <vscale x 1 x i64> %1,
283     <vscale x 1 x i1> %2,
284     iXLen 0, iXLen %3, iXLen 1)
286   ret <vscale x 1 x float> %a
289 declare <vscale x 2 x float> @llvm.riscv.vfncvt.f.x.w.nxv2f32.nxv2i64(
290   <vscale x 2 x float>,
291   <vscale x 2 x i64>,
292   iXLen, iXLen);
294 define <vscale x 2 x float> @intrinsic_vfncvt_f.x.w_nxv2f32_nxv2i64(<vscale x 2 x i64> %0, iXLen %1) nounwind {
295 ; CHECK-LABEL: intrinsic_vfncvt_f.x.w_nxv2f32_nxv2i64:
296 ; CHECK:       # %bb.0: # %entry
297 ; CHECK-NEXT:    vsetvli zero, a0, e32, m1, ta, ma
298 ; CHECK-NEXT:    fsrmi a0, 0
299 ; CHECK-NEXT:    vfncvt.f.x.w v10, v8
300 ; CHECK-NEXT:    fsrm a0
301 ; CHECK-NEXT:    vmv.v.v v8, v10
302 ; CHECK-NEXT:    ret
303 entry:
304   %a = call <vscale x 2 x float> @llvm.riscv.vfncvt.f.x.w.nxv2f32.nxv2i64(
305     <vscale x 2 x float> undef,
306     <vscale x 2 x i64> %0,
307     iXLen 0, iXLen %1)
309   ret <vscale x 2 x float> %a
312 declare <vscale x 2 x float> @llvm.riscv.vfncvt.f.x.w.mask.nxv2f32.nxv2i64(
313   <vscale x 2 x float>,
314   <vscale x 2 x i64>,
315   <vscale x 2 x i1>,
316   iXLen, iXLen, iXLen);
318 define <vscale x 2 x float> @intrinsic_vfncvt_mask_f.x.w_nxv2f32_nxv2i64(<vscale x 2 x float> %0, <vscale x 2 x i64> %1, <vscale x 2 x i1> %2, iXLen %3) nounwind {
319 ; CHECK-LABEL: intrinsic_vfncvt_mask_f.x.w_nxv2f32_nxv2i64:
320 ; CHECK:       # %bb.0: # %entry
321 ; CHECK-NEXT:    vsetvli zero, a0, e32, m1, ta, mu
322 ; CHECK-NEXT:    fsrmi a0, 0
323 ; CHECK-NEXT:    vfncvt.f.x.w v8, v10, v0.t
324 ; CHECK-NEXT:    fsrm a0
325 ; CHECK-NEXT:    ret
326 entry:
327   %a = call <vscale x 2 x float> @llvm.riscv.vfncvt.f.x.w.mask.nxv2f32.nxv2i64(
328     <vscale x 2 x float> %0,
329     <vscale x 2 x i64> %1,
330     <vscale x 2 x i1> %2,
331     iXLen 0, iXLen %3, iXLen 1)
333   ret <vscale x 2 x float> %a
336 declare <vscale x 4 x float> @llvm.riscv.vfncvt.f.x.w.nxv4f32.nxv4i64(
337   <vscale x 4 x float>,
338   <vscale x 4 x i64>,
339   iXLen, iXLen);
341 define <vscale x 4 x float> @intrinsic_vfncvt_f.x.w_nxv4f32_nxv4i64(<vscale x 4 x i64> %0, iXLen %1) nounwind {
342 ; CHECK-LABEL: intrinsic_vfncvt_f.x.w_nxv4f32_nxv4i64:
343 ; CHECK:       # %bb.0: # %entry
344 ; CHECK-NEXT:    vsetvli zero, a0, e32, m2, ta, ma
345 ; CHECK-NEXT:    fsrmi a0, 0
346 ; CHECK-NEXT:    vfncvt.f.x.w v12, v8
347 ; CHECK-NEXT:    fsrm a0
348 ; CHECK-NEXT:    vmv.v.v v8, v12
349 ; CHECK-NEXT:    ret
350 entry:
351   %a = call <vscale x 4 x float> @llvm.riscv.vfncvt.f.x.w.nxv4f32.nxv4i64(
352     <vscale x 4 x float> undef,
353     <vscale x 4 x i64> %0,
354     iXLen 0, iXLen %1)
356   ret <vscale x 4 x float> %a
359 declare <vscale x 4 x float> @llvm.riscv.vfncvt.f.x.w.mask.nxv4f32.nxv4i64(
360   <vscale x 4 x float>,
361   <vscale x 4 x i64>,
362   <vscale x 4 x i1>,
363   iXLen, iXLen, iXLen);
365 define <vscale x 4 x float> @intrinsic_vfncvt_mask_f.x.w_nxv4f32_nxv4i64(<vscale x 4 x float> %0, <vscale x 4 x i64> %1, <vscale x 4 x i1> %2, iXLen %3) nounwind {
366 ; CHECK-LABEL: intrinsic_vfncvt_mask_f.x.w_nxv4f32_nxv4i64:
367 ; CHECK:       # %bb.0: # %entry
368 ; CHECK-NEXT:    vsetvli zero, a0, e32, m2, ta, mu
369 ; CHECK-NEXT:    fsrmi a0, 0
370 ; CHECK-NEXT:    vfncvt.f.x.w v8, v12, v0.t
371 ; CHECK-NEXT:    fsrm a0
372 ; CHECK-NEXT:    ret
373 entry:
374   %a = call <vscale x 4 x float> @llvm.riscv.vfncvt.f.x.w.mask.nxv4f32.nxv4i64(
375     <vscale x 4 x float> %0,
376     <vscale x 4 x i64> %1,
377     <vscale x 4 x i1> %2,
378     iXLen 0, iXLen %3, iXLen 1)
380   ret <vscale x 4 x float> %a
383 declare <vscale x 8 x float> @llvm.riscv.vfncvt.f.x.w.nxv8f32.nxv8i64(
384   <vscale x 8 x float>,
385   <vscale x 8 x i64>,
386   iXLen, iXLen);
388 define <vscale x 8 x float> @intrinsic_vfncvt_f.x.w_nxv8f32_nxv8i64(<vscale x 8 x i64> %0, iXLen %1) nounwind {
389 ; CHECK-LABEL: intrinsic_vfncvt_f.x.w_nxv8f32_nxv8i64:
390 ; CHECK:       # %bb.0: # %entry
391 ; CHECK-NEXT:    vsetvli zero, a0, e32, m4, ta, ma
392 ; CHECK-NEXT:    fsrmi a0, 0
393 ; CHECK-NEXT:    vfncvt.f.x.w v16, v8
394 ; CHECK-NEXT:    fsrm a0
395 ; CHECK-NEXT:    vmv.v.v v8, v16
396 ; CHECK-NEXT:    ret
397 entry:
398   %a = call <vscale x 8 x float> @llvm.riscv.vfncvt.f.x.w.nxv8f32.nxv8i64(
399     <vscale x 8 x float> undef,
400     <vscale x 8 x i64> %0,
401     iXLen 0, iXLen %1)
403   ret <vscale x 8 x float> %a
406 declare <vscale x 8 x float> @llvm.riscv.vfncvt.f.x.w.mask.nxv8f32.nxv8i64(
407   <vscale x 8 x float>,
408   <vscale x 8 x i64>,
409   <vscale x 8 x i1>,
410   iXLen, iXLen, iXLen);
412 define <vscale x 8 x float> @intrinsic_vfncvt_mask_f.x.w_nxv8f32_nxv8i64(<vscale x 8 x float> %0, <vscale x 8 x i64> %1, <vscale x 8 x i1> %2, iXLen %3) nounwind {
413 ; CHECK-LABEL: intrinsic_vfncvt_mask_f.x.w_nxv8f32_nxv8i64:
414 ; CHECK:       # %bb.0: # %entry
415 ; CHECK-NEXT:    vsetvli zero, a0, e32, m4, ta, mu
416 ; CHECK-NEXT:    fsrmi a0, 0
417 ; CHECK-NEXT:    vfncvt.f.x.w v8, v16, v0.t
418 ; CHECK-NEXT:    fsrm a0
419 ; CHECK-NEXT:    ret
420 entry:
421   %a = call <vscale x 8 x float> @llvm.riscv.vfncvt.f.x.w.mask.nxv8f32.nxv8i64(
422     <vscale x 8 x float> %0,
423     <vscale x 8 x i64> %1,
424     <vscale x 8 x i1> %2,
425     iXLen 0, iXLen %3, iXLen 1)
427   ret <vscale x 8 x float> %a