[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / CodeGen / RISCV / rvv / vnclip.ll
blob54f4c17dd7ed832b6aaee5eff0eb6662b637d172
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 \
3 ; RUN:   -verify-machineinstrs | FileCheck %s --check-prefixes=CHECK
4 ; RUN: sed 's/iXLen/i64/g' %s | llc -mtriple=riscv64 -mattr=+v \
5 ; RUN:   -verify-machineinstrs | FileCheck %s --check-prefixes=CHECK
7 declare <vscale x 1 x i8> @llvm.riscv.vnclip.nxv1i8.nxv1i16.nxv1i8(
8   <vscale x 1 x i8>,
9   <vscale x 1 x i16>,
10   <vscale x 1 x i8>,
11   iXLen, iXLen);
13 define <vscale x 1 x i8> @intrinsic_vnclip_wv_nxv1i8_nxv1i16_nxv1i8(<vscale x 1 x i16> %0, <vscale x 1 x i8> %1, iXLen %2) nounwind {
14 ; CHECK-LABEL: intrinsic_vnclip_wv_nxv1i8_nxv1i16_nxv1i8:
15 ; CHECK:       # %bb.0: # %entry
16 ; CHECK-NEXT:    vsetvli zero, a0, e8, mf8, ta, ma
17 ; CHECK-NEXT:    csrwi vxrm, 0
18 ; CHECK-NEXT:    vnclip.wv v8, v8, v9
19 ; CHECK-NEXT:    ret
20 entry:
21   %a = call <vscale x 1 x i8> @llvm.riscv.vnclip.nxv1i8.nxv1i16.nxv1i8(
22     <vscale x 1 x i8> undef,
23     <vscale x 1 x i16> %0,
24     <vscale x 1 x i8> %1,
25     iXLen 0, iXLen %2)
27   ret <vscale x 1 x i8> %a
30 declare <vscale x 1 x i8> @llvm.riscv.vnclip.mask.nxv1i8.nxv1i16.nxv1i8(
31   <vscale x 1 x i8>,
32   <vscale x 1 x i16>,
33   <vscale x 1 x i8>,
34   <vscale x 1 x i1>,
35   iXLen, iXLen, iXLen);
37 define <vscale x 1 x i8> @intrinsic_vnclip_mask_wv_nxv1i8_nxv1i16_nxv1i8(<vscale x 1 x i8> %0, <vscale x 1 x i16> %1, <vscale x 1 x i8> %2, <vscale x 1 x i1> %3, iXLen %4) nounwind {
38 ; CHECK-LABEL: intrinsic_vnclip_mask_wv_nxv1i8_nxv1i16_nxv1i8:
39 ; CHECK:       # %bb.0: # %entry
40 ; CHECK-NEXT:    vsetvli zero, a0, e8, mf8, ta, mu
41 ; CHECK-NEXT:    csrwi vxrm, 0
42 ; CHECK-NEXT:    vnclip.wv v8, v9, v10, v0.t
43 ; CHECK-NEXT:    ret
44 entry:
45   %a = call <vscale x 1 x i8> @llvm.riscv.vnclip.mask.nxv1i8.nxv1i16.nxv1i8(
46     <vscale x 1 x i8> %0,
47     <vscale x 1 x i16> %1,
48     <vscale x 1 x i8> %2,
49     <vscale x 1 x i1> %3,
50     iXLen 0, iXLen %4, iXLen 1)
52   ret <vscale x 1 x i8> %a
55 declare <vscale x 2 x i8> @llvm.riscv.vnclip.nxv2i8.nxv2i16.nxv2i8(
56   <vscale x 2 x i8>,
57   <vscale x 2 x i16>,
58   <vscale x 2 x i8>,
59   iXLen, iXLen);
61 define <vscale x 2 x i8> @intrinsic_vnclip_wv_nxv2i8_nxv2i16_nxv2i8(<vscale x 2 x i16> %0, <vscale x 2 x i8> %1, iXLen %2) nounwind {
62 ; CHECK-LABEL: intrinsic_vnclip_wv_nxv2i8_nxv2i16_nxv2i8:
63 ; CHECK:       # %bb.0: # %entry
64 ; CHECK-NEXT:    vsetvli zero, a0, e8, mf4, ta, ma
65 ; CHECK-NEXT:    csrwi vxrm, 0
66 ; CHECK-NEXT:    vnclip.wv v8, v8, v9
67 ; CHECK-NEXT:    ret
68 entry:
69   %a = call <vscale x 2 x i8> @llvm.riscv.vnclip.nxv2i8.nxv2i16.nxv2i8(
70     <vscale x 2 x i8> undef,
71     <vscale x 2 x i16> %0,
72     <vscale x 2 x i8> %1,
73     iXLen 0, iXLen %2)
75   ret <vscale x 2 x i8> %a
78 declare <vscale x 2 x i8> @llvm.riscv.vnclip.mask.nxv2i8.nxv2i16.nxv2i8(
79   <vscale x 2 x i8>,
80   <vscale x 2 x i16>,
81   <vscale x 2 x i8>,
82   <vscale x 2 x i1>,
83   iXLen, iXLen, iXLen);
85 define <vscale x 2 x i8> @intrinsic_vnclip_mask_wv_nxv2i8_nxv2i16_nxv2i8(<vscale x 2 x i8> %0, <vscale x 2 x i16> %1, <vscale x 2 x i8> %2, <vscale x 2 x i1> %3, iXLen %4) nounwind {
86 ; CHECK-LABEL: intrinsic_vnclip_mask_wv_nxv2i8_nxv2i16_nxv2i8:
87 ; CHECK:       # %bb.0: # %entry
88 ; CHECK-NEXT:    vsetvli zero, a0, e8, mf4, ta, mu
89 ; CHECK-NEXT:    csrwi vxrm, 0
90 ; CHECK-NEXT:    vnclip.wv v8, v9, v10, v0.t
91 ; CHECK-NEXT:    ret
92 entry:
93   %a = call <vscale x 2 x i8> @llvm.riscv.vnclip.mask.nxv2i8.nxv2i16.nxv2i8(
94     <vscale x 2 x i8> %0,
95     <vscale x 2 x i16> %1,
96     <vscale x 2 x i8> %2,
97     <vscale x 2 x i1> %3,
98     iXLen 0, iXLen %4, iXLen 1)
100   ret <vscale x 2 x i8> %a
103 declare <vscale x 4 x i8> @llvm.riscv.vnclip.nxv4i8.nxv4i16.nxv4i8(
104   <vscale x 4 x i8>,
105   <vscale x 4 x i16>,
106   <vscale x 4 x i8>,
107   iXLen, iXLen);
109 define <vscale x 4 x i8> @intrinsic_vnclip_wv_nxv4i8_nxv4i16_nxv4i8(<vscale x 4 x i16> %0, <vscale x 4 x i8> %1, iXLen %2) nounwind {
110 ; CHECK-LABEL: intrinsic_vnclip_wv_nxv4i8_nxv4i16_nxv4i8:
111 ; CHECK:       # %bb.0: # %entry
112 ; CHECK-NEXT:    vsetvli zero, a0, e8, mf2, ta, ma
113 ; CHECK-NEXT:    csrwi vxrm, 0
114 ; CHECK-NEXT:    vnclip.wv v8, v8, v9
115 ; CHECK-NEXT:    ret
116 entry:
117   %a = call <vscale x 4 x i8> @llvm.riscv.vnclip.nxv4i8.nxv4i16.nxv4i8(
118     <vscale x 4 x i8> undef,
119     <vscale x 4 x i16> %0,
120     <vscale x 4 x i8> %1,
121     iXLen 0, iXLen %2)
123   ret <vscale x 4 x i8> %a
126 declare <vscale x 4 x i8> @llvm.riscv.vnclip.mask.nxv4i8.nxv4i16.nxv4i8(
127   <vscale x 4 x i8>,
128   <vscale x 4 x i16>,
129   <vscale x 4 x i8>,
130   <vscale x 4 x i1>,
131   iXLen, iXLen, iXLen);
133 define <vscale x 4 x i8> @intrinsic_vnclip_mask_wv_nxv4i8_nxv4i16_nxv4i8(<vscale x 4 x i8> %0, <vscale x 4 x i16> %1, <vscale x 4 x i8> %2, <vscale x 4 x i1> %3, iXLen %4) nounwind {
134 ; CHECK-LABEL: intrinsic_vnclip_mask_wv_nxv4i8_nxv4i16_nxv4i8:
135 ; CHECK:       # %bb.0: # %entry
136 ; CHECK-NEXT:    vsetvli zero, a0, e8, mf2, ta, mu
137 ; CHECK-NEXT:    csrwi vxrm, 0
138 ; CHECK-NEXT:    vnclip.wv v8, v9, v10, v0.t
139 ; CHECK-NEXT:    ret
140 entry:
141   %a = call <vscale x 4 x i8> @llvm.riscv.vnclip.mask.nxv4i8.nxv4i16.nxv4i8(
142     <vscale x 4 x i8> %0,
143     <vscale x 4 x i16> %1,
144     <vscale x 4 x i8> %2,
145     <vscale x 4 x i1> %3,
146     iXLen 0, iXLen %4, iXLen 1)
148   ret <vscale x 4 x i8> %a
151 declare <vscale x 8 x i8> @llvm.riscv.vnclip.nxv8i8.nxv8i16.nxv8i8(
152   <vscale x 8 x i8>,
153   <vscale x 8 x i16>,
154   <vscale x 8 x i8>,
155   iXLen, iXLen);
157 define <vscale x 8 x i8> @intrinsic_vnclip_wv_nxv8i8_nxv8i16_nxv8i8(<vscale x 8 x i16> %0, <vscale x 8 x i8> %1, iXLen %2) nounwind {
158 ; CHECK-LABEL: intrinsic_vnclip_wv_nxv8i8_nxv8i16_nxv8i8:
159 ; CHECK:       # %bb.0: # %entry
160 ; CHECK-NEXT:    vsetvli zero, a0, e8, m1, ta, ma
161 ; CHECK-NEXT:    csrwi vxrm, 0
162 ; CHECK-NEXT:    vnclip.wv v11, v8, v10
163 ; CHECK-NEXT:    vmv.v.v v8, v11
164 ; CHECK-NEXT:    ret
165 entry:
166   %a = call <vscale x 8 x i8> @llvm.riscv.vnclip.nxv8i8.nxv8i16.nxv8i8(
167     <vscale x 8 x i8> undef,
168     <vscale x 8 x i16> %0,
169     <vscale x 8 x i8> %1,
170     iXLen 0, iXLen %2)
172   ret <vscale x 8 x i8> %a
175 declare <vscale x 8 x i8> @llvm.riscv.vnclip.mask.nxv8i8.nxv8i16.nxv8i8(
176   <vscale x 8 x i8>,
177   <vscale x 8 x i16>,
178   <vscale x 8 x i8>,
179   <vscale x 8 x i1>,
180   iXLen, iXLen, iXLen);
182 define <vscale x 8 x i8> @intrinsic_vnclip_mask_wv_nxv8i8_nxv8i16_nxv8i8(<vscale x 8 x i8> %0, <vscale x 8 x i16> %1, <vscale x 8 x i8> %2, <vscale x 8 x i1> %3, iXLen %4) nounwind {
183 ; CHECK-LABEL: intrinsic_vnclip_mask_wv_nxv8i8_nxv8i16_nxv8i8:
184 ; CHECK:       # %bb.0: # %entry
185 ; CHECK-NEXT:    vsetvli zero, a0, e8, m1, ta, mu
186 ; CHECK-NEXT:    csrwi vxrm, 0
187 ; CHECK-NEXT:    vnclip.wv v8, v10, v9, v0.t
188 ; CHECK-NEXT:    ret
189 entry:
190   %a = call <vscale x 8 x i8> @llvm.riscv.vnclip.mask.nxv8i8.nxv8i16.nxv8i8(
191     <vscale x 8 x i8> %0,
192     <vscale x 8 x i16> %1,
193     <vscale x 8 x i8> %2,
194     <vscale x 8 x i1> %3,
195     iXLen 0, iXLen %4, iXLen 1)
197   ret <vscale x 8 x i8> %a
200 declare <vscale x 16 x i8> @llvm.riscv.vnclip.nxv16i8.nxv16i16.nxv16i8(
201   <vscale x 16 x i8>,
202   <vscale x 16 x i16>,
203   <vscale x 16 x i8>,
204   iXLen, iXLen);
206 define <vscale x 16 x i8> @intrinsic_vnclip_wv_nxv16i8_nxv16i16_nxv16i8(<vscale x 16 x i16> %0, <vscale x 16 x i8> %1, iXLen %2) nounwind {
207 ; CHECK-LABEL: intrinsic_vnclip_wv_nxv16i8_nxv16i16_nxv16i8:
208 ; CHECK:       # %bb.0: # %entry
209 ; CHECK-NEXT:    vsetvli zero, a0, e8, m2, ta, ma
210 ; CHECK-NEXT:    csrwi vxrm, 0
211 ; CHECK-NEXT:    vnclip.wv v14, v8, v12
212 ; CHECK-NEXT:    vmv.v.v v8, v14
213 ; CHECK-NEXT:    ret
214 entry:
215   %a = call <vscale x 16 x i8> @llvm.riscv.vnclip.nxv16i8.nxv16i16.nxv16i8(
216     <vscale x 16 x i8> undef,
217     <vscale x 16 x i16> %0,
218     <vscale x 16 x i8> %1,
219     iXLen 0, iXLen %2)
221   ret <vscale x 16 x i8> %a
224 declare <vscale x 16 x i8> @llvm.riscv.vnclip.mask.nxv16i8.nxv16i16.nxv16i8(
225   <vscale x 16 x i8>,
226   <vscale x 16 x i16>,
227   <vscale x 16 x i8>,
228   <vscale x 16 x i1>,
229   iXLen, iXLen, iXLen);
231 define <vscale x 16 x i8> @intrinsic_vnclip_mask_wv_nxv16i8_nxv16i16_nxv16i8(<vscale x 16 x i8> %0, <vscale x 16 x i16> %1, <vscale x 16 x i8> %2, <vscale x 16 x i1> %3, iXLen %4) nounwind {
232 ; CHECK-LABEL: intrinsic_vnclip_mask_wv_nxv16i8_nxv16i16_nxv16i8:
233 ; CHECK:       # %bb.0: # %entry
234 ; CHECK-NEXT:    vsetvli zero, a0, e8, m2, ta, mu
235 ; CHECK-NEXT:    csrwi vxrm, 0
236 ; CHECK-NEXT:    vnclip.wv v8, v12, v10, v0.t
237 ; CHECK-NEXT:    ret
238 entry:
239   %a = call <vscale x 16 x i8> @llvm.riscv.vnclip.mask.nxv16i8.nxv16i16.nxv16i8(
240     <vscale x 16 x i8> %0,
241     <vscale x 16 x i16> %1,
242     <vscale x 16 x i8> %2,
243     <vscale x 16 x i1> %3,
244     iXLen 0, iXLen %4, iXLen 1)
246   ret <vscale x 16 x i8> %a
249 declare <vscale x 32 x i8> @llvm.riscv.vnclip.nxv32i8.nxv32i16.nxv32i8(
250   <vscale x 32 x i8>,
251   <vscale x 32 x i16>,
252   <vscale x 32 x i8>,
253   iXLen, iXLen);
255 define <vscale x 32 x i8> @intrinsic_vnclip_wv_nxv32i8_nxv32i16_nxv32i8(<vscale x 32 x i16> %0, <vscale x 32 x i8> %1, iXLen %2) nounwind {
256 ; CHECK-LABEL: intrinsic_vnclip_wv_nxv32i8_nxv32i16_nxv32i8:
257 ; CHECK:       # %bb.0: # %entry
258 ; CHECK-NEXT:    vsetvli zero, a0, e8, m4, ta, ma
259 ; CHECK-NEXT:    csrwi vxrm, 0
260 ; CHECK-NEXT:    vnclip.wv v20, v8, v16
261 ; CHECK-NEXT:    vmv.v.v v8, v20
262 ; CHECK-NEXT:    ret
263 entry:
264   %a = call <vscale x 32 x i8> @llvm.riscv.vnclip.nxv32i8.nxv32i16.nxv32i8(
265     <vscale x 32 x i8> undef,
266     <vscale x 32 x i16> %0,
267     <vscale x 32 x i8> %1,
268     iXLen 0, iXLen %2)
270   ret <vscale x 32 x i8> %a
273 declare <vscale x 32 x i8> @llvm.riscv.vnclip.mask.nxv32i8.nxv32i16.nxv32i8(
274   <vscale x 32 x i8>,
275   <vscale x 32 x i16>,
276   <vscale x 32 x i8>,
277   <vscale x 32 x i1>,
278   iXLen, iXLen, iXLen);
280 define <vscale x 32 x i8> @intrinsic_vnclip_mask_wv_nxv32i8_nxv32i16_nxv32i8(<vscale x 32 x i8> %0, <vscale x 32 x i16> %1, <vscale x 32 x i8> %2, <vscale x 32 x i1> %3, iXLen %4) nounwind {
281 ; CHECK-LABEL: intrinsic_vnclip_mask_wv_nxv32i8_nxv32i16_nxv32i8:
282 ; CHECK:       # %bb.0: # %entry
283 ; CHECK-NEXT:    vsetvli zero, a0, e8, m4, ta, mu
284 ; CHECK-NEXT:    csrwi vxrm, 0
285 ; CHECK-NEXT:    vnclip.wv v8, v16, v12, v0.t
286 ; CHECK-NEXT:    ret
287 entry:
288   %a = call <vscale x 32 x i8> @llvm.riscv.vnclip.mask.nxv32i8.nxv32i16.nxv32i8(
289     <vscale x 32 x i8> %0,
290     <vscale x 32 x i16> %1,
291     <vscale x 32 x i8> %2,
292     <vscale x 32 x i1> %3,
293     iXLen 0, iXLen %4, iXLen 1)
295   ret <vscale x 32 x i8> %a
298 declare <vscale x 1 x i16> @llvm.riscv.vnclip.nxv1i16.nxv1i32.nxv1i16(
299   <vscale x 1 x i16>,
300   <vscale x 1 x i32>,
301   <vscale x 1 x i16>,
302   iXLen, iXLen);
304 define <vscale x 1 x i16> @intrinsic_vnclip_wv_nxv1i16_nxv1i32_nxv1i16(<vscale x 1 x i32> %0, <vscale x 1 x i16> %1, iXLen %2) nounwind {
305 ; CHECK-LABEL: intrinsic_vnclip_wv_nxv1i16_nxv1i32_nxv1i16:
306 ; CHECK:       # %bb.0: # %entry
307 ; CHECK-NEXT:    vsetvli zero, a0, e16, mf4, ta, ma
308 ; CHECK-NEXT:    csrwi vxrm, 0
309 ; CHECK-NEXT:    vnclip.wv v8, v8, v9
310 ; CHECK-NEXT:    ret
311 entry:
312   %a = call <vscale x 1 x i16> @llvm.riscv.vnclip.nxv1i16.nxv1i32.nxv1i16(
313     <vscale x 1 x i16> undef,
314     <vscale x 1 x i32> %0,
315     <vscale x 1 x i16> %1,
316     iXLen 0, iXLen %2)
318   ret <vscale x 1 x i16> %a
321 declare <vscale x 1 x i16> @llvm.riscv.vnclip.mask.nxv1i16.nxv1i32.nxv1i16(
322   <vscale x 1 x i16>,
323   <vscale x 1 x i32>,
324   <vscale x 1 x i16>,
325   <vscale x 1 x i1>,
326   iXLen, iXLen, iXLen);
328 define <vscale x 1 x i16> @intrinsic_vnclip_mask_wv_nxv1i16_nxv1i32_nxv1i16(<vscale x 1 x i16> %0, <vscale x 1 x i32> %1, <vscale x 1 x i16> %2, <vscale x 1 x i1> %3, iXLen %4) nounwind {
329 ; CHECK-LABEL: intrinsic_vnclip_mask_wv_nxv1i16_nxv1i32_nxv1i16:
330 ; CHECK:       # %bb.0: # %entry
331 ; CHECK-NEXT:    vsetvli zero, a0, e16, mf4, ta, mu
332 ; CHECK-NEXT:    csrwi vxrm, 0
333 ; CHECK-NEXT:    vnclip.wv v8, v9, v10, v0.t
334 ; CHECK-NEXT:    ret
335 entry:
336   %a = call <vscale x 1 x i16> @llvm.riscv.vnclip.mask.nxv1i16.nxv1i32.nxv1i16(
337     <vscale x 1 x i16> %0,
338     <vscale x 1 x i32> %1,
339     <vscale x 1 x i16> %2,
340     <vscale x 1 x i1> %3,
341     iXLen 0, iXLen %4, iXLen 1)
343   ret <vscale x 1 x i16> %a
346 declare <vscale x 2 x i16> @llvm.riscv.vnclip.nxv2i16.nxv2i32.nxv2i16(
347   <vscale x 2 x i16>,
348   <vscale x 2 x i32>,
349   <vscale x 2 x i16>,
350   iXLen, iXLen);
352 define <vscale x 2 x i16> @intrinsic_vnclip_wv_nxv2i16_nxv2i32_nxv2i16(<vscale x 2 x i32> %0, <vscale x 2 x i16> %1, iXLen %2) nounwind {
353 ; CHECK-LABEL: intrinsic_vnclip_wv_nxv2i16_nxv2i32_nxv2i16:
354 ; CHECK:       # %bb.0: # %entry
355 ; CHECK-NEXT:    vsetvli zero, a0, e16, mf2, ta, ma
356 ; CHECK-NEXT:    csrwi vxrm, 0
357 ; CHECK-NEXT:    vnclip.wv v8, v8, v9
358 ; CHECK-NEXT:    ret
359 entry:
360   %a = call <vscale x 2 x i16> @llvm.riscv.vnclip.nxv2i16.nxv2i32.nxv2i16(
361     <vscale x 2 x i16> undef,
362     <vscale x 2 x i32> %0,
363     <vscale x 2 x i16> %1,
364     iXLen 0, iXLen %2)
366   ret <vscale x 2 x i16> %a
369 declare <vscale x 2 x i16> @llvm.riscv.vnclip.mask.nxv2i16.nxv2i32.nxv2i16(
370   <vscale x 2 x i16>,
371   <vscale x 2 x i32>,
372   <vscale x 2 x i16>,
373   <vscale x 2 x i1>,
374   iXLen, iXLen, iXLen);
376 define <vscale x 2 x i16> @intrinsic_vnclip_mask_wv_nxv2i16_nxv2i32_nxv2i16(<vscale x 2 x i16> %0, <vscale x 2 x i32> %1, <vscale x 2 x i16> %2, <vscale x 2 x i1> %3, iXLen %4) nounwind {
377 ; CHECK-LABEL: intrinsic_vnclip_mask_wv_nxv2i16_nxv2i32_nxv2i16:
378 ; CHECK:       # %bb.0: # %entry
379 ; CHECK-NEXT:    vsetvli zero, a0, e16, mf2, ta, mu
380 ; CHECK-NEXT:    csrwi vxrm, 0
381 ; CHECK-NEXT:    vnclip.wv v8, v9, v10, v0.t
382 ; CHECK-NEXT:    ret
383 entry:
384   %a = call <vscale x 2 x i16> @llvm.riscv.vnclip.mask.nxv2i16.nxv2i32.nxv2i16(
385     <vscale x 2 x i16> %0,
386     <vscale x 2 x i32> %1,
387     <vscale x 2 x i16> %2,
388     <vscale x 2 x i1> %3,
389     iXLen 0, iXLen %4, iXLen 1)
391   ret <vscale x 2 x i16> %a
394 declare <vscale x 4 x i16> @llvm.riscv.vnclip.nxv4i16.nxv4i32.nxv4i16(
395   <vscale x 4 x i16>,
396   <vscale x 4 x i32>,
397   <vscale x 4 x i16>,
398   iXLen, iXLen);
400 define <vscale x 4 x i16> @intrinsic_vnclip_wv_nxv4i16_nxv4i32_nxv4i16(<vscale x 4 x i32> %0, <vscale x 4 x i16> %1, iXLen %2) nounwind {
401 ; CHECK-LABEL: intrinsic_vnclip_wv_nxv4i16_nxv4i32_nxv4i16:
402 ; CHECK:       # %bb.0: # %entry
403 ; CHECK-NEXT:    vsetvli zero, a0, e16, m1, ta, ma
404 ; CHECK-NEXT:    csrwi vxrm, 0
405 ; CHECK-NEXT:    vnclip.wv v11, v8, v10
406 ; CHECK-NEXT:    vmv.v.v v8, v11
407 ; CHECK-NEXT:    ret
408 entry:
409   %a = call <vscale x 4 x i16> @llvm.riscv.vnclip.nxv4i16.nxv4i32.nxv4i16(
410     <vscale x 4 x i16> undef,
411     <vscale x 4 x i32> %0,
412     <vscale x 4 x i16> %1,
413     iXLen 0, iXLen %2)
415   ret <vscale x 4 x i16> %a
418 declare <vscale x 4 x i16> @llvm.riscv.vnclip.mask.nxv4i16.nxv4i32.nxv4i16(
419   <vscale x 4 x i16>,
420   <vscale x 4 x i32>,
421   <vscale x 4 x i16>,
422   <vscale x 4 x i1>,
423   iXLen, iXLen, iXLen);
425 define <vscale x 4 x i16> @intrinsic_vnclip_mask_wv_nxv4i16_nxv4i32_nxv4i16(<vscale x 4 x i16> %0, <vscale x 4 x i32> %1, <vscale x 4 x i16> %2, <vscale x 4 x i1> %3, iXLen %4) nounwind {
426 ; CHECK-LABEL: intrinsic_vnclip_mask_wv_nxv4i16_nxv4i32_nxv4i16:
427 ; CHECK:       # %bb.0: # %entry
428 ; CHECK-NEXT:    vsetvli zero, a0, e16, m1, ta, mu
429 ; CHECK-NEXT:    csrwi vxrm, 0
430 ; CHECK-NEXT:    vnclip.wv v8, v10, v9, v0.t
431 ; CHECK-NEXT:    ret
432 entry:
433   %a = call <vscale x 4 x i16> @llvm.riscv.vnclip.mask.nxv4i16.nxv4i32.nxv4i16(
434     <vscale x 4 x i16> %0,
435     <vscale x 4 x i32> %1,
436     <vscale x 4 x i16> %2,
437     <vscale x 4 x i1> %3,
438     iXLen 0, iXLen %4, iXLen 1)
440   ret <vscale x 4 x i16> %a
443 declare <vscale x 8 x i16> @llvm.riscv.vnclip.nxv8i16.nxv8i32.nxv8i16(
444   <vscale x 8 x i16>,
445   <vscale x 8 x i32>,
446   <vscale x 8 x i16>,
447   iXLen, iXLen);
449 define <vscale x 8 x i16> @intrinsic_vnclip_wv_nxv8i16_nxv8i32_nxv8i16(<vscale x 8 x i32> %0, <vscale x 8 x i16> %1, iXLen %2) nounwind {
450 ; CHECK-LABEL: intrinsic_vnclip_wv_nxv8i16_nxv8i32_nxv8i16:
451 ; CHECK:       # %bb.0: # %entry
452 ; CHECK-NEXT:    vsetvli zero, a0, e16, m2, ta, ma
453 ; CHECK-NEXT:    csrwi vxrm, 0
454 ; CHECK-NEXT:    vnclip.wv v14, v8, v12
455 ; CHECK-NEXT:    vmv.v.v v8, v14
456 ; CHECK-NEXT:    ret
457 entry:
458   %a = call <vscale x 8 x i16> @llvm.riscv.vnclip.nxv8i16.nxv8i32.nxv8i16(
459     <vscale x 8 x i16> undef,
460     <vscale x 8 x i32> %0,
461     <vscale x 8 x i16> %1,
462     iXLen 0, iXLen %2)
464   ret <vscale x 8 x i16> %a
467 declare <vscale x 8 x i16> @llvm.riscv.vnclip.mask.nxv8i16.nxv8i32.nxv8i16(
468   <vscale x 8 x i16>,
469   <vscale x 8 x i32>,
470   <vscale x 8 x i16>,
471   <vscale x 8 x i1>,
472   iXLen, iXLen, iXLen);
474 define <vscale x 8 x i16> @intrinsic_vnclip_mask_wv_nxv8i16_nxv8i32_nxv8i16(<vscale x 8 x i16> %0, <vscale x 8 x i32> %1, <vscale x 8 x i16> %2, <vscale x 8 x i1> %3, iXLen %4) nounwind {
475 ; CHECK-LABEL: intrinsic_vnclip_mask_wv_nxv8i16_nxv8i32_nxv8i16:
476 ; CHECK:       # %bb.0: # %entry
477 ; CHECK-NEXT:    vsetvli zero, a0, e16, m2, ta, mu
478 ; CHECK-NEXT:    csrwi vxrm, 0
479 ; CHECK-NEXT:    vnclip.wv v8, v12, v10, v0.t
480 ; CHECK-NEXT:    ret
481 entry:
482   %a = call <vscale x 8 x i16> @llvm.riscv.vnclip.mask.nxv8i16.nxv8i32.nxv8i16(
483     <vscale x 8 x i16> %0,
484     <vscale x 8 x i32> %1,
485     <vscale x 8 x i16> %2,
486     <vscale x 8 x i1> %3,
487     iXLen 0, iXLen %4, iXLen 1)
489   ret <vscale x 8 x i16> %a
492 declare <vscale x 16 x i16> @llvm.riscv.vnclip.nxv16i16.nxv16i32.nxv16i16(
493   <vscale x 16 x i16>,
494   <vscale x 16 x i32>,
495   <vscale x 16 x i16>,
496   iXLen, iXLen);
498 define <vscale x 16 x i16> @intrinsic_vnclip_wv_nxv16i16_nxv16i32_nxv16i16(<vscale x 16 x i32> %0, <vscale x 16 x i16> %1, iXLen %2) nounwind {
499 ; CHECK-LABEL: intrinsic_vnclip_wv_nxv16i16_nxv16i32_nxv16i16:
500 ; CHECK:       # %bb.0: # %entry
501 ; CHECK-NEXT:    vsetvli zero, a0, e16, m4, ta, ma
502 ; CHECK-NEXT:    csrwi vxrm, 0
503 ; CHECK-NEXT:    vnclip.wv v20, v8, v16
504 ; CHECK-NEXT:    vmv.v.v v8, v20
505 ; CHECK-NEXT:    ret
506 entry:
507   %a = call <vscale x 16 x i16> @llvm.riscv.vnclip.nxv16i16.nxv16i32.nxv16i16(
508     <vscale x 16 x i16> undef,
509     <vscale x 16 x i32> %0,
510     <vscale x 16 x i16> %1,
511     iXLen 0, iXLen %2)
513   ret <vscale x 16 x i16> %a
516 declare <vscale x 16 x i16> @llvm.riscv.vnclip.mask.nxv16i16.nxv16i32.nxv16i16(
517   <vscale x 16 x i16>,
518   <vscale x 16 x i32>,
519   <vscale x 16 x i16>,
520   <vscale x 16 x i1>,
521   iXLen, iXLen, iXLen);
523 define <vscale x 16 x i16> @intrinsic_vnclip_mask_wv_nxv16i16_nxv16i32_nxv16i16(<vscale x 16 x i16> %0, <vscale x 16 x i32> %1, <vscale x 16 x i16> %2, <vscale x 16 x i1> %3, iXLen %4) nounwind {
524 ; CHECK-LABEL: intrinsic_vnclip_mask_wv_nxv16i16_nxv16i32_nxv16i16:
525 ; CHECK:       # %bb.0: # %entry
526 ; CHECK-NEXT:    vsetvli zero, a0, e16, m4, ta, mu
527 ; CHECK-NEXT:    csrwi vxrm, 0
528 ; CHECK-NEXT:    vnclip.wv v8, v16, v12, v0.t
529 ; CHECK-NEXT:    ret
530 entry:
531   %a = call <vscale x 16 x i16> @llvm.riscv.vnclip.mask.nxv16i16.nxv16i32.nxv16i16(
532     <vscale x 16 x i16> %0,
533     <vscale x 16 x i32> %1,
534     <vscale x 16 x i16> %2,
535     <vscale x 16 x i1> %3,
536     iXLen 0, iXLen %4, iXLen 1)
538   ret <vscale x 16 x i16> %a
541 declare <vscale x 1 x i32> @llvm.riscv.vnclip.nxv1i32.nxv1i64.nxv1i32(
542   <vscale x 1 x i32>,
543   <vscale x 1 x i64>,
544   <vscale x 1 x i32>,
545   iXLen, iXLen);
547 define <vscale x 1 x i32> @intrinsic_vnclip_wv_nxv1i32_nxv1i64_nxv1i32(<vscale x 1 x i64> %0, <vscale x 1 x i32> %1, iXLen %2) nounwind {
548 ; CHECK-LABEL: intrinsic_vnclip_wv_nxv1i32_nxv1i64_nxv1i32:
549 ; CHECK:       # %bb.0: # %entry
550 ; CHECK-NEXT:    vsetvli zero, a0, e32, mf2, ta, ma
551 ; CHECK-NEXT:    csrwi vxrm, 0
552 ; CHECK-NEXT:    vnclip.wv v8, v8, v9
553 ; CHECK-NEXT:    ret
554 entry:
555   %a = call <vscale x 1 x i32> @llvm.riscv.vnclip.nxv1i32.nxv1i64.nxv1i32(
556     <vscale x 1 x i32> undef,
557     <vscale x 1 x i64> %0,
558     <vscale x 1 x i32> %1,
559     iXLen 0, iXLen %2)
561   ret <vscale x 1 x i32> %a
564 declare <vscale x 1 x i32> @llvm.riscv.vnclip.mask.nxv1i32.nxv1i64.nxv1i32(
565   <vscale x 1 x i32>,
566   <vscale x 1 x i64>,
567   <vscale x 1 x i32>,
568   <vscale x 1 x i1>,
569   iXLen, iXLen, iXLen);
571 define <vscale x 1 x i32> @intrinsic_vnclip_mask_wv_nxv1i32_nxv1i64_nxv1i32(<vscale x 1 x i32> %0, <vscale x 1 x i64> %1, <vscale x 1 x i32> %2, <vscale x 1 x i1> %3, iXLen %4) nounwind {
572 ; CHECK-LABEL: intrinsic_vnclip_mask_wv_nxv1i32_nxv1i64_nxv1i32:
573 ; CHECK:       # %bb.0: # %entry
574 ; CHECK-NEXT:    vsetvli zero, a0, e32, mf2, ta, mu
575 ; CHECK-NEXT:    csrwi vxrm, 0
576 ; CHECK-NEXT:    vnclip.wv v8, v9, v10, v0.t
577 ; CHECK-NEXT:    ret
578 entry:
579   %a = call <vscale x 1 x i32> @llvm.riscv.vnclip.mask.nxv1i32.nxv1i64.nxv1i32(
580     <vscale x 1 x i32> %0,
581     <vscale x 1 x i64> %1,
582     <vscale x 1 x i32> %2,
583     <vscale x 1 x i1> %3,
584     iXLen 0, iXLen %4, iXLen 1)
586   ret <vscale x 1 x i32> %a
589 declare <vscale x 2 x i32> @llvm.riscv.vnclip.nxv2i32.nxv2i64.nxv2i32(
590   <vscale x 2 x i32>,
591   <vscale x 2 x i64>,
592   <vscale x 2 x i32>,
593   iXLen, iXLen);
595 define <vscale x 2 x i32> @intrinsic_vnclip_wv_nxv2i32_nxv2i64_nxv2i32(<vscale x 2 x i64> %0, <vscale x 2 x i32> %1, iXLen %2) nounwind {
596 ; CHECK-LABEL: intrinsic_vnclip_wv_nxv2i32_nxv2i64_nxv2i32:
597 ; CHECK:       # %bb.0: # %entry
598 ; CHECK-NEXT:    vsetvli zero, a0, e32, m1, ta, ma
599 ; CHECK-NEXT:    csrwi vxrm, 0
600 ; CHECK-NEXT:    vnclip.wv v11, v8, v10
601 ; CHECK-NEXT:    vmv.v.v v8, v11
602 ; CHECK-NEXT:    ret
603 entry:
604   %a = call <vscale x 2 x i32> @llvm.riscv.vnclip.nxv2i32.nxv2i64.nxv2i32(
605     <vscale x 2 x i32> undef,
606     <vscale x 2 x i64> %0,
607     <vscale x 2 x i32> %1,
608     iXLen 0, iXLen %2)
610   ret <vscale x 2 x i32> %a
613 declare <vscale x 2 x i32> @llvm.riscv.vnclip.mask.nxv2i32.nxv2i64.nxv2i32(
614   <vscale x 2 x i32>,
615   <vscale x 2 x i64>,
616   <vscale x 2 x i32>,
617   <vscale x 2 x i1>,
618   iXLen, iXLen, iXLen);
620 define <vscale x 2 x i32> @intrinsic_vnclip_mask_wv_nxv2i32_nxv2i64_nxv2i32(<vscale x 2 x i32> %0, <vscale x 2 x i64> %1, <vscale x 2 x i32> %2, <vscale x 2 x i1> %3, iXLen %4) nounwind {
621 ; CHECK-LABEL: intrinsic_vnclip_mask_wv_nxv2i32_nxv2i64_nxv2i32:
622 ; CHECK:       # %bb.0: # %entry
623 ; CHECK-NEXT:    vsetvli zero, a0, e32, m1, ta, mu
624 ; CHECK-NEXT:    csrwi vxrm, 0
625 ; CHECK-NEXT:    vnclip.wv v8, v10, v9, v0.t
626 ; CHECK-NEXT:    ret
627 entry:
628   %a = call <vscale x 2 x i32> @llvm.riscv.vnclip.mask.nxv2i32.nxv2i64.nxv2i32(
629     <vscale x 2 x i32> %0,
630     <vscale x 2 x i64> %1,
631     <vscale x 2 x i32> %2,
632     <vscale x 2 x i1> %3,
633     iXLen 0, iXLen %4, iXLen 1)
635   ret <vscale x 2 x i32> %a
638 declare <vscale x 4 x i32> @llvm.riscv.vnclip.nxv4i32.nxv4i64.nxv4i32(
639   <vscale x 4 x i32>,
640   <vscale x 4 x i64>,
641   <vscale x 4 x i32>,
642   iXLen, iXLen);
644 define <vscale x 4 x i32> @intrinsic_vnclip_wv_nxv4i32_nxv4i64_nxv4i32(<vscale x 4 x i64> %0, <vscale x 4 x i32> %1, iXLen %2) nounwind {
645 ; CHECK-LABEL: intrinsic_vnclip_wv_nxv4i32_nxv4i64_nxv4i32:
646 ; CHECK:       # %bb.0: # %entry
647 ; CHECK-NEXT:    vsetvli zero, a0, e32, m2, ta, ma
648 ; CHECK-NEXT:    csrwi vxrm, 0
649 ; CHECK-NEXT:    vnclip.wv v14, v8, v12
650 ; CHECK-NEXT:    vmv.v.v v8, v14
651 ; CHECK-NEXT:    ret
652 entry:
653   %a = call <vscale x 4 x i32> @llvm.riscv.vnclip.nxv4i32.nxv4i64.nxv4i32(
654     <vscale x 4 x i32> undef,
655     <vscale x 4 x i64> %0,
656     <vscale x 4 x i32> %1,
657     iXLen 0, iXLen %2)
659   ret <vscale x 4 x i32> %a
662 declare <vscale x 4 x i32> @llvm.riscv.vnclip.mask.nxv4i32.nxv4i64.nxv4i32(
663   <vscale x 4 x i32>,
664   <vscale x 4 x i64>,
665   <vscale x 4 x i32>,
666   <vscale x 4 x i1>,
667   iXLen, iXLen, iXLen);
669 define <vscale x 4 x i32> @intrinsic_vnclip_mask_wv_nxv4i32_nxv4i64_nxv4i32(<vscale x 4 x i32> %0, <vscale x 4 x i64> %1, <vscale x 4 x i32> %2, <vscale x 4 x i1> %3, iXLen %4) nounwind {
670 ; CHECK-LABEL: intrinsic_vnclip_mask_wv_nxv4i32_nxv4i64_nxv4i32:
671 ; CHECK:       # %bb.0: # %entry
672 ; CHECK-NEXT:    vsetvli zero, a0, e32, m2, ta, mu
673 ; CHECK-NEXT:    csrwi vxrm, 0
674 ; CHECK-NEXT:    vnclip.wv v8, v12, v10, v0.t
675 ; CHECK-NEXT:    ret
676 entry:
677   %a = call <vscale x 4 x i32> @llvm.riscv.vnclip.mask.nxv4i32.nxv4i64.nxv4i32(
678     <vscale x 4 x i32> %0,
679     <vscale x 4 x i64> %1,
680     <vscale x 4 x i32> %2,
681     <vscale x 4 x i1> %3,
682     iXLen 0, iXLen %4, iXLen 1)
684   ret <vscale x 4 x i32> %a
687 declare <vscale x 8 x i32> @llvm.riscv.vnclip.nxv8i32.nxv8i64.nxv8i32(
688   <vscale x 8 x i32>,
689   <vscale x 8 x i64>,
690   <vscale x 8 x i32>,
691   iXLen, iXLen);
693 define <vscale x 8 x i32> @intrinsic_vnclip_wv_nxv8i32_nxv8i64_nxv8i32(<vscale x 8 x i64> %0, <vscale x 8 x i32> %1, iXLen %2) nounwind {
694 ; CHECK-LABEL: intrinsic_vnclip_wv_nxv8i32_nxv8i64_nxv8i32:
695 ; CHECK:       # %bb.0: # %entry
696 ; CHECK-NEXT:    vsetvli zero, a0, e32, m4, ta, ma
697 ; CHECK-NEXT:    csrwi vxrm, 0
698 ; CHECK-NEXT:    vnclip.wv v20, v8, v16
699 ; CHECK-NEXT:    vmv.v.v v8, v20
700 ; CHECK-NEXT:    ret
701 entry:
702   %a = call <vscale x 8 x i32> @llvm.riscv.vnclip.nxv8i32.nxv8i64.nxv8i32(
703     <vscale x 8 x i32> undef,
704     <vscale x 8 x i64> %0,
705     <vscale x 8 x i32> %1,
706     iXLen 0, iXLen %2)
708   ret <vscale x 8 x i32> %a
711 declare <vscale x 8 x i32> @llvm.riscv.vnclip.mask.nxv8i32.nxv8i64.nxv8i32(
712   <vscale x 8 x i32>,
713   <vscale x 8 x i64>,
714   <vscale x 8 x i32>,
715   <vscale x 8 x i1>,
716   iXLen, iXLen, iXLen);
718 define <vscale x 8 x i32> @intrinsic_vnclip_mask_wv_nxv8i32_nxv8i64_nxv8i32(<vscale x 8 x i32> %0, <vscale x 8 x i64> %1, <vscale x 8 x i32> %2, <vscale x 8 x i1> %3, iXLen %4) nounwind {
719 ; CHECK-LABEL: intrinsic_vnclip_mask_wv_nxv8i32_nxv8i64_nxv8i32:
720 ; CHECK:       # %bb.0: # %entry
721 ; CHECK-NEXT:    vsetvli zero, a0, e32, m4, ta, mu
722 ; CHECK-NEXT:    csrwi vxrm, 0
723 ; CHECK-NEXT:    vnclip.wv v8, v16, v12, v0.t
724 ; CHECK-NEXT:    ret
725 entry:
726   %a = call <vscale x 8 x i32> @llvm.riscv.vnclip.mask.nxv8i32.nxv8i64.nxv8i32(
727     <vscale x 8 x i32> %0,
728     <vscale x 8 x i64> %1,
729     <vscale x 8 x i32> %2,
730     <vscale x 8 x i1> %3,
731     iXLen 0, iXLen %4, iXLen 1)
733   ret <vscale x 8 x i32> %a
736 declare <vscale x 1 x i8> @llvm.riscv.vnclip.nxv1i8.nxv1i16(
737   <vscale x 1 x i8>,
738   <vscale x 1 x i16>,
739   iXLen, iXLen, iXLen);
741 define <vscale x 1 x i8> @intrinsic_vnclip_vx_nxv1i8_nxv1i16(<vscale x 1 x i16> %0, iXLen %1, iXLen %2) nounwind {
742 ; CHECK-LABEL: intrinsic_vnclip_vx_nxv1i8_nxv1i16:
743 ; CHECK:       # %bb.0: # %entry
744 ; CHECK-NEXT:    vsetvli zero, a1, e8, mf8, ta, ma
745 ; CHECK-NEXT:    csrwi vxrm, 0
746 ; CHECK-NEXT:    vnclip.wx v8, v8, a0
747 ; CHECK-NEXT:    ret
748 entry:
749   %a = call <vscale x 1 x i8> @llvm.riscv.vnclip.nxv1i8.nxv1i16(
750     <vscale x 1 x i8> undef,
751     <vscale x 1 x i16> %0,
752     iXLen %1,
753     iXLen 0, iXLen %2)
755   ret <vscale x 1 x i8> %a
758 declare <vscale x 1 x i8> @llvm.riscv.vnclip.mask.nxv1i8.nxv1i16(
759   <vscale x 1 x i8>,
760   <vscale x 1 x i16>,
761   iXLen,
762   <vscale x 1 x i1>,
763   iXLen, iXLen, iXLen);
765 define <vscale x 1 x i8> @intrinsic_vnclip_mask_vx_nxv1i8_nxv1i16(<vscale x 1 x i8> %0, <vscale x 1 x i16> %1, iXLen %2, <vscale x 1 x i1> %3, iXLen %4) nounwind {
766 ; CHECK-LABEL: intrinsic_vnclip_mask_vx_nxv1i8_nxv1i16:
767 ; CHECK:       # %bb.0: # %entry
768 ; CHECK-NEXT:    vsetvli zero, a1, e8, mf8, ta, mu
769 ; CHECK-NEXT:    csrwi vxrm, 0
770 ; CHECK-NEXT:    vnclip.wx v8, v9, a0, v0.t
771 ; CHECK-NEXT:    ret
772 entry:
773   %a = call <vscale x 1 x i8> @llvm.riscv.vnclip.mask.nxv1i8.nxv1i16(
774     <vscale x 1 x i8> %0,
775     <vscale x 1 x i16> %1,
776     iXLen %2,
777     <vscale x 1 x i1> %3,
778     iXLen 0, iXLen %4, iXLen 1)
780   ret <vscale x 1 x i8> %a
783 declare <vscale x 2 x i8> @llvm.riscv.vnclip.nxv2i8.nxv2i16(
784   <vscale x 2 x i8>,
785   <vscale x 2 x i16>,
786   iXLen, iXLen, iXLen);
788 define <vscale x 2 x i8> @intrinsic_vnclip_vx_nxv2i8_nxv2i16(<vscale x 2 x i16> %0, iXLen %1, iXLen %2) nounwind {
789 ; CHECK-LABEL: intrinsic_vnclip_vx_nxv2i8_nxv2i16:
790 ; CHECK:       # %bb.0: # %entry
791 ; CHECK-NEXT:    vsetvli zero, a1, e8, mf4, ta, ma
792 ; CHECK-NEXT:    csrwi vxrm, 0
793 ; CHECK-NEXT:    vnclip.wx v8, v8, a0
794 ; CHECK-NEXT:    ret
795 entry:
796   %a = call <vscale x 2 x i8> @llvm.riscv.vnclip.nxv2i8.nxv2i16(
797     <vscale x 2 x i8> undef,
798     <vscale x 2 x i16> %0,
799     iXLen %1,
800     iXLen 0, iXLen %2)
802   ret <vscale x 2 x i8> %a
805 declare <vscale x 2 x i8> @llvm.riscv.vnclip.mask.nxv2i8.nxv2i16(
806   <vscale x 2 x i8>,
807   <vscale x 2 x i16>,
808   iXLen,
809   <vscale x 2 x i1>,
810   iXLen, iXLen, iXLen);
812 define <vscale x 2 x i8> @intrinsic_vnclip_mask_vx_nxv2i8_nxv2i16(<vscale x 2 x i8> %0, <vscale x 2 x i16> %1, iXLen %2, <vscale x 2 x i1> %3, iXLen %4) nounwind {
813 ; CHECK-LABEL: intrinsic_vnclip_mask_vx_nxv2i8_nxv2i16:
814 ; CHECK:       # %bb.0: # %entry
815 ; CHECK-NEXT:    vsetvli zero, a1, e8, mf4, ta, mu
816 ; CHECK-NEXT:    csrwi vxrm, 0
817 ; CHECK-NEXT:    vnclip.wx v8, v9, a0, v0.t
818 ; CHECK-NEXT:    ret
819 entry:
820   %a = call <vscale x 2 x i8> @llvm.riscv.vnclip.mask.nxv2i8.nxv2i16(
821     <vscale x 2 x i8> %0,
822     <vscale x 2 x i16> %1,
823     iXLen %2,
824     <vscale x 2 x i1> %3,
825     iXLen 0, iXLen %4, iXLen 1)
827   ret <vscale x 2 x i8> %a
830 declare <vscale x 4 x i8> @llvm.riscv.vnclip.nxv4i8.nxv4i16(
831   <vscale x 4 x i8>,
832   <vscale x 4 x i16>,
833   iXLen, iXLen, iXLen);
835 define <vscale x 4 x i8> @intrinsic_vnclip_vx_nxv4i8_nxv4i16(<vscale x 4 x i16> %0, iXLen %1, iXLen %2) nounwind {
836 ; CHECK-LABEL: intrinsic_vnclip_vx_nxv4i8_nxv4i16:
837 ; CHECK:       # %bb.0: # %entry
838 ; CHECK-NEXT:    vsetvli zero, a1, e8, mf2, ta, ma
839 ; CHECK-NEXT:    csrwi vxrm, 0
840 ; CHECK-NEXT:    vnclip.wx v8, v8, a0
841 ; CHECK-NEXT:    ret
842 entry:
843   %a = call <vscale x 4 x i8> @llvm.riscv.vnclip.nxv4i8.nxv4i16(
844     <vscale x 4 x i8> undef,
845     <vscale x 4 x i16> %0,
846     iXLen %1,
847     iXLen 0, iXLen %2)
849   ret <vscale x 4 x i8> %a
852 declare <vscale x 4 x i8> @llvm.riscv.vnclip.mask.nxv4i8.nxv4i16(
853   <vscale x 4 x i8>,
854   <vscale x 4 x i16>,
855   iXLen,
856   <vscale x 4 x i1>,
857   iXLen, iXLen, iXLen);
859 define <vscale x 4 x i8> @intrinsic_vnclip_mask_vx_nxv4i8_nxv4i16(<vscale x 4 x i8> %0, <vscale x 4 x i16> %1, iXLen %2, <vscale x 4 x i1> %3, iXLen %4) nounwind {
860 ; CHECK-LABEL: intrinsic_vnclip_mask_vx_nxv4i8_nxv4i16:
861 ; CHECK:       # %bb.0: # %entry
862 ; CHECK-NEXT:    vsetvli zero, a1, e8, mf2, ta, mu
863 ; CHECK-NEXT:    csrwi vxrm, 0
864 ; CHECK-NEXT:    vnclip.wx v8, v9, a0, v0.t
865 ; CHECK-NEXT:    ret
866 entry:
867   %a = call <vscale x 4 x i8> @llvm.riscv.vnclip.mask.nxv4i8.nxv4i16(
868     <vscale x 4 x i8> %0,
869     <vscale x 4 x i16> %1,
870     iXLen %2,
871     <vscale x 4 x i1> %3,
872     iXLen 0, iXLen %4, iXLen 1)
874   ret <vscale x 4 x i8> %a
877 declare <vscale x 8 x i8> @llvm.riscv.vnclip.nxv8i8.nxv8i16(
878   <vscale x 8 x i8>,
879   <vscale x 8 x i16>,
880   iXLen, iXLen, iXLen);
882 define <vscale x 8 x i8> @intrinsic_vnclip_vx_nxv8i8_nxv8i16(<vscale x 8 x i16> %0, iXLen %1, iXLen %2) nounwind {
883 ; CHECK-LABEL: intrinsic_vnclip_vx_nxv8i8_nxv8i16:
884 ; CHECK:       # %bb.0: # %entry
885 ; CHECK-NEXT:    vsetvli zero, a1, e8, m1, ta, ma
886 ; CHECK-NEXT:    csrwi vxrm, 0
887 ; CHECK-NEXT:    vnclip.wx v10, v8, a0
888 ; CHECK-NEXT:    vmv.v.v v8, v10
889 ; CHECK-NEXT:    ret
890 entry:
891   %a = call <vscale x 8 x i8> @llvm.riscv.vnclip.nxv8i8.nxv8i16(
892     <vscale x 8 x i8> undef,
893     <vscale x 8 x i16> %0,
894     iXLen %1,
895     iXLen 0, iXLen %2)
897   ret <vscale x 8 x i8> %a
900 declare <vscale x 8 x i8> @llvm.riscv.vnclip.mask.nxv8i8.nxv8i16(
901   <vscale x 8 x i8>,
902   <vscale x 8 x i16>,
903   iXLen,
904   <vscale x 8 x i1>,
905   iXLen, iXLen, iXLen);
907 define <vscale x 8 x i8> @intrinsic_vnclip_mask_vx_nxv8i8_nxv8i16(<vscale x 8 x i8> %0, <vscale x 8 x i16> %1, iXLen %2, <vscale x 8 x i1> %3, iXLen %4) nounwind {
908 ; CHECK-LABEL: intrinsic_vnclip_mask_vx_nxv8i8_nxv8i16:
909 ; CHECK:       # %bb.0: # %entry
910 ; CHECK-NEXT:    vsetvli zero, a1, e8, m1, ta, mu
911 ; CHECK-NEXT:    csrwi vxrm, 0
912 ; CHECK-NEXT:    vnclip.wx v8, v10, a0, v0.t
913 ; CHECK-NEXT:    ret
914 entry:
915   %a = call <vscale x 8 x i8> @llvm.riscv.vnclip.mask.nxv8i8.nxv8i16(
916     <vscale x 8 x i8> %0,
917     <vscale x 8 x i16> %1,
918     iXLen %2,
919     <vscale x 8 x i1> %3,
920     iXLen 0, iXLen %4, iXLen 1)
922   ret <vscale x 8 x i8> %a
925 declare <vscale x 16 x i8> @llvm.riscv.vnclip.nxv16i8.nxv16i16(
926   <vscale x 16 x i8>,
927   <vscale x 16 x i16>,
928   iXLen, iXLen, iXLen);
930 define <vscale x 16 x i8> @intrinsic_vnclip_vx_nxv16i8_nxv16i16(<vscale x 16 x i16> %0, iXLen %1, iXLen %2) nounwind {
931 ; CHECK-LABEL: intrinsic_vnclip_vx_nxv16i8_nxv16i16:
932 ; CHECK:       # %bb.0: # %entry
933 ; CHECK-NEXT:    vsetvli zero, a1, e8, m2, ta, ma
934 ; CHECK-NEXT:    csrwi vxrm, 0
935 ; CHECK-NEXT:    vnclip.wx v12, v8, a0
936 ; CHECK-NEXT:    vmv.v.v v8, v12
937 ; CHECK-NEXT:    ret
938 entry:
939   %a = call <vscale x 16 x i8> @llvm.riscv.vnclip.nxv16i8.nxv16i16(
940     <vscale x 16 x i8> undef,
941     <vscale x 16 x i16> %0,
942     iXLen %1,
943     iXLen 0, iXLen %2)
945   ret <vscale x 16 x i8> %a
948 declare <vscale x 16 x i8> @llvm.riscv.vnclip.mask.nxv16i8.nxv16i16(
949   <vscale x 16 x i8>,
950   <vscale x 16 x i16>,
951   iXLen,
952   <vscale x 16 x i1>,
953   iXLen, iXLen, iXLen);
955 define <vscale x 16 x i8> @intrinsic_vnclip_mask_vx_nxv16i8_nxv16i16(<vscale x 16 x i8> %0, <vscale x 16 x i16> %1, iXLen %2, <vscale x 16 x i1> %3, iXLen %4) nounwind {
956 ; CHECK-LABEL: intrinsic_vnclip_mask_vx_nxv16i8_nxv16i16:
957 ; CHECK:       # %bb.0: # %entry
958 ; CHECK-NEXT:    vsetvli zero, a1, e8, m2, ta, mu
959 ; CHECK-NEXT:    csrwi vxrm, 0
960 ; CHECK-NEXT:    vnclip.wx v8, v12, a0, v0.t
961 ; CHECK-NEXT:    ret
962 entry:
963   %a = call <vscale x 16 x i8> @llvm.riscv.vnclip.mask.nxv16i8.nxv16i16(
964     <vscale x 16 x i8> %0,
965     <vscale x 16 x i16> %1,
966     iXLen %2,
967     <vscale x 16 x i1> %3,
968     iXLen 0, iXLen %4, iXLen 1)
970   ret <vscale x 16 x i8> %a
973 declare <vscale x 32 x i8> @llvm.riscv.vnclip.nxv32i8.nxv32i16(
974   <vscale x 32 x i8>,
975   <vscale x 32 x i16>,
976   iXLen, iXLen, iXLen);
978 define <vscale x 32 x i8> @intrinsic_vnclip_vx_nxv32i8_nxv32i16(<vscale x 32 x i16> %0, iXLen %1, iXLen %2) nounwind {
979 ; CHECK-LABEL: intrinsic_vnclip_vx_nxv32i8_nxv32i16:
980 ; CHECK:       # %bb.0: # %entry
981 ; CHECK-NEXT:    vsetvli zero, a1, e8, m4, ta, ma
982 ; CHECK-NEXT:    csrwi vxrm, 0
983 ; CHECK-NEXT:    vnclip.wx v16, v8, a0
984 ; CHECK-NEXT:    vmv.v.v v8, v16
985 ; CHECK-NEXT:    ret
986 entry:
987   %a = call <vscale x 32 x i8> @llvm.riscv.vnclip.nxv32i8.nxv32i16(
988     <vscale x 32 x i8> undef,
989     <vscale x 32 x i16> %0,
990     iXLen %1,
991     iXLen 0, iXLen %2)
993   ret <vscale x 32 x i8> %a
996 declare <vscale x 32 x i8> @llvm.riscv.vnclip.mask.nxv32i8.nxv32i16(
997   <vscale x 32 x i8>,
998   <vscale x 32 x i16>,
999   iXLen,
1000   <vscale x 32 x i1>,
1001   iXLen, iXLen, iXLen);
1003 define <vscale x 32 x i8> @intrinsic_vnclip_mask_vx_nxv32i8_nxv32i16(<vscale x 32 x i8> %0, <vscale x 32 x i16> %1, iXLen %2, <vscale x 32 x i1> %3, iXLen %4) nounwind {
1004 ; CHECK-LABEL: intrinsic_vnclip_mask_vx_nxv32i8_nxv32i16:
1005 ; CHECK:       # %bb.0: # %entry
1006 ; CHECK-NEXT:    vsetvli zero, a1, e8, m4, ta, mu
1007 ; CHECK-NEXT:    csrwi vxrm, 0
1008 ; CHECK-NEXT:    vnclip.wx v8, v16, a0, v0.t
1009 ; CHECK-NEXT:    ret
1010 entry:
1011   %a = call <vscale x 32 x i8> @llvm.riscv.vnclip.mask.nxv32i8.nxv32i16(
1012     <vscale x 32 x i8> %0,
1013     <vscale x 32 x i16> %1,
1014     iXLen %2,
1015     <vscale x 32 x i1> %3,
1016     iXLen 0, iXLen %4, iXLen 1)
1018   ret <vscale x 32 x i8> %a
1021 declare <vscale x 1 x i16> @llvm.riscv.vnclip.nxv1i16.nxv1i32(
1022   <vscale x 1 x i16>,
1023   <vscale x 1 x i32>,
1024   iXLen, iXLen, iXLen);
1026 define <vscale x 1 x i16> @intrinsic_vnclip_vx_nxv1i16_nxv1i32(<vscale x 1 x i32> %0, iXLen %1, iXLen %2) nounwind {
1027 ; CHECK-LABEL: intrinsic_vnclip_vx_nxv1i16_nxv1i32:
1028 ; CHECK:       # %bb.0: # %entry
1029 ; CHECK-NEXT:    vsetvli zero, a1, e16, mf4, ta, ma
1030 ; CHECK-NEXT:    csrwi vxrm, 0
1031 ; CHECK-NEXT:    vnclip.wx v8, v8, a0
1032 ; CHECK-NEXT:    ret
1033 entry:
1034   %a = call <vscale x 1 x i16> @llvm.riscv.vnclip.nxv1i16.nxv1i32(
1035     <vscale x 1 x i16> undef,
1036     <vscale x 1 x i32> %0,
1037     iXLen %1,
1038     iXLen 0, iXLen %2)
1040   ret <vscale x 1 x i16> %a
1043 declare <vscale x 1 x i16> @llvm.riscv.vnclip.mask.nxv1i16.nxv1i32(
1044   <vscale x 1 x i16>,
1045   <vscale x 1 x i32>,
1046   iXLen,
1047   <vscale x 1 x i1>,
1048   iXLen, iXLen, iXLen);
1050 define <vscale x 1 x i16> @intrinsic_vnclip_mask_vx_nxv1i16_nxv1i32(<vscale x 1 x i16> %0, <vscale x 1 x i32> %1, iXLen %2, <vscale x 1 x i1> %3, iXLen %4) nounwind {
1051 ; CHECK-LABEL: intrinsic_vnclip_mask_vx_nxv1i16_nxv1i32:
1052 ; CHECK:       # %bb.0: # %entry
1053 ; CHECK-NEXT:    vsetvli zero, a1, e16, mf4, ta, mu
1054 ; CHECK-NEXT:    csrwi vxrm, 0
1055 ; CHECK-NEXT:    vnclip.wx v8, v9, a0, v0.t
1056 ; CHECK-NEXT:    ret
1057 entry:
1058   %a = call <vscale x 1 x i16> @llvm.riscv.vnclip.mask.nxv1i16.nxv1i32(
1059     <vscale x 1 x i16> %0,
1060     <vscale x 1 x i32> %1,
1061     iXLen %2,
1062     <vscale x 1 x i1> %3,
1063     iXLen 0, iXLen %4, iXLen 1)
1065   ret <vscale x 1 x i16> %a
1068 declare <vscale x 2 x i16> @llvm.riscv.vnclip.nxv2i16.nxv2i32(
1069   <vscale x 2 x i16>,
1070   <vscale x 2 x i32>,
1071   iXLen, iXLen, iXLen);
1073 define <vscale x 2 x i16> @intrinsic_vnclip_vx_nxv2i16_nxv2i32(<vscale x 2 x i32> %0, iXLen %1, iXLen %2) nounwind {
1074 ; CHECK-LABEL: intrinsic_vnclip_vx_nxv2i16_nxv2i32:
1075 ; CHECK:       # %bb.0: # %entry
1076 ; CHECK-NEXT:    vsetvli zero, a1, e16, mf2, ta, ma
1077 ; CHECK-NEXT:    csrwi vxrm, 0
1078 ; CHECK-NEXT:    vnclip.wx v8, v8, a0
1079 ; CHECK-NEXT:    ret
1080 entry:
1081   %a = call <vscale x 2 x i16> @llvm.riscv.vnclip.nxv2i16.nxv2i32(
1082     <vscale x 2 x i16> undef,
1083     <vscale x 2 x i32> %0,
1084     iXLen %1,
1085     iXLen 0, iXLen %2)
1087   ret <vscale x 2 x i16> %a
1090 declare <vscale x 2 x i16> @llvm.riscv.vnclip.mask.nxv2i16.nxv2i32(
1091   <vscale x 2 x i16>,
1092   <vscale x 2 x i32>,
1093   iXLen,
1094   <vscale x 2 x i1>,
1095   iXLen, iXLen, iXLen);
1097 define <vscale x 2 x i16> @intrinsic_vnclip_mask_vx_nxv2i16_nxv2i32(<vscale x 2 x i16> %0, <vscale x 2 x i32> %1, iXLen %2, <vscale x 2 x i1> %3, iXLen %4) nounwind {
1098 ; CHECK-LABEL: intrinsic_vnclip_mask_vx_nxv2i16_nxv2i32:
1099 ; CHECK:       # %bb.0: # %entry
1100 ; CHECK-NEXT:    vsetvli zero, a1, e16, mf2, ta, mu
1101 ; CHECK-NEXT:    csrwi vxrm, 0
1102 ; CHECK-NEXT:    vnclip.wx v8, v9, a0, v0.t
1103 ; CHECK-NEXT:    ret
1104 entry:
1105   %a = call <vscale x 2 x i16> @llvm.riscv.vnclip.mask.nxv2i16.nxv2i32(
1106     <vscale x 2 x i16> %0,
1107     <vscale x 2 x i32> %1,
1108     iXLen %2,
1109     <vscale x 2 x i1> %3,
1110     iXLen 0, iXLen %4, iXLen 1)
1112   ret <vscale x 2 x i16> %a
1115 declare <vscale x 4 x i16> @llvm.riscv.vnclip.nxv4i16.nxv4i32(
1116   <vscale x 4 x i16>,
1117   <vscale x 4 x i32>,
1118   iXLen, iXLen, iXLen);
1120 define <vscale x 4 x i16> @intrinsic_vnclip_vx_nxv4i16_nxv4i32(<vscale x 4 x i32> %0, iXLen %1, iXLen %2) nounwind {
1121 ; CHECK-LABEL: intrinsic_vnclip_vx_nxv4i16_nxv4i32:
1122 ; CHECK:       # %bb.0: # %entry
1123 ; CHECK-NEXT:    vsetvli zero, a1, e16, m1, ta, ma
1124 ; CHECK-NEXT:    csrwi vxrm, 0
1125 ; CHECK-NEXT:    vnclip.wx v10, v8, a0
1126 ; CHECK-NEXT:    vmv.v.v v8, v10
1127 ; CHECK-NEXT:    ret
1128 entry:
1129   %a = call <vscale x 4 x i16> @llvm.riscv.vnclip.nxv4i16.nxv4i32(
1130     <vscale x 4 x i16> undef,
1131     <vscale x 4 x i32> %0,
1132     iXLen %1,
1133     iXLen 0, iXLen %2)
1135   ret <vscale x 4 x i16> %a
1138 declare <vscale x 4 x i16> @llvm.riscv.vnclip.mask.nxv4i16.nxv4i32(
1139   <vscale x 4 x i16>,
1140   <vscale x 4 x i32>,
1141   iXLen,
1142   <vscale x 4 x i1>,
1143   iXLen, iXLen, iXLen);
1145 define <vscale x 4 x i16> @intrinsic_vnclip_mask_vx_nxv4i16_nxv4i32(<vscale x 4 x i16> %0, <vscale x 4 x i32> %1, iXLen %2, <vscale x 4 x i1> %3, iXLen %4) nounwind {
1146 ; CHECK-LABEL: intrinsic_vnclip_mask_vx_nxv4i16_nxv4i32:
1147 ; CHECK:       # %bb.0: # %entry
1148 ; CHECK-NEXT:    vsetvli zero, a1, e16, m1, ta, mu
1149 ; CHECK-NEXT:    csrwi vxrm, 0
1150 ; CHECK-NEXT:    vnclip.wx v8, v10, a0, v0.t
1151 ; CHECK-NEXT:    ret
1152 entry:
1153   %a = call <vscale x 4 x i16> @llvm.riscv.vnclip.mask.nxv4i16.nxv4i32(
1154     <vscale x 4 x i16> %0,
1155     <vscale x 4 x i32> %1,
1156     iXLen %2,
1157     <vscale x 4 x i1> %3,
1158     iXLen 0, iXLen %4, iXLen 1)
1160   ret <vscale x 4 x i16> %a
1163 declare <vscale x 8 x i16> @llvm.riscv.vnclip.nxv8i16.nxv8i32(
1164   <vscale x 8 x i16>,
1165   <vscale x 8 x i32>,
1166   iXLen, iXLen, iXLen);
1168 define <vscale x 8 x i16> @intrinsic_vnclip_vx_nxv8i16_nxv8i32(<vscale x 8 x i32> %0, iXLen %1, iXLen %2) nounwind {
1169 ; CHECK-LABEL: intrinsic_vnclip_vx_nxv8i16_nxv8i32:
1170 ; CHECK:       # %bb.0: # %entry
1171 ; CHECK-NEXT:    vsetvli zero, a1, e16, m2, ta, ma
1172 ; CHECK-NEXT:    csrwi vxrm, 0
1173 ; CHECK-NEXT:    vnclip.wx v12, v8, a0
1174 ; CHECK-NEXT:    vmv.v.v v8, v12
1175 ; CHECK-NEXT:    ret
1176 entry:
1177   %a = call <vscale x 8 x i16> @llvm.riscv.vnclip.nxv8i16.nxv8i32(
1178     <vscale x 8 x i16> undef,
1179     <vscale x 8 x i32> %0,
1180     iXLen %1,
1181     iXLen 0, iXLen %2)
1183   ret <vscale x 8 x i16> %a
1186 declare <vscale x 8 x i16> @llvm.riscv.vnclip.mask.nxv8i16.nxv8i32(
1187   <vscale x 8 x i16>,
1188   <vscale x 8 x i32>,
1189   iXLen,
1190   <vscale x 8 x i1>,
1191   iXLen, iXLen, iXLen);
1193 define <vscale x 8 x i16> @intrinsic_vnclip_mask_vx_nxv8i16_nxv8i32(<vscale x 8 x i16> %0, <vscale x 8 x i32> %1, iXLen %2, <vscale x 8 x i1> %3, iXLen %4) nounwind {
1194 ; CHECK-LABEL: intrinsic_vnclip_mask_vx_nxv8i16_nxv8i32:
1195 ; CHECK:       # %bb.0: # %entry
1196 ; CHECK-NEXT:    vsetvli zero, a1, e16, m2, ta, mu
1197 ; CHECK-NEXT:    csrwi vxrm, 0
1198 ; CHECK-NEXT:    vnclip.wx v8, v12, a0, v0.t
1199 ; CHECK-NEXT:    ret
1200 entry:
1201   %a = call <vscale x 8 x i16> @llvm.riscv.vnclip.mask.nxv8i16.nxv8i32(
1202     <vscale x 8 x i16> %0,
1203     <vscale x 8 x i32> %1,
1204     iXLen %2,
1205     <vscale x 8 x i1> %3,
1206     iXLen 0, iXLen %4, iXLen 1)
1208   ret <vscale x 8 x i16> %a
1211 declare <vscale x 16 x i16> @llvm.riscv.vnclip.nxv16i16.nxv16i32(
1212   <vscale x 16 x i16>,
1213   <vscale x 16 x i32>,
1214   iXLen, iXLen, iXLen);
1216 define <vscale x 16 x i16> @intrinsic_vnclip_vx_nxv16i16_nxv16i32(<vscale x 16 x i32> %0, iXLen %1, iXLen %2) nounwind {
1217 ; CHECK-LABEL: intrinsic_vnclip_vx_nxv16i16_nxv16i32:
1218 ; CHECK:       # %bb.0: # %entry
1219 ; CHECK-NEXT:    vsetvli zero, a1, e16, m4, ta, ma
1220 ; CHECK-NEXT:    csrwi vxrm, 0
1221 ; CHECK-NEXT:    vnclip.wx v16, v8, a0
1222 ; CHECK-NEXT:    vmv.v.v v8, v16
1223 ; CHECK-NEXT:    ret
1224 entry:
1225   %a = call <vscale x 16 x i16> @llvm.riscv.vnclip.nxv16i16.nxv16i32(
1226     <vscale x 16 x i16> undef,
1227     <vscale x 16 x i32> %0,
1228     iXLen %1,
1229     iXLen 0, iXLen %2)
1231   ret <vscale x 16 x i16> %a
1234 declare <vscale x 16 x i16> @llvm.riscv.vnclip.mask.nxv16i16.nxv16i32(
1235   <vscale x 16 x i16>,
1236   <vscale x 16 x i32>,
1237   iXLen,
1238   <vscale x 16 x i1>,
1239   iXLen, iXLen, iXLen);
1241 define <vscale x 16 x i16> @intrinsic_vnclip_mask_vx_nxv16i16_nxv16i32(<vscale x 16 x i16> %0, <vscale x 16 x i32> %1, iXLen %2, <vscale x 16 x i1> %3, iXLen %4) nounwind {
1242 ; CHECK-LABEL: intrinsic_vnclip_mask_vx_nxv16i16_nxv16i32:
1243 ; CHECK:       # %bb.0: # %entry
1244 ; CHECK-NEXT:    vsetvli zero, a1, e16, m4, ta, mu
1245 ; CHECK-NEXT:    csrwi vxrm, 0
1246 ; CHECK-NEXT:    vnclip.wx v8, v16, a0, v0.t
1247 ; CHECK-NEXT:    ret
1248 entry:
1249   %a = call <vscale x 16 x i16> @llvm.riscv.vnclip.mask.nxv16i16.nxv16i32(
1250     <vscale x 16 x i16> %0,
1251     <vscale x 16 x i32> %1,
1252     iXLen %2,
1253     <vscale x 16 x i1> %3,
1254     iXLen 0, iXLen %4, iXLen 1)
1256   ret <vscale x 16 x i16> %a
1259 declare <vscale x 1 x i32> @llvm.riscv.vnclip.nxv1i32.nxv1i64(
1260   <vscale x 1 x i32>,
1261   <vscale x 1 x i64>,
1262   iXLen, iXLen, iXLen);
1264 define <vscale x 1 x i32> @intrinsic_vnclip_vx_nxv1i32_nxv1i64(<vscale x 1 x i64> %0, iXLen %1, iXLen %2) nounwind {
1265 ; CHECK-LABEL: intrinsic_vnclip_vx_nxv1i32_nxv1i64:
1266 ; CHECK:       # %bb.0: # %entry
1267 ; CHECK-NEXT:    vsetvli zero, a1, e32, mf2, ta, ma
1268 ; CHECK-NEXT:    csrwi vxrm, 0
1269 ; CHECK-NEXT:    vnclip.wx v8, v8, a0
1270 ; CHECK-NEXT:    ret
1271 entry:
1272   %a = call <vscale x 1 x i32> @llvm.riscv.vnclip.nxv1i32.nxv1i64(
1273     <vscale x 1 x i32> undef,
1274     <vscale x 1 x i64> %0,
1275     iXLen %1,
1276     iXLen 0, iXLen %2)
1278   ret <vscale x 1 x i32> %a
1281 declare <vscale x 1 x i32> @llvm.riscv.vnclip.mask.nxv1i32.nxv1i64(
1282   <vscale x 1 x i32>,
1283   <vscale x 1 x i64>,
1284   iXLen,
1285   <vscale x 1 x i1>,
1286   iXLen, iXLen, iXLen);
1288 define <vscale x 1 x i32> @intrinsic_vnclip_mask_vx_nxv1i32_nxv1i64(<vscale x 1 x i32> %0, <vscale x 1 x i64> %1, iXLen %2, <vscale x 1 x i1> %3, iXLen %4) nounwind {
1289 ; CHECK-LABEL: intrinsic_vnclip_mask_vx_nxv1i32_nxv1i64:
1290 ; CHECK:       # %bb.0: # %entry
1291 ; CHECK-NEXT:    vsetvli zero, a1, e32, mf2, ta, mu
1292 ; CHECK-NEXT:    csrwi vxrm, 0
1293 ; CHECK-NEXT:    vnclip.wx v8, v9, a0, v0.t
1294 ; CHECK-NEXT:    ret
1295 entry:
1296   %a = call <vscale x 1 x i32> @llvm.riscv.vnclip.mask.nxv1i32.nxv1i64(
1297     <vscale x 1 x i32> %0,
1298     <vscale x 1 x i64> %1,
1299     iXLen %2,
1300     <vscale x 1 x i1> %3,
1301     iXLen 0, iXLen %4, iXLen 1)
1303   ret <vscale x 1 x i32> %a
1306 declare <vscale x 2 x i32> @llvm.riscv.vnclip.nxv2i32.nxv2i64(
1307   <vscale x 2 x i32>,
1308   <vscale x 2 x i64>,
1309   iXLen, iXLen, iXLen);
1311 define <vscale x 2 x i32> @intrinsic_vnclip_vx_nxv2i32_nxv2i64(<vscale x 2 x i64> %0, iXLen %1, iXLen %2) nounwind {
1312 ; CHECK-LABEL: intrinsic_vnclip_vx_nxv2i32_nxv2i64:
1313 ; CHECK:       # %bb.0: # %entry
1314 ; CHECK-NEXT:    vsetvli zero, a1, e32, m1, ta, ma
1315 ; CHECK-NEXT:    csrwi vxrm, 0
1316 ; CHECK-NEXT:    vnclip.wx v10, v8, a0
1317 ; CHECK-NEXT:    vmv.v.v v8, v10
1318 ; CHECK-NEXT:    ret
1319 entry:
1320   %a = call <vscale x 2 x i32> @llvm.riscv.vnclip.nxv2i32.nxv2i64(
1321     <vscale x 2 x i32> undef,
1322     <vscale x 2 x i64> %0,
1323     iXLen %1,
1324     iXLen 0, iXLen %2)
1326   ret <vscale x 2 x i32> %a
1329 declare <vscale x 2 x i32> @llvm.riscv.vnclip.mask.nxv2i32.nxv2i64(
1330   <vscale x 2 x i32>,
1331   <vscale x 2 x i64>,
1332   iXLen,
1333   <vscale x 2 x i1>,
1334   iXLen, iXLen, iXLen);
1336 define <vscale x 2 x i32> @intrinsic_vnclip_mask_vx_nxv2i32_nxv2i64(<vscale x 2 x i32> %0, <vscale x 2 x i64> %1, iXLen %2, <vscale x 2 x i1> %3, iXLen %4) nounwind {
1337 ; CHECK-LABEL: intrinsic_vnclip_mask_vx_nxv2i32_nxv2i64:
1338 ; CHECK:       # %bb.0: # %entry
1339 ; CHECK-NEXT:    vsetvli zero, a1, e32, m1, ta, mu
1340 ; CHECK-NEXT:    csrwi vxrm, 0
1341 ; CHECK-NEXT:    vnclip.wx v8, v10, a0, v0.t
1342 ; CHECK-NEXT:    ret
1343 entry:
1344   %a = call <vscale x 2 x i32> @llvm.riscv.vnclip.mask.nxv2i32.nxv2i64(
1345     <vscale x 2 x i32> %0,
1346     <vscale x 2 x i64> %1,
1347     iXLen %2,
1348     <vscale x 2 x i1> %3,
1349     iXLen 0, iXLen %4, iXLen 1)
1351   ret <vscale x 2 x i32> %a
1354 declare <vscale x 4 x i32> @llvm.riscv.vnclip.nxv4i32.nxv4i64(
1355   <vscale x 4 x i32>,
1356   <vscale x 4 x i64>,
1357   iXLen, iXLen, iXLen);
1359 define <vscale x 4 x i32> @intrinsic_vnclip_vx_nxv4i32_nxv4i64(<vscale x 4 x i64> %0, iXLen %1, iXLen %2) nounwind {
1360 ; CHECK-LABEL: intrinsic_vnclip_vx_nxv4i32_nxv4i64:
1361 ; CHECK:       # %bb.0: # %entry
1362 ; CHECK-NEXT:    vsetvli zero, a1, e32, m2, ta, ma
1363 ; CHECK-NEXT:    csrwi vxrm, 0
1364 ; CHECK-NEXT:    vnclip.wx v12, v8, a0
1365 ; CHECK-NEXT:    vmv.v.v v8, v12
1366 ; CHECK-NEXT:    ret
1367 entry:
1368   %a = call <vscale x 4 x i32> @llvm.riscv.vnclip.nxv4i32.nxv4i64(
1369     <vscale x 4 x i32> undef,
1370     <vscale x 4 x i64> %0,
1371     iXLen %1,
1372     iXLen 0, iXLen %2)
1374   ret <vscale x 4 x i32> %a
1377 declare <vscale x 4 x i32> @llvm.riscv.vnclip.mask.nxv4i32.nxv4i64(
1378   <vscale x 4 x i32>,
1379   <vscale x 4 x i64>,
1380   iXLen,
1381   <vscale x 4 x i1>,
1382   iXLen, iXLen, iXLen);
1384 define <vscale x 4 x i32> @intrinsic_vnclip_mask_vx_nxv4i32_nxv4i64(<vscale x 4 x i32> %0, <vscale x 4 x i64> %1, iXLen %2, <vscale x 4 x i1> %3, iXLen %4) nounwind {
1385 ; CHECK-LABEL: intrinsic_vnclip_mask_vx_nxv4i32_nxv4i64:
1386 ; CHECK:       # %bb.0: # %entry
1387 ; CHECK-NEXT:    vsetvli zero, a1, e32, m2, ta, mu
1388 ; CHECK-NEXT:    csrwi vxrm, 0
1389 ; CHECK-NEXT:    vnclip.wx v8, v12, a0, v0.t
1390 ; CHECK-NEXT:    ret
1391 entry:
1392   %a = call <vscale x 4 x i32> @llvm.riscv.vnclip.mask.nxv4i32.nxv4i64(
1393     <vscale x 4 x i32> %0,
1394     <vscale x 4 x i64> %1,
1395     iXLen %2,
1396     <vscale x 4 x i1> %3,
1397     iXLen 0, iXLen %4, iXLen 1)
1399   ret <vscale x 4 x i32> %a
1402 declare <vscale x 8 x i32> @llvm.riscv.vnclip.nxv8i32.nxv8i64(
1403   <vscale x 8 x i32>,
1404   <vscale x 8 x i64>,
1405   iXLen, iXLen, iXLen);
1407 define <vscale x 8 x i32> @intrinsic_vnclip_vx_nxv8i32_nxv8i64(<vscale x 8 x i64> %0, iXLen %1, iXLen %2) nounwind {
1408 ; CHECK-LABEL: intrinsic_vnclip_vx_nxv8i32_nxv8i64:
1409 ; CHECK:       # %bb.0: # %entry
1410 ; CHECK-NEXT:    vsetvli zero, a1, e32, m4, ta, ma
1411 ; CHECK-NEXT:    csrwi vxrm, 0
1412 ; CHECK-NEXT:    vnclip.wx v16, v8, a0
1413 ; CHECK-NEXT:    vmv.v.v v8, v16
1414 ; CHECK-NEXT:    ret
1415 entry:
1416   %a = call <vscale x 8 x i32> @llvm.riscv.vnclip.nxv8i32.nxv8i64(
1417     <vscale x 8 x i32> undef,
1418     <vscale x 8 x i64> %0,
1419     iXLen %1,
1420     iXLen 0, iXLen %2)
1422   ret <vscale x 8 x i32> %a
1425 declare <vscale x 8 x i32> @llvm.riscv.vnclip.mask.nxv8i32.nxv8i64(
1426   <vscale x 8 x i32>,
1427   <vscale x 8 x i64>,
1428   iXLen,
1429   <vscale x 8 x i1>,
1430   iXLen, iXLen, iXLen);
1432 define <vscale x 8 x i32> @intrinsic_vnclip_mask_vx_nxv8i32_nxv8i64(<vscale x 8 x i32> %0, <vscale x 8 x i64> %1, iXLen %2, <vscale x 8 x i1> %3, iXLen %4) nounwind {
1433 ; CHECK-LABEL: intrinsic_vnclip_mask_vx_nxv8i32_nxv8i64:
1434 ; CHECK:       # %bb.0: # %entry
1435 ; CHECK-NEXT:    vsetvli zero, a1, e32, m4, ta, mu
1436 ; CHECK-NEXT:    csrwi vxrm, 0
1437 ; CHECK-NEXT:    vnclip.wx v8, v16, a0, v0.t
1438 ; CHECK-NEXT:    ret
1439 entry:
1440   %a = call <vscale x 8 x i32> @llvm.riscv.vnclip.mask.nxv8i32.nxv8i64(
1441     <vscale x 8 x i32> %0,
1442     <vscale x 8 x i64> %1,
1443     iXLen %2,
1444     <vscale x 8 x i1> %3,
1445     iXLen 0, iXLen %4, iXLen 1)
1447   ret <vscale x 8 x i32> %a
1450 define <vscale x 1 x i8> @intrinsic_vnclip_vi_nxv1i8_nxv1i16_i8(<vscale x 1 x i16> %0, iXLen %1) nounwind {
1451 ; CHECK-LABEL: intrinsic_vnclip_vi_nxv1i8_nxv1i16_i8:
1452 ; CHECK:       # %bb.0: # %entry
1453 ; CHECK-NEXT:    vsetvli zero, a0, e8, mf8, ta, ma
1454 ; CHECK-NEXT:    csrwi vxrm, 0
1455 ; CHECK-NEXT:    vnclip.wi v8, v8, 9
1456 ; CHECK-NEXT:    ret
1457 entry:
1458   %a = call <vscale x 1 x i8> @llvm.riscv.vnclip.nxv1i8.nxv1i16(
1459     <vscale x 1 x i8> undef,
1460     <vscale x 1 x i16> %0,
1461     iXLen 9,
1462     iXLen 0, iXLen %1)
1464   ret <vscale x 1 x i8> %a
1467 define <vscale x 1 x i8> @intrinsic_vnclip_mask_vi_nxv1i8_nxv1i16_i8(<vscale x 1 x i8> %0, <vscale x 1 x i16> %1, <vscale x 1 x i1> %2, iXLen %3) nounwind {
1468 ; CHECK-LABEL: intrinsic_vnclip_mask_vi_nxv1i8_nxv1i16_i8:
1469 ; CHECK:       # %bb.0: # %entry
1470 ; CHECK-NEXT:    vsetvli zero, a0, e8, mf8, ta, mu
1471 ; CHECK-NEXT:    csrwi vxrm, 0
1472 ; CHECK-NEXT:    vnclip.wi v8, v9, 9, v0.t
1473 ; CHECK-NEXT:    ret
1474 entry:
1475   %a = call <vscale x 1 x i8> @llvm.riscv.vnclip.mask.nxv1i8.nxv1i16(
1476     <vscale x 1 x i8> %0,
1477     <vscale x 1 x i16> %1,
1478     iXLen 9,
1479     <vscale x 1 x i1> %2,
1480     iXLen 0, iXLen %3, iXLen 1)
1482   ret <vscale x 1 x i8> %a
1485 define <vscale x 2 x i8> @intrinsic_vnclip_vi_nxv2i8_nxv2i16_i8(<vscale x 2 x i16> %0, iXLen %1) nounwind {
1486 ; CHECK-LABEL: intrinsic_vnclip_vi_nxv2i8_nxv2i16_i8:
1487 ; CHECK:       # %bb.0: # %entry
1488 ; CHECK-NEXT:    vsetvli zero, a0, e8, mf4, ta, ma
1489 ; CHECK-NEXT:    csrwi vxrm, 0
1490 ; CHECK-NEXT:    vnclip.wi v8, v8, 9
1491 ; CHECK-NEXT:    ret
1492 entry:
1493   %a = call <vscale x 2 x i8> @llvm.riscv.vnclip.nxv2i8.nxv2i16(
1494     <vscale x 2 x i8> undef,
1495     <vscale x 2 x i16> %0,
1496     iXLen 9,
1497     iXLen 0, iXLen %1)
1499   ret <vscale x 2 x i8> %a
1502 define <vscale x 2 x i8> @intrinsic_vnclip_mask_vi_nxv2i8_nxv2i16_i8(<vscale x 2 x i8> %0, <vscale x 2 x i16> %1, <vscale x 2 x i1> %2, iXLen %3) nounwind {
1503 ; CHECK-LABEL: intrinsic_vnclip_mask_vi_nxv2i8_nxv2i16_i8:
1504 ; CHECK:       # %bb.0: # %entry
1505 ; CHECK-NEXT:    vsetvli zero, a0, e8, mf4, ta, mu
1506 ; CHECK-NEXT:    csrwi vxrm, 0
1507 ; CHECK-NEXT:    vnclip.wi v8, v9, 9, v0.t
1508 ; CHECK-NEXT:    ret
1509 entry:
1510   %a = call <vscale x 2 x i8> @llvm.riscv.vnclip.mask.nxv2i8.nxv2i16(
1511     <vscale x 2 x i8> %0,
1512     <vscale x 2 x i16> %1,
1513     iXLen 9,
1514     <vscale x 2 x i1> %2,
1515     iXLen 0, iXLen %3, iXLen 1)
1517   ret <vscale x 2 x i8> %a
1520 define <vscale x 4 x i8> @intrinsic_vnclip_vi_nxv4i8_nxv4i16_i8(<vscale x 4 x i16> %0, iXLen %1) nounwind {
1521 ; CHECK-LABEL: intrinsic_vnclip_vi_nxv4i8_nxv4i16_i8:
1522 ; CHECK:       # %bb.0: # %entry
1523 ; CHECK-NEXT:    vsetvli zero, a0, e8, mf2, ta, ma
1524 ; CHECK-NEXT:    csrwi vxrm, 0
1525 ; CHECK-NEXT:    vnclip.wi v8, v8, 9
1526 ; CHECK-NEXT:    ret
1527 entry:
1528   %a = call <vscale x 4 x i8> @llvm.riscv.vnclip.nxv4i8.nxv4i16(
1529     <vscale x 4 x i8> undef,
1530     <vscale x 4 x i16> %0,
1531     iXLen 9,
1532     iXLen 0, iXLen %1)
1534   ret <vscale x 4 x i8> %a
1537 define <vscale x 4 x i8> @intrinsic_vnclip_mask_vi_nxv4i8_nxv4i16_i8(<vscale x 4 x i8> %0, <vscale x 4 x i16> %1, <vscale x 4 x i1> %2, iXLen %3) nounwind {
1538 ; CHECK-LABEL: intrinsic_vnclip_mask_vi_nxv4i8_nxv4i16_i8:
1539 ; CHECK:       # %bb.0: # %entry
1540 ; CHECK-NEXT:    vsetvli zero, a0, e8, mf2, ta, mu
1541 ; CHECK-NEXT:    csrwi vxrm, 0
1542 ; CHECK-NEXT:    vnclip.wi v8, v9, 9, v0.t
1543 ; CHECK-NEXT:    ret
1544 entry:
1545   %a = call <vscale x 4 x i8> @llvm.riscv.vnclip.mask.nxv4i8.nxv4i16(
1546     <vscale x 4 x i8> %0,
1547     <vscale x 4 x i16> %1,
1548     iXLen 9,
1549     <vscale x 4 x i1> %2,
1550     iXLen 0, iXLen %3, iXLen 1)
1552   ret <vscale x 4 x i8> %a
1555 define <vscale x 8 x i8> @intrinsic_vnclip_vi_nxv8i8_nxv8i16_i8(<vscale x 8 x i16> %0, iXLen %1) nounwind {
1556 ; CHECK-LABEL: intrinsic_vnclip_vi_nxv8i8_nxv8i16_i8:
1557 ; CHECK:       # %bb.0: # %entry
1558 ; CHECK-NEXT:    vsetvli zero, a0, e8, m1, ta, ma
1559 ; CHECK-NEXT:    csrwi vxrm, 0
1560 ; CHECK-NEXT:    vnclip.wi v10, v8, 9
1561 ; CHECK-NEXT:    vmv.v.v v8, v10
1562 ; CHECK-NEXT:    ret
1563 entry:
1564   %a = call <vscale x 8 x i8> @llvm.riscv.vnclip.nxv8i8.nxv8i16(
1565     <vscale x 8 x i8> undef,
1566     <vscale x 8 x i16> %0,
1567     iXLen 9,
1568     iXLen 0, iXLen %1)
1570   ret <vscale x 8 x i8> %a
1573 define <vscale x 8 x i8> @intrinsic_vnclip_mask_vi_nxv8i8_nxv8i16_i8(<vscale x 8 x i8> %0, <vscale x 8 x i16> %1, <vscale x 8 x i1> %2, iXLen %3) nounwind {
1574 ; CHECK-LABEL: intrinsic_vnclip_mask_vi_nxv8i8_nxv8i16_i8:
1575 ; CHECK:       # %bb.0: # %entry
1576 ; CHECK-NEXT:    vsetvli zero, a0, e8, m1, ta, mu
1577 ; CHECK-NEXT:    csrwi vxrm, 0
1578 ; CHECK-NEXT:    vnclip.wi v8, v10, 9, v0.t
1579 ; CHECK-NEXT:    ret
1580 entry:
1581   %a = call <vscale x 8 x i8> @llvm.riscv.vnclip.mask.nxv8i8.nxv8i16(
1582     <vscale x 8 x i8> %0,
1583     <vscale x 8 x i16> %1,
1584     iXLen 9,
1585     <vscale x 8 x i1> %2,
1586     iXLen 0, iXLen %3, iXLen 1)
1588   ret <vscale x 8 x i8> %a
1591 define <vscale x 16 x i8> @intrinsic_vnclip_vi_nxv16i8_nxv16i16_i8(<vscale x 16 x i16> %0, iXLen %1) nounwind {
1592 ; CHECK-LABEL: intrinsic_vnclip_vi_nxv16i8_nxv16i16_i8:
1593 ; CHECK:       # %bb.0: # %entry
1594 ; CHECK-NEXT:    vsetvli zero, a0, e8, m2, ta, ma
1595 ; CHECK-NEXT:    csrwi vxrm, 0
1596 ; CHECK-NEXT:    vnclip.wi v12, v8, 9
1597 ; CHECK-NEXT:    vmv.v.v v8, v12
1598 ; CHECK-NEXT:    ret
1599 entry:
1600   %a = call <vscale x 16 x i8> @llvm.riscv.vnclip.nxv16i8.nxv16i16(
1601     <vscale x 16 x i8> undef,
1602     <vscale x 16 x i16> %0,
1603     iXLen 9,
1604     iXLen 0, iXLen %1)
1606   ret <vscale x 16 x i8> %a
1609 define <vscale x 16 x i8> @intrinsic_vnclip_mask_vi_nxv16i8_nxv16i16_i8(<vscale x 16 x i8> %0, <vscale x 16 x i16> %1, <vscale x 16 x i1> %2, iXLen %3) nounwind {
1610 ; CHECK-LABEL: intrinsic_vnclip_mask_vi_nxv16i8_nxv16i16_i8:
1611 ; CHECK:       # %bb.0: # %entry
1612 ; CHECK-NEXT:    vsetvli zero, a0, e8, m2, ta, mu
1613 ; CHECK-NEXT:    csrwi vxrm, 0
1614 ; CHECK-NEXT:    vnclip.wi v8, v12, 9, v0.t
1615 ; CHECK-NEXT:    ret
1616 entry:
1617   %a = call <vscale x 16 x i8> @llvm.riscv.vnclip.mask.nxv16i8.nxv16i16(
1618     <vscale x 16 x i8> %0,
1619     <vscale x 16 x i16> %1,
1620     iXLen 9,
1621     <vscale x 16 x i1> %2,
1622     iXLen 0, iXLen %3, iXLen 1)
1624   ret <vscale x 16 x i8> %a
1627 define <vscale x 32 x i8> @intrinsic_vnclip_vi_nxv32i8_nxv32i16_i8(<vscale x 32 x i16> %0, iXLen %1) nounwind {
1628 ; CHECK-LABEL: intrinsic_vnclip_vi_nxv32i8_nxv32i16_i8:
1629 ; CHECK:       # %bb.0: # %entry
1630 ; CHECK-NEXT:    vsetvli zero, a0, e8, m4, ta, ma
1631 ; CHECK-NEXT:    csrwi vxrm, 0
1632 ; CHECK-NEXT:    vnclip.wi v16, v8, 9
1633 ; CHECK-NEXT:    vmv.v.v v8, v16
1634 ; CHECK-NEXT:    ret
1635 entry:
1636   %a = call <vscale x 32 x i8> @llvm.riscv.vnclip.nxv32i8.nxv32i16(
1637     <vscale x 32 x i8> undef,
1638     <vscale x 32 x i16> %0,
1639     iXLen 9,
1640     iXLen 0, iXLen %1)
1642   ret <vscale x 32 x i8> %a
1645 define <vscale x 32 x i8> @intrinsic_vnclip_mask_vi_nxv32i8_nxv32i16_i8(<vscale x 32 x i8> %0, <vscale x 32 x i16> %1, <vscale x 32 x i1> %2, iXLen %3) nounwind {
1646 ; CHECK-LABEL: intrinsic_vnclip_mask_vi_nxv32i8_nxv32i16_i8:
1647 ; CHECK:       # %bb.0: # %entry
1648 ; CHECK-NEXT:    vsetvli zero, a0, e8, m4, ta, mu
1649 ; CHECK-NEXT:    csrwi vxrm, 0
1650 ; CHECK-NEXT:    vnclip.wi v8, v16, 9, v0.t
1651 ; CHECK-NEXT:    ret
1652 entry:
1653   %a = call <vscale x 32 x i8> @llvm.riscv.vnclip.mask.nxv32i8.nxv32i16(
1654     <vscale x 32 x i8> %0,
1655     <vscale x 32 x i16> %1,
1656     iXLen 9,
1657     <vscale x 32 x i1> %2,
1658     iXLen 0, iXLen %3, iXLen 1)
1660   ret <vscale x 32 x i8> %a
1663 define <vscale x 1 x i16> @intrinsic_vnclip_vi_nxv1i16_nxv1i32_i16(<vscale x 1 x i32> %0, iXLen %1) nounwind {
1664 ; CHECK-LABEL: intrinsic_vnclip_vi_nxv1i16_nxv1i32_i16:
1665 ; CHECK:       # %bb.0: # %entry
1666 ; CHECK-NEXT:    vsetvli zero, a0, e16, mf4, ta, ma
1667 ; CHECK-NEXT:    csrwi vxrm, 0
1668 ; CHECK-NEXT:    vnclip.wi v8, v8, 9
1669 ; CHECK-NEXT:    ret
1670 entry:
1671   %a = call <vscale x 1 x i16> @llvm.riscv.vnclip.nxv1i16.nxv1i32(
1672     <vscale x 1 x i16> undef,
1673     <vscale x 1 x i32> %0,
1674     iXLen 9,
1675     iXLen 0, iXLen %1)
1677   ret <vscale x 1 x i16> %a
1680 define <vscale x 1 x i16> @intrinsic_vnclip_mask_vi_nxv1i16_nxv1i32_i16(<vscale x 1 x i16> %0, <vscale x 1 x i32> %1, <vscale x 1 x i1> %2, iXLen %3) nounwind {
1681 ; CHECK-LABEL: intrinsic_vnclip_mask_vi_nxv1i16_nxv1i32_i16:
1682 ; CHECK:       # %bb.0: # %entry
1683 ; CHECK-NEXT:    vsetvli zero, a0, e16, mf4, ta, mu
1684 ; CHECK-NEXT:    csrwi vxrm, 0
1685 ; CHECK-NEXT:    vnclip.wi v8, v9, 9, v0.t
1686 ; CHECK-NEXT:    ret
1687 entry:
1688   %a = call <vscale x 1 x i16> @llvm.riscv.vnclip.mask.nxv1i16.nxv1i32(
1689     <vscale x 1 x i16> %0,
1690     <vscale x 1 x i32> %1,
1691     iXLen 9,
1692     <vscale x 1 x i1> %2,
1693     iXLen 0, iXLen %3, iXLen 1)
1695   ret <vscale x 1 x i16> %a
1698 define <vscale x 2 x i16> @intrinsic_vnclip_vi_nxv2i16_nxv2i32_i16(<vscale x 2 x i32> %0, iXLen %1) nounwind {
1699 ; CHECK-LABEL: intrinsic_vnclip_vi_nxv2i16_nxv2i32_i16:
1700 ; CHECK:       # %bb.0: # %entry
1701 ; CHECK-NEXT:    vsetvli zero, a0, e16, mf2, ta, ma
1702 ; CHECK-NEXT:    csrwi vxrm, 0
1703 ; CHECK-NEXT:    vnclip.wi v8, v8, 9
1704 ; CHECK-NEXT:    ret
1705 entry:
1706   %a = call <vscale x 2 x i16> @llvm.riscv.vnclip.nxv2i16.nxv2i32(
1707     <vscale x 2 x i16> undef,
1708     <vscale x 2 x i32> %0,
1709     iXLen 9,
1710     iXLen 0, iXLen %1)
1712   ret <vscale x 2 x i16> %a
1715 define <vscale x 2 x i16> @intrinsic_vnclip_mask_vi_nxv2i16_nxv2i32_i16(<vscale x 2 x i16> %0, <vscale x 2 x i32> %1, <vscale x 2 x i1> %2, iXLen %3) nounwind {
1716 ; CHECK-LABEL: intrinsic_vnclip_mask_vi_nxv2i16_nxv2i32_i16:
1717 ; CHECK:       # %bb.0: # %entry
1718 ; CHECK-NEXT:    vsetvli zero, a0, e16, mf2, ta, mu
1719 ; CHECK-NEXT:    csrwi vxrm, 0
1720 ; CHECK-NEXT:    vnclip.wi v8, v9, 9, v0.t
1721 ; CHECK-NEXT:    ret
1722 entry:
1723   %a = call <vscale x 2 x i16> @llvm.riscv.vnclip.mask.nxv2i16.nxv2i32(
1724     <vscale x 2 x i16> %0,
1725     <vscale x 2 x i32> %1,
1726     iXLen 9,
1727     <vscale x 2 x i1> %2,
1728     iXLen 0, iXLen %3, iXLen 1)
1730   ret <vscale x 2 x i16> %a
1733 define <vscale x 4 x i16> @intrinsic_vnclip_vi_nxv4i16_nxv4i32_i16(<vscale x 4 x i32> %0, iXLen %1) nounwind {
1734 ; CHECK-LABEL: intrinsic_vnclip_vi_nxv4i16_nxv4i32_i16:
1735 ; CHECK:       # %bb.0: # %entry
1736 ; CHECK-NEXT:    vsetvli zero, a0, e16, m1, ta, ma
1737 ; CHECK-NEXT:    csrwi vxrm, 0
1738 ; CHECK-NEXT:    vnclip.wi v10, v8, 9
1739 ; CHECK-NEXT:    vmv.v.v v8, v10
1740 ; CHECK-NEXT:    ret
1741 entry:
1742   %a = call <vscale x 4 x i16> @llvm.riscv.vnclip.nxv4i16.nxv4i32(
1743     <vscale x 4 x i16> undef,
1744     <vscale x 4 x i32> %0,
1745     iXLen 9,
1746     iXLen 0, iXLen %1)
1748   ret <vscale x 4 x i16> %a
1751 define <vscale x 4 x i16> @intrinsic_vnclip_mask_vi_nxv4i16_nxv4i32_i16(<vscale x 4 x i16> %0, <vscale x 4 x i32> %1, <vscale x 4 x i1> %2, iXLen %3) nounwind {
1752 ; CHECK-LABEL: intrinsic_vnclip_mask_vi_nxv4i16_nxv4i32_i16:
1753 ; CHECK:       # %bb.0: # %entry
1754 ; CHECK-NEXT:    vsetvli zero, a0, e16, m1, ta, mu
1755 ; CHECK-NEXT:    csrwi vxrm, 0
1756 ; CHECK-NEXT:    vnclip.wi v8, v10, 9, v0.t
1757 ; CHECK-NEXT:    ret
1758 entry:
1759   %a = call <vscale x 4 x i16> @llvm.riscv.vnclip.mask.nxv4i16.nxv4i32(
1760     <vscale x 4 x i16> %0,
1761     <vscale x 4 x i32> %1,
1762     iXLen 9,
1763     <vscale x 4 x i1> %2,
1764     iXLen 0, iXLen %3, iXLen 1)
1766   ret <vscale x 4 x i16> %a
1769 define <vscale x 8 x i16> @intrinsic_vnclip_vi_nxv8i16_nxv8i32_i16(<vscale x 8 x i32> %0, iXLen %1) nounwind {
1770 ; CHECK-LABEL: intrinsic_vnclip_vi_nxv8i16_nxv8i32_i16:
1771 ; CHECK:       # %bb.0: # %entry
1772 ; CHECK-NEXT:    vsetvli zero, a0, e16, m2, ta, ma
1773 ; CHECK-NEXT:    csrwi vxrm, 0
1774 ; CHECK-NEXT:    vnclip.wi v12, v8, 9
1775 ; CHECK-NEXT:    vmv.v.v v8, v12
1776 ; CHECK-NEXT:    ret
1777 entry:
1778   %a = call <vscale x 8 x i16> @llvm.riscv.vnclip.nxv8i16.nxv8i32(
1779     <vscale x 8 x i16> undef,
1780     <vscale x 8 x i32> %0,
1781     iXLen 9,
1782     iXLen 0, iXLen %1)
1784   ret <vscale x 8 x i16> %a
1787 define <vscale x 8 x i16> @intrinsic_vnclip_mask_vi_nxv8i16_nxv8i32_i16(<vscale x 8 x i16> %0, <vscale x 8 x i32> %1, <vscale x 8 x i1> %2, iXLen %3) nounwind {
1788 ; CHECK-LABEL: intrinsic_vnclip_mask_vi_nxv8i16_nxv8i32_i16:
1789 ; CHECK:       # %bb.0: # %entry
1790 ; CHECK-NEXT:    vsetvli zero, a0, e16, m2, ta, mu
1791 ; CHECK-NEXT:    csrwi vxrm, 0
1792 ; CHECK-NEXT:    vnclip.wi v8, v12, 9, v0.t
1793 ; CHECK-NEXT:    ret
1794 entry:
1795   %a = call <vscale x 8 x i16> @llvm.riscv.vnclip.mask.nxv8i16.nxv8i32(
1796     <vscale x 8 x i16> %0,
1797     <vscale x 8 x i32> %1,
1798     iXLen 9,
1799     <vscale x 8 x i1> %2,
1800     iXLen 0, iXLen %3, iXLen 1)
1802   ret <vscale x 8 x i16> %a
1805 define <vscale x 16 x i16> @intrinsic_vnclip_vi_nxv16i16_nxv16i32_i16(<vscale x 16 x i32> %0, iXLen %1) nounwind {
1806 ; CHECK-LABEL: intrinsic_vnclip_vi_nxv16i16_nxv16i32_i16:
1807 ; CHECK:       # %bb.0: # %entry
1808 ; CHECK-NEXT:    vsetvli zero, a0, e16, m4, ta, ma
1809 ; CHECK-NEXT:    csrwi vxrm, 0
1810 ; CHECK-NEXT:    vnclip.wi v16, v8, 9
1811 ; CHECK-NEXT:    vmv.v.v v8, v16
1812 ; CHECK-NEXT:    ret
1813 entry:
1814   %a = call <vscale x 16 x i16> @llvm.riscv.vnclip.nxv16i16.nxv16i32(
1815     <vscale x 16 x i16> undef,
1816     <vscale x 16 x i32> %0,
1817     iXLen 9,
1818     iXLen 0, iXLen %1)
1820   ret <vscale x 16 x i16> %a
1823 define <vscale x 16 x i16> @intrinsic_vnclip_mask_vi_nxv16i16_nxv16i32_i16(<vscale x 16 x i16> %0, <vscale x 16 x i32> %1, <vscale x 16 x i1> %2, iXLen %3) nounwind {
1824 ; CHECK-LABEL: intrinsic_vnclip_mask_vi_nxv16i16_nxv16i32_i16:
1825 ; CHECK:       # %bb.0: # %entry
1826 ; CHECK-NEXT:    vsetvli zero, a0, e16, m4, ta, mu
1827 ; CHECK-NEXT:    csrwi vxrm, 0
1828 ; CHECK-NEXT:    vnclip.wi v8, v16, 9, v0.t
1829 ; CHECK-NEXT:    ret
1830 entry:
1831   %a = call <vscale x 16 x i16> @llvm.riscv.vnclip.mask.nxv16i16.nxv16i32(
1832     <vscale x 16 x i16> %0,
1833     <vscale x 16 x i32> %1,
1834     iXLen 9,
1835     <vscale x 16 x i1> %2,
1836     iXLen 0, iXLen %3, iXLen 1)
1838   ret <vscale x 16 x i16> %a
1841 define <vscale x 1 x i32> @intrinsic_vnclip_vi_nxv1i32_nxv1i64_i32(<vscale x 1 x i64> %0, iXLen %1) nounwind {
1842 ; CHECK-LABEL: intrinsic_vnclip_vi_nxv1i32_nxv1i64_i32:
1843 ; CHECK:       # %bb.0: # %entry
1844 ; CHECK-NEXT:    vsetvli zero, a0, e32, mf2, ta, ma
1845 ; CHECK-NEXT:    csrwi vxrm, 0
1846 ; CHECK-NEXT:    vnclip.wi v8, v8, 9
1847 ; CHECK-NEXT:    ret
1848 entry:
1849   %a = call <vscale x 1 x i32> @llvm.riscv.vnclip.nxv1i32.nxv1i64(
1850     <vscale x 1 x i32> undef,
1851     <vscale x 1 x i64> %0,
1852     iXLen 9,
1853     iXLen 0, iXLen %1)
1855   ret <vscale x 1 x i32> %a
1858 define <vscale x 1 x i32> @intrinsic_vnclip_mask_vi_nxv1i32_nxv1i64_i32(<vscale x 1 x i32> %0, <vscale x 1 x i64> %1, <vscale x 1 x i1> %2, iXLen %3) nounwind {
1859 ; CHECK-LABEL: intrinsic_vnclip_mask_vi_nxv1i32_nxv1i64_i32:
1860 ; CHECK:       # %bb.0: # %entry
1861 ; CHECK-NEXT:    vsetvli zero, a0, e32, mf2, ta, mu
1862 ; CHECK-NEXT:    csrwi vxrm, 0
1863 ; CHECK-NEXT:    vnclip.wi v8, v9, 9, v0.t
1864 ; CHECK-NEXT:    ret
1865 entry:
1866   %a = call <vscale x 1 x i32> @llvm.riscv.vnclip.mask.nxv1i32.nxv1i64(
1867     <vscale x 1 x i32> %0,
1868     <vscale x 1 x i64> %1,
1869     iXLen 9,
1870     <vscale x 1 x i1> %2,
1871     iXLen 0, iXLen %3, iXLen 1)
1873   ret <vscale x 1 x i32> %a
1876 define <vscale x 2 x i32> @intrinsic_vnclip_vi_nxv2i32_nxv2i64_i32(<vscale x 2 x i64> %0, iXLen %1) nounwind {
1877 ; CHECK-LABEL: intrinsic_vnclip_vi_nxv2i32_nxv2i64_i32:
1878 ; CHECK:       # %bb.0: # %entry
1879 ; CHECK-NEXT:    vsetvli zero, a0, e32, m1, ta, ma
1880 ; CHECK-NEXT:    csrwi vxrm, 0
1881 ; CHECK-NEXT:    vnclip.wi v10, v8, 9
1882 ; CHECK-NEXT:    vmv.v.v v8, v10
1883 ; CHECK-NEXT:    ret
1884 entry:
1885   %a = call <vscale x 2 x i32> @llvm.riscv.vnclip.nxv2i32.nxv2i64(
1886     <vscale x 2 x i32> undef,
1887     <vscale x 2 x i64> %0,
1888     iXLen 9,
1889     iXLen 0, iXLen %1)
1891   ret <vscale x 2 x i32> %a
1894 define <vscale x 2 x i32> @intrinsic_vnclip_mask_vi_nxv2i32_nxv2i64_i32(<vscale x 2 x i32> %0, <vscale x 2 x i64> %1, <vscale x 2 x i1> %2, iXLen %3) nounwind {
1895 ; CHECK-LABEL: intrinsic_vnclip_mask_vi_nxv2i32_nxv2i64_i32:
1896 ; CHECK:       # %bb.0: # %entry
1897 ; CHECK-NEXT:    vsetvli zero, a0, e32, m1, ta, mu
1898 ; CHECK-NEXT:    csrwi vxrm, 0
1899 ; CHECK-NEXT:    vnclip.wi v8, v10, 9, v0.t
1900 ; CHECK-NEXT:    ret
1901 entry:
1902   %a = call <vscale x 2 x i32> @llvm.riscv.vnclip.mask.nxv2i32.nxv2i64(
1903     <vscale x 2 x i32> %0,
1904     <vscale x 2 x i64> %1,
1905     iXLen 9,
1906     <vscale x 2 x i1> %2,
1907     iXLen 0, iXLen %3, iXLen 1)
1909   ret <vscale x 2 x i32> %a
1912 define <vscale x 4 x i32> @intrinsic_vnclip_vi_nxv4i32_nxv4i64_i32(<vscale x 4 x i64> %0, iXLen %1) nounwind {
1913 ; CHECK-LABEL: intrinsic_vnclip_vi_nxv4i32_nxv4i64_i32:
1914 ; CHECK:       # %bb.0: # %entry
1915 ; CHECK-NEXT:    vsetvli zero, a0, e32, m2, ta, ma
1916 ; CHECK-NEXT:    csrwi vxrm, 0
1917 ; CHECK-NEXT:    vnclip.wi v12, v8, 9
1918 ; CHECK-NEXT:    vmv.v.v v8, v12
1919 ; CHECK-NEXT:    ret
1920 entry:
1921   %a = call <vscale x 4 x i32> @llvm.riscv.vnclip.nxv4i32.nxv4i64(
1922     <vscale x 4 x i32> undef,
1923     <vscale x 4 x i64> %0,
1924     iXLen 9,
1925     iXLen 0, iXLen %1)
1927   ret <vscale x 4 x i32> %a
1930 define <vscale x 4 x i32> @intrinsic_vnclip_mask_vi_nxv4i32_nxv4i64_i32(<vscale x 4 x i32> %0, <vscale x 4 x i64> %1, <vscale x 4 x i1> %2, iXLen %3) nounwind {
1931 ; CHECK-LABEL: intrinsic_vnclip_mask_vi_nxv4i32_nxv4i64_i32:
1932 ; CHECK:       # %bb.0: # %entry
1933 ; CHECK-NEXT:    vsetvli zero, a0, e32, m2, ta, mu
1934 ; CHECK-NEXT:    csrwi vxrm, 0
1935 ; CHECK-NEXT:    vnclip.wi v8, v12, 9, v0.t
1936 ; CHECK-NEXT:    ret
1937 entry:
1938   %a = call <vscale x 4 x i32> @llvm.riscv.vnclip.mask.nxv4i32.nxv4i64(
1939     <vscale x 4 x i32> %0,
1940     <vscale x 4 x i64> %1,
1941     iXLen 9,
1942     <vscale x 4 x i1> %2,
1943     iXLen 0, iXLen %3, iXLen 1)
1945   ret <vscale x 4 x i32> %a
1948 define <vscale x 8 x i32> @intrinsic_vnclip_vi_nxv8i32_nxv8i64_i32(<vscale x 8 x i64> %0, iXLen %1) nounwind {
1949 ; CHECK-LABEL: intrinsic_vnclip_vi_nxv8i32_nxv8i64_i32:
1950 ; CHECK:       # %bb.0: # %entry
1951 ; CHECK-NEXT:    vsetvli zero, a0, e32, m4, ta, ma
1952 ; CHECK-NEXT:    csrwi vxrm, 0
1953 ; CHECK-NEXT:    vnclip.wi v16, v8, 9
1954 ; CHECK-NEXT:    vmv.v.v v8, v16
1955 ; CHECK-NEXT:    ret
1956 entry:
1957   %a = call <vscale x 8 x i32> @llvm.riscv.vnclip.nxv8i32.nxv8i64(
1958     <vscale x 8 x i32> undef,
1959     <vscale x 8 x i64> %0,
1960     iXLen 9,
1961     iXLen 0, iXLen %1)
1963   ret <vscale x 8 x i32> %a
1966 define <vscale x 8 x i32> @intrinsic_vnclip_mask_vi_nxv8i32_nxv8i64_i32(<vscale x 8 x i32> %0, <vscale x 8 x i64> %1, <vscale x 8 x i1> %2, iXLen %3) nounwind {
1967 ; CHECK-LABEL: intrinsic_vnclip_mask_vi_nxv8i32_nxv8i64_i32:
1968 ; CHECK:       # %bb.0: # %entry
1969 ; CHECK-NEXT:    vsetvli zero, a0, e32, m4, ta, mu
1970 ; CHECK-NEXT:    csrwi vxrm, 0
1971 ; CHECK-NEXT:    vnclip.wi v8, v16, 9, v0.t
1972 ; CHECK-NEXT:    ret
1973 entry:
1974   %a = call <vscale x 8 x i32> @llvm.riscv.vnclip.mask.nxv8i32.nxv8i64(
1975     <vscale x 8 x i32> %0,
1976     <vscale x 8 x i64> %1,
1977     iXLen 9,
1978     <vscale x 8 x i1> %2,
1979     iXLen 0, iXLen %3, iXLen 1)
1981   ret <vscale x 8 x i32> %a