1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 2
2 ; RUN: llc -mtriple=riscv64 -mattr=+v -verify-machineinstrs \
3 ; RUN: < %s | FileCheck %s
5 define <vscale x 1 x i8> @test_vssrl_vv_u8mf8(<vscale x 1 x i8> %op1, <vscale x 1 x i8> %shift, i64 %vl) {
6 ; CHECK-LABEL: test_vssrl_vv_u8mf8:
7 ; CHECK: # %bb.0: # %entry
8 ; CHECK-NEXT: csrwi vxrm, 0
9 ; CHECK-NEXT: vsetvli zero, a0, e8, mf8, ta, ma
10 ; CHECK-NEXT: vssrl.vv v8, v8, v9
13 %0 = call <vscale x 1 x i8> @llvm.riscv.vssrl.nxv1i8.nxv1i8.i64(<vscale x 1 x i8> poison, <vscale x 1 x i8> %op1, <vscale x 1 x i8> %shift, i64 0, i64 %vl)
14 ret <vscale x 1 x i8> %0
17 declare <vscale x 1 x i8> @llvm.riscv.vssrl.nxv1i8.nxv1i8.i64(<vscale x 1 x i8>, <vscale x 1 x i8>, <vscale x 1 x i8>, i64 immarg, i64)
19 define <vscale x 1 x i8> @test_vssrl_vx_u8mf8(<vscale x 1 x i8> %op1, i64 %shift, i64 %vl) {
20 ; CHECK-LABEL: test_vssrl_vx_u8mf8:
21 ; CHECK: # %bb.0: # %entry
22 ; CHECK-NEXT: csrwi vxrm, 0
23 ; CHECK-NEXT: vsetvli zero, a1, e8, mf8, ta, ma
24 ; CHECK-NEXT: vssrl.vx v8, v8, a0
27 %0 = call <vscale x 1 x i8> @llvm.riscv.vssrl.nxv1i8.i64.i64(<vscale x 1 x i8> poison, <vscale x 1 x i8> %op1, i64 %shift, i64 0, i64 %vl)
28 ret <vscale x 1 x i8> %0
31 declare <vscale x 1 x i8> @llvm.riscv.vssrl.nxv1i8.i64.i64(<vscale x 1 x i8>, <vscale x 1 x i8>, i64, i64 immarg, i64)
33 define <vscale x 2 x i8> @test_vssrl_vv_u8mf4(<vscale x 2 x i8> %op1, <vscale x 2 x i8> %shift, i64 %vl) {
34 ; CHECK-LABEL: test_vssrl_vv_u8mf4:
35 ; CHECK: # %bb.0: # %entry
36 ; CHECK-NEXT: csrwi vxrm, 0
37 ; CHECK-NEXT: vsetvli zero, a0, e8, mf4, ta, ma
38 ; CHECK-NEXT: vssrl.vv v8, v8, v9
41 %0 = call <vscale x 2 x i8> @llvm.riscv.vssrl.nxv2i8.nxv2i8.i64(<vscale x 2 x i8> poison, <vscale x 2 x i8> %op1, <vscale x 2 x i8> %shift, i64 0, i64 %vl)
42 ret <vscale x 2 x i8> %0
45 declare <vscale x 2 x i8> @llvm.riscv.vssrl.nxv2i8.nxv2i8.i64(<vscale x 2 x i8>, <vscale x 2 x i8>, <vscale x 2 x i8>, i64 immarg, i64)
47 define <vscale x 2 x i8> @test_vssrl_vx_u8mf4(<vscale x 2 x i8> %op1, i64 %shift, i64 %vl) {
48 ; CHECK-LABEL: test_vssrl_vx_u8mf4:
49 ; CHECK: # %bb.0: # %entry
50 ; CHECK-NEXT: csrwi vxrm, 0
51 ; CHECK-NEXT: vsetvli zero, a1, e8, mf4, ta, ma
52 ; CHECK-NEXT: vssrl.vx v8, v8, a0
55 %0 = call <vscale x 2 x i8> @llvm.riscv.vssrl.nxv2i8.i64.i64(<vscale x 2 x i8> poison, <vscale x 2 x i8> %op1, i64 %shift, i64 0, i64 %vl)
56 ret <vscale x 2 x i8> %0
59 declare <vscale x 2 x i8> @llvm.riscv.vssrl.nxv2i8.i64.i64(<vscale x 2 x i8>, <vscale x 2 x i8>, i64, i64 immarg, i64)
61 define <vscale x 4 x i8> @test_vssrl_vv_u8mf2(<vscale x 4 x i8> %op1, <vscale x 4 x i8> %shift, i64 %vl) {
62 ; CHECK-LABEL: test_vssrl_vv_u8mf2:
63 ; CHECK: # %bb.0: # %entry
64 ; CHECK-NEXT: csrwi vxrm, 0
65 ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma
66 ; CHECK-NEXT: vssrl.vv v8, v8, v9
69 %0 = call <vscale x 4 x i8> @llvm.riscv.vssrl.nxv4i8.nxv4i8.i64(<vscale x 4 x i8> poison, <vscale x 4 x i8> %op1, <vscale x 4 x i8> %shift, i64 0, i64 %vl)
70 ret <vscale x 4 x i8> %0
73 declare <vscale x 4 x i8> @llvm.riscv.vssrl.nxv4i8.nxv4i8.i64(<vscale x 4 x i8>, <vscale x 4 x i8>, <vscale x 4 x i8>, i64 immarg, i64)
75 define <vscale x 4 x i8> @test_vssrl_vx_u8mf2(<vscale x 4 x i8> %op1, i64 %shift, i64 %vl) {
76 ; CHECK-LABEL: test_vssrl_vx_u8mf2:
77 ; CHECK: # %bb.0: # %entry
78 ; CHECK-NEXT: csrwi vxrm, 0
79 ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma
80 ; CHECK-NEXT: vssrl.vx v8, v8, a0
83 %0 = call <vscale x 4 x i8> @llvm.riscv.vssrl.nxv4i8.i64.i64(<vscale x 4 x i8> poison, <vscale x 4 x i8> %op1, i64 %shift, i64 0, i64 %vl)
84 ret <vscale x 4 x i8> %0
87 declare <vscale x 4 x i8> @llvm.riscv.vssrl.nxv4i8.i64.i64(<vscale x 4 x i8>, <vscale x 4 x i8>, i64, i64 immarg, i64)
89 define <vscale x 8 x i8> @test_vssrl_vv_u8m1(<vscale x 8 x i8> %op1, <vscale x 8 x i8> %shift, i64 %vl) {
90 ; CHECK-LABEL: test_vssrl_vv_u8m1:
91 ; CHECK: # %bb.0: # %entry
92 ; CHECK-NEXT: csrwi vxrm, 0
93 ; CHECK-NEXT: vsetvli zero, a0, e8, m1, ta, ma
94 ; CHECK-NEXT: vssrl.vv v8, v8, v9
97 %0 = call <vscale x 8 x i8> @llvm.riscv.vssrl.nxv8i8.nxv8i8.i64(<vscale x 8 x i8> poison, <vscale x 8 x i8> %op1, <vscale x 8 x i8> %shift, i64 0, i64 %vl)
98 ret <vscale x 8 x i8> %0
101 declare <vscale x 8 x i8> @llvm.riscv.vssrl.nxv8i8.nxv8i8.i64(<vscale x 8 x i8>, <vscale x 8 x i8>, <vscale x 8 x i8>, i64 immarg, i64)
103 define <vscale x 8 x i8> @test_vssrl_vx_u8m1(<vscale x 8 x i8> %op1, i64 %shift, i64 %vl) {
104 ; CHECK-LABEL: test_vssrl_vx_u8m1:
105 ; CHECK: # %bb.0: # %entry
106 ; CHECK-NEXT: csrwi vxrm, 0
107 ; CHECK-NEXT: vsetvli zero, a1, e8, m1, ta, ma
108 ; CHECK-NEXT: vssrl.vx v8, v8, a0
111 %0 = call <vscale x 8 x i8> @llvm.riscv.vssrl.nxv8i8.i64.i64(<vscale x 8 x i8> poison, <vscale x 8 x i8> %op1, i64 %shift, i64 0, i64 %vl)
112 ret <vscale x 8 x i8> %0
115 declare <vscale x 8 x i8> @llvm.riscv.vssrl.nxv8i8.i64.i64(<vscale x 8 x i8>, <vscale x 8 x i8>, i64, i64 immarg, i64)
117 define <vscale x 16 x i8> @test_vssrl_vv_u8m2(<vscale x 16 x i8> %op1, <vscale x 16 x i8> %shift, i64 %vl) {
118 ; CHECK-LABEL: test_vssrl_vv_u8m2:
119 ; CHECK: # %bb.0: # %entry
120 ; CHECK-NEXT: csrwi vxrm, 0
121 ; CHECK-NEXT: vsetvli zero, a0, e8, m2, ta, ma
122 ; CHECK-NEXT: vssrl.vv v8, v8, v10
125 %0 = call <vscale x 16 x i8> @llvm.riscv.vssrl.nxv16i8.nxv16i8.i64(<vscale x 16 x i8> poison, <vscale x 16 x i8> %op1, <vscale x 16 x i8> %shift, i64 0, i64 %vl)
126 ret <vscale x 16 x i8> %0
129 declare <vscale x 16 x i8> @llvm.riscv.vssrl.nxv16i8.nxv16i8.i64(<vscale x 16 x i8>, <vscale x 16 x i8>, <vscale x 16 x i8>, i64 immarg, i64)
131 define <vscale x 16 x i8> @test_vssrl_vx_u8m2(<vscale x 16 x i8> %op1, i64 %shift, i64 %vl) {
132 ; CHECK-LABEL: test_vssrl_vx_u8m2:
133 ; CHECK: # %bb.0: # %entry
134 ; CHECK-NEXT: csrwi vxrm, 0
135 ; CHECK-NEXT: vsetvli zero, a1, e8, m2, ta, ma
136 ; CHECK-NEXT: vssrl.vx v8, v8, a0
139 %0 = call <vscale x 16 x i8> @llvm.riscv.vssrl.nxv16i8.i64.i64(<vscale x 16 x i8> poison, <vscale x 16 x i8> %op1, i64 %shift, i64 0, i64 %vl)
140 ret <vscale x 16 x i8> %0
143 declare <vscale x 16 x i8> @llvm.riscv.vssrl.nxv16i8.i64.i64(<vscale x 16 x i8>, <vscale x 16 x i8>, i64, i64 immarg, i64)
145 define <vscale x 32 x i8> @test_vssrl_vv_u8m4(<vscale x 32 x i8> %op1, <vscale x 32 x i8> %shift, i64 %vl) {
146 ; CHECK-LABEL: test_vssrl_vv_u8m4:
147 ; CHECK: # %bb.0: # %entry
148 ; CHECK-NEXT: csrwi vxrm, 0
149 ; CHECK-NEXT: vsetvli zero, a0, e8, m4, ta, ma
150 ; CHECK-NEXT: vssrl.vv v8, v8, v12
153 %0 = call <vscale x 32 x i8> @llvm.riscv.vssrl.nxv32i8.nxv32i8.i64(<vscale x 32 x i8> poison, <vscale x 32 x i8> %op1, <vscale x 32 x i8> %shift, i64 0, i64 %vl)
154 ret <vscale x 32 x i8> %0
157 declare <vscale x 32 x i8> @llvm.riscv.vssrl.nxv32i8.nxv32i8.i64(<vscale x 32 x i8>, <vscale x 32 x i8>, <vscale x 32 x i8>, i64 immarg, i64)
159 define <vscale x 32 x i8> @test_vssrl_vx_u8m4(<vscale x 32 x i8> %op1, i64 %shift, i64 %vl) {
160 ; CHECK-LABEL: test_vssrl_vx_u8m4:
161 ; CHECK: # %bb.0: # %entry
162 ; CHECK-NEXT: csrwi vxrm, 0
163 ; CHECK-NEXT: vsetvli zero, a1, e8, m4, ta, ma
164 ; CHECK-NEXT: vssrl.vx v8, v8, a0
167 %0 = call <vscale x 32 x i8> @llvm.riscv.vssrl.nxv32i8.i64.i64(<vscale x 32 x i8> poison, <vscale x 32 x i8> %op1, i64 %shift, i64 0, i64 %vl)
168 ret <vscale x 32 x i8> %0
171 declare <vscale x 32 x i8> @llvm.riscv.vssrl.nxv32i8.i64.i64(<vscale x 32 x i8>, <vscale x 32 x i8>, i64, i64 immarg, i64)
173 define <vscale x 64 x i8> @test_vssrl_vv_u8m8(<vscale x 64 x i8> %op1, <vscale x 64 x i8> %shift, i64 %vl) {
174 ; CHECK-LABEL: test_vssrl_vv_u8m8:
175 ; CHECK: # %bb.0: # %entry
176 ; CHECK-NEXT: csrwi vxrm, 0
177 ; CHECK-NEXT: vsetvli zero, a0, e8, m8, ta, ma
178 ; CHECK-NEXT: vssrl.vv v8, v8, v16
181 %0 = call <vscale x 64 x i8> @llvm.riscv.vssrl.nxv64i8.nxv64i8.i64(<vscale x 64 x i8> poison, <vscale x 64 x i8> %op1, <vscale x 64 x i8> %shift, i64 0, i64 %vl)
182 ret <vscale x 64 x i8> %0
185 declare <vscale x 64 x i8> @llvm.riscv.vssrl.nxv64i8.nxv64i8.i64(<vscale x 64 x i8>, <vscale x 64 x i8>, <vscale x 64 x i8>, i64 immarg, i64)
187 define <vscale x 64 x i8> @test_vssrl_vx_u8m8(<vscale x 64 x i8> %op1, i64 %shift, i64 %vl) {
188 ; CHECK-LABEL: test_vssrl_vx_u8m8:
189 ; CHECK: # %bb.0: # %entry
190 ; CHECK-NEXT: csrwi vxrm, 0
191 ; CHECK-NEXT: vsetvli zero, a1, e8, m8, ta, ma
192 ; CHECK-NEXT: vssrl.vx v8, v8, a0
195 %0 = call <vscale x 64 x i8> @llvm.riscv.vssrl.nxv64i8.i64.i64(<vscale x 64 x i8> poison, <vscale x 64 x i8> %op1, i64 %shift, i64 0, i64 %vl)
196 ret <vscale x 64 x i8> %0
199 declare <vscale x 64 x i8> @llvm.riscv.vssrl.nxv64i8.i64.i64(<vscale x 64 x i8>, <vscale x 64 x i8>, i64, i64 immarg, i64)
201 define <vscale x 1 x i16> @test_vssrl_vv_u16mf4(<vscale x 1 x i16> %op1, <vscale x 1 x i16> %shift, i64 %vl) {
202 ; CHECK-LABEL: test_vssrl_vv_u16mf4:
203 ; CHECK: # %bb.0: # %entry
204 ; CHECK-NEXT: csrwi vxrm, 0
205 ; CHECK-NEXT: vsetvli zero, a0, e16, mf4, ta, ma
206 ; CHECK-NEXT: vssrl.vv v8, v8, v9
209 %0 = call <vscale x 1 x i16> @llvm.riscv.vssrl.nxv1i16.nxv1i16.i64(<vscale x 1 x i16> poison, <vscale x 1 x i16> %op1, <vscale x 1 x i16> %shift, i64 0, i64 %vl)
210 ret <vscale x 1 x i16> %0
213 declare <vscale x 1 x i16> @llvm.riscv.vssrl.nxv1i16.nxv1i16.i64(<vscale x 1 x i16>, <vscale x 1 x i16>, <vscale x 1 x i16>, i64 immarg, i64)
215 define <vscale x 1 x i16> @test_vssrl_vx_u16mf4(<vscale x 1 x i16> %op1, i64 %shift, i64 %vl) {
216 ; CHECK-LABEL: test_vssrl_vx_u16mf4:
217 ; CHECK: # %bb.0: # %entry
218 ; CHECK-NEXT: csrwi vxrm, 0
219 ; CHECK-NEXT: vsetvli zero, a1, e16, mf4, ta, ma
220 ; CHECK-NEXT: vssrl.vx v8, v8, a0
223 %0 = call <vscale x 1 x i16> @llvm.riscv.vssrl.nxv1i16.i64.i64(<vscale x 1 x i16> poison, <vscale x 1 x i16> %op1, i64 %shift, i64 0, i64 %vl)
224 ret <vscale x 1 x i16> %0
227 declare <vscale x 1 x i16> @llvm.riscv.vssrl.nxv1i16.i64.i64(<vscale x 1 x i16>, <vscale x 1 x i16>, i64, i64 immarg, i64)
229 define <vscale x 2 x i16> @test_vssrl_vv_u16mf2(<vscale x 2 x i16> %op1, <vscale x 2 x i16> %shift, i64 %vl) {
230 ; CHECK-LABEL: test_vssrl_vv_u16mf2:
231 ; CHECK: # %bb.0: # %entry
232 ; CHECK-NEXT: csrwi vxrm, 0
233 ; CHECK-NEXT: vsetvli zero, a0, e16, mf2, ta, ma
234 ; CHECK-NEXT: vssrl.vv v8, v8, v9
237 %0 = call <vscale x 2 x i16> @llvm.riscv.vssrl.nxv2i16.nxv2i16.i64(<vscale x 2 x i16> poison, <vscale x 2 x i16> %op1, <vscale x 2 x i16> %shift, i64 0, i64 %vl)
238 ret <vscale x 2 x i16> %0
241 declare <vscale x 2 x i16> @llvm.riscv.vssrl.nxv2i16.nxv2i16.i64(<vscale x 2 x i16>, <vscale x 2 x i16>, <vscale x 2 x i16>, i64 immarg, i64)
243 define <vscale x 2 x i16> @test_vssrl_vx_u16mf2(<vscale x 2 x i16> %op1, i64 %shift, i64 %vl) {
244 ; CHECK-LABEL: test_vssrl_vx_u16mf2:
245 ; CHECK: # %bb.0: # %entry
246 ; CHECK-NEXT: csrwi vxrm, 0
247 ; CHECK-NEXT: vsetvli zero, a1, e16, mf2, ta, ma
248 ; CHECK-NEXT: vssrl.vx v8, v8, a0
251 %0 = call <vscale x 2 x i16> @llvm.riscv.vssrl.nxv2i16.i64.i64(<vscale x 2 x i16> poison, <vscale x 2 x i16> %op1, i64 %shift, i64 0, i64 %vl)
252 ret <vscale x 2 x i16> %0
255 declare <vscale x 2 x i16> @llvm.riscv.vssrl.nxv2i16.i64.i64(<vscale x 2 x i16>, <vscale x 2 x i16>, i64, i64 immarg, i64)
257 define <vscale x 4 x i16> @test_vssrl_vv_u16m1(<vscale x 4 x i16> %op1, <vscale x 4 x i16> %shift, i64 %vl) {
258 ; CHECK-LABEL: test_vssrl_vv_u16m1:
259 ; CHECK: # %bb.0: # %entry
260 ; CHECK-NEXT: csrwi vxrm, 0
261 ; CHECK-NEXT: vsetvli zero, a0, e16, m1, ta, ma
262 ; CHECK-NEXT: vssrl.vv v8, v8, v9
265 %0 = call <vscale x 4 x i16> @llvm.riscv.vssrl.nxv4i16.nxv4i16.i64(<vscale x 4 x i16> poison, <vscale x 4 x i16> %op1, <vscale x 4 x i16> %shift, i64 0, i64 %vl)
266 ret <vscale x 4 x i16> %0
269 declare <vscale x 4 x i16> @llvm.riscv.vssrl.nxv4i16.nxv4i16.i64(<vscale x 4 x i16>, <vscale x 4 x i16>, <vscale x 4 x i16>, i64 immarg, i64)
271 define <vscale x 4 x i16> @test_vssrl_vx_u16m1(<vscale x 4 x i16> %op1, i64 %shift, i64 %vl) {
272 ; CHECK-LABEL: test_vssrl_vx_u16m1:
273 ; CHECK: # %bb.0: # %entry
274 ; CHECK-NEXT: csrwi vxrm, 0
275 ; CHECK-NEXT: vsetvli zero, a1, e16, m1, ta, ma
276 ; CHECK-NEXT: vssrl.vx v8, v8, a0
279 %0 = call <vscale x 4 x i16> @llvm.riscv.vssrl.nxv4i16.i64.i64(<vscale x 4 x i16> poison, <vscale x 4 x i16> %op1, i64 %shift, i64 0, i64 %vl)
280 ret <vscale x 4 x i16> %0
283 declare <vscale x 4 x i16> @llvm.riscv.vssrl.nxv4i16.i64.i64(<vscale x 4 x i16>, <vscale x 4 x i16>, i64, i64 immarg, i64)
285 define <vscale x 8 x i16> @test_vssrl_vv_u16m2(<vscale x 8 x i16> %op1, <vscale x 8 x i16> %shift, i64 %vl) {
286 ; CHECK-LABEL: test_vssrl_vv_u16m2:
287 ; CHECK: # %bb.0: # %entry
288 ; CHECK-NEXT: csrwi vxrm, 0
289 ; CHECK-NEXT: vsetvli zero, a0, e16, m2, ta, ma
290 ; CHECK-NEXT: vssrl.vv v8, v8, v10
293 %0 = call <vscale x 8 x i16> @llvm.riscv.vssrl.nxv8i16.nxv8i16.i64(<vscale x 8 x i16> poison, <vscale x 8 x i16> %op1, <vscale x 8 x i16> %shift, i64 0, i64 %vl)
294 ret <vscale x 8 x i16> %0
297 declare <vscale x 8 x i16> @llvm.riscv.vssrl.nxv8i16.nxv8i16.i64(<vscale x 8 x i16>, <vscale x 8 x i16>, <vscale x 8 x i16>, i64 immarg, i64)
299 define <vscale x 8 x i16> @test_vssrl_vx_u16m2(<vscale x 8 x i16> %op1, i64 %shift, i64 %vl) {
300 ; CHECK-LABEL: test_vssrl_vx_u16m2:
301 ; CHECK: # %bb.0: # %entry
302 ; CHECK-NEXT: csrwi vxrm, 0
303 ; CHECK-NEXT: vsetvli zero, a1, e16, m2, ta, ma
304 ; CHECK-NEXT: vssrl.vx v8, v8, a0
307 %0 = call <vscale x 8 x i16> @llvm.riscv.vssrl.nxv8i16.i64.i64(<vscale x 8 x i16> poison, <vscale x 8 x i16> %op1, i64 %shift, i64 0, i64 %vl)
308 ret <vscale x 8 x i16> %0
311 declare <vscale x 8 x i16> @llvm.riscv.vssrl.nxv8i16.i64.i64(<vscale x 8 x i16>, <vscale x 8 x i16>, i64, i64 immarg, i64)
313 define <vscale x 16 x i16> @test_vssrl_vv_u16m4(<vscale x 16 x i16> %op1, <vscale x 16 x i16> %shift, i64 %vl) {
314 ; CHECK-LABEL: test_vssrl_vv_u16m4:
315 ; CHECK: # %bb.0: # %entry
316 ; CHECK-NEXT: csrwi vxrm, 0
317 ; CHECK-NEXT: vsetvli zero, a0, e16, m4, ta, ma
318 ; CHECK-NEXT: vssrl.vv v8, v8, v12
321 %0 = call <vscale x 16 x i16> @llvm.riscv.vssrl.nxv16i16.nxv16i16.i64(<vscale x 16 x i16> poison, <vscale x 16 x i16> %op1, <vscale x 16 x i16> %shift, i64 0, i64 %vl)
322 ret <vscale x 16 x i16> %0
325 declare <vscale x 16 x i16> @llvm.riscv.vssrl.nxv16i16.nxv16i16.i64(<vscale x 16 x i16>, <vscale x 16 x i16>, <vscale x 16 x i16>, i64 immarg, i64)
327 define <vscale x 16 x i16> @test_vssrl_vx_u16m4(<vscale x 16 x i16> %op1, i64 %shift, i64 %vl) {
328 ; CHECK-LABEL: test_vssrl_vx_u16m4:
329 ; CHECK: # %bb.0: # %entry
330 ; CHECK-NEXT: csrwi vxrm, 0
331 ; CHECK-NEXT: vsetvli zero, a1, e16, m4, ta, ma
332 ; CHECK-NEXT: vssrl.vx v8, v8, a0
335 %0 = call <vscale x 16 x i16> @llvm.riscv.vssrl.nxv16i16.i64.i64(<vscale x 16 x i16> poison, <vscale x 16 x i16> %op1, i64 %shift, i64 0, i64 %vl)
336 ret <vscale x 16 x i16> %0
339 declare <vscale x 16 x i16> @llvm.riscv.vssrl.nxv16i16.i64.i64(<vscale x 16 x i16>, <vscale x 16 x i16>, i64, i64 immarg, i64)
341 define <vscale x 32 x i16> @test_vssrl_vv_u16m8(<vscale x 32 x i16> %op1, <vscale x 32 x i16> %shift, i64 %vl) {
342 ; CHECK-LABEL: test_vssrl_vv_u16m8:
343 ; CHECK: # %bb.0: # %entry
344 ; CHECK-NEXT: csrwi vxrm, 0
345 ; CHECK-NEXT: vsetvli zero, a0, e16, m8, ta, ma
346 ; CHECK-NEXT: vssrl.vv v8, v8, v16
349 %0 = call <vscale x 32 x i16> @llvm.riscv.vssrl.nxv32i16.nxv32i16.i64(<vscale x 32 x i16> poison, <vscale x 32 x i16> %op1, <vscale x 32 x i16> %shift, i64 0, i64 %vl)
350 ret <vscale x 32 x i16> %0
353 declare <vscale x 32 x i16> @llvm.riscv.vssrl.nxv32i16.nxv32i16.i64(<vscale x 32 x i16>, <vscale x 32 x i16>, <vscale x 32 x i16>, i64 immarg, i64)
355 define <vscale x 32 x i16> @test_vssrl_vx_u16m8(<vscale x 32 x i16> %op1, i64 %shift, i64 %vl) {
356 ; CHECK-LABEL: test_vssrl_vx_u16m8:
357 ; CHECK: # %bb.0: # %entry
358 ; CHECK-NEXT: csrwi vxrm, 0
359 ; CHECK-NEXT: vsetvli zero, a1, e16, m8, ta, ma
360 ; CHECK-NEXT: vssrl.vx v8, v8, a0
363 %0 = call <vscale x 32 x i16> @llvm.riscv.vssrl.nxv32i16.i64.i64(<vscale x 32 x i16> poison, <vscale x 32 x i16> %op1, i64 %shift, i64 0, i64 %vl)
364 ret <vscale x 32 x i16> %0
367 declare <vscale x 32 x i16> @llvm.riscv.vssrl.nxv32i16.i64.i64(<vscale x 32 x i16>, <vscale x 32 x i16>, i64, i64 immarg, i64)
369 define <vscale x 1 x i32> @test_vssrl_vv_u32mf2(<vscale x 1 x i32> %op1, <vscale x 1 x i32> %shift, i64 %vl) {
370 ; CHECK-LABEL: test_vssrl_vv_u32mf2:
371 ; CHECK: # %bb.0: # %entry
372 ; CHECK-NEXT: csrwi vxrm, 0
373 ; CHECK-NEXT: vsetvli zero, a0, e32, mf2, ta, ma
374 ; CHECK-NEXT: vssrl.vv v8, v8, v9
377 %0 = call <vscale x 1 x i32> @llvm.riscv.vssrl.nxv1i32.nxv1i32.i64(<vscale x 1 x i32> poison, <vscale x 1 x i32> %op1, <vscale x 1 x i32> %shift, i64 0, i64 %vl)
378 ret <vscale x 1 x i32> %0
381 declare <vscale x 1 x i32> @llvm.riscv.vssrl.nxv1i32.nxv1i32.i64(<vscale x 1 x i32>, <vscale x 1 x i32>, <vscale x 1 x i32>, i64 immarg, i64)
383 define <vscale x 1 x i32> @test_vssrl_vx_u32mf2(<vscale x 1 x i32> %op1, i64 %shift, i64 %vl) {
384 ; CHECK-LABEL: test_vssrl_vx_u32mf2:
385 ; CHECK: # %bb.0: # %entry
386 ; CHECK-NEXT: csrwi vxrm, 0
387 ; CHECK-NEXT: vsetvli zero, a1, e32, mf2, ta, ma
388 ; CHECK-NEXT: vssrl.vx v8, v8, a0
391 %0 = call <vscale x 1 x i32> @llvm.riscv.vssrl.nxv1i32.i64.i64(<vscale x 1 x i32> poison, <vscale x 1 x i32> %op1, i64 %shift, i64 0, i64 %vl)
392 ret <vscale x 1 x i32> %0
395 declare <vscale x 1 x i32> @llvm.riscv.vssrl.nxv1i32.i64.i64(<vscale x 1 x i32>, <vscale x 1 x i32>, i64, i64 immarg, i64)
397 define <vscale x 2 x i32> @test_vssrl_vv_u32m1(<vscale x 2 x i32> %op1, <vscale x 2 x i32> %shift, i64 %vl) {
398 ; CHECK-LABEL: test_vssrl_vv_u32m1:
399 ; CHECK: # %bb.0: # %entry
400 ; CHECK-NEXT: csrwi vxrm, 0
401 ; CHECK-NEXT: vsetvli zero, a0, e32, m1, ta, ma
402 ; CHECK-NEXT: vssrl.vv v8, v8, v9
405 %0 = call <vscale x 2 x i32> @llvm.riscv.vssrl.nxv2i32.nxv2i32.i64(<vscale x 2 x i32> poison, <vscale x 2 x i32> %op1, <vscale x 2 x i32> %shift, i64 0, i64 %vl)
406 ret <vscale x 2 x i32> %0
409 declare <vscale x 2 x i32> @llvm.riscv.vssrl.nxv2i32.nxv2i32.i64(<vscale x 2 x i32>, <vscale x 2 x i32>, <vscale x 2 x i32>, i64 immarg, i64)
411 define <vscale x 2 x i32> @test_vssrl_vx_u32m1(<vscale x 2 x i32> %op1, i64 %shift, i64 %vl) {
412 ; CHECK-LABEL: test_vssrl_vx_u32m1:
413 ; CHECK: # %bb.0: # %entry
414 ; CHECK-NEXT: csrwi vxrm, 0
415 ; CHECK-NEXT: vsetvli zero, a1, e32, m1, ta, ma
416 ; CHECK-NEXT: vssrl.vx v8, v8, a0
419 %0 = call <vscale x 2 x i32> @llvm.riscv.vssrl.nxv2i32.i64.i64(<vscale x 2 x i32> poison, <vscale x 2 x i32> %op1, i64 %shift, i64 0, i64 %vl)
420 ret <vscale x 2 x i32> %0
423 declare <vscale x 2 x i32> @llvm.riscv.vssrl.nxv2i32.i64.i64(<vscale x 2 x i32>, <vscale x 2 x i32>, i64, i64 immarg, i64)
425 define <vscale x 4 x i32> @test_vssrl_vv_u32m2(<vscale x 4 x i32> %op1, <vscale x 4 x i32> %shift, i64 %vl) {
426 ; CHECK-LABEL: test_vssrl_vv_u32m2:
427 ; CHECK: # %bb.0: # %entry
428 ; CHECK-NEXT: csrwi vxrm, 0
429 ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma
430 ; CHECK-NEXT: vssrl.vv v8, v8, v10
433 %0 = call <vscale x 4 x i32> @llvm.riscv.vssrl.nxv4i32.nxv4i32.i64(<vscale x 4 x i32> poison, <vscale x 4 x i32> %op1, <vscale x 4 x i32> %shift, i64 0, i64 %vl)
434 ret <vscale x 4 x i32> %0
437 declare <vscale x 4 x i32> @llvm.riscv.vssrl.nxv4i32.nxv4i32.i64(<vscale x 4 x i32>, <vscale x 4 x i32>, <vscale x 4 x i32>, i64 immarg, i64)
439 define <vscale x 4 x i32> @test_vssrl_vx_u32m2(<vscale x 4 x i32> %op1, i64 %shift, i64 %vl) {
440 ; CHECK-LABEL: test_vssrl_vx_u32m2:
441 ; CHECK: # %bb.0: # %entry
442 ; CHECK-NEXT: csrwi vxrm, 0
443 ; CHECK-NEXT: vsetvli zero, a1, e32, m2, ta, ma
444 ; CHECK-NEXT: vssrl.vx v8, v8, a0
447 %0 = call <vscale x 4 x i32> @llvm.riscv.vssrl.nxv4i32.i64.i64(<vscale x 4 x i32> poison, <vscale x 4 x i32> %op1, i64 %shift, i64 0, i64 %vl)
448 ret <vscale x 4 x i32> %0
451 declare <vscale x 4 x i32> @llvm.riscv.vssrl.nxv4i32.i64.i64(<vscale x 4 x i32>, <vscale x 4 x i32>, i64, i64 immarg, i64)
453 define <vscale x 8 x i32> @test_vssrl_vv_u32m4(<vscale x 8 x i32> %op1, <vscale x 8 x i32> %shift, i64 %vl) {
454 ; CHECK-LABEL: test_vssrl_vv_u32m4:
455 ; CHECK: # %bb.0: # %entry
456 ; CHECK-NEXT: csrwi vxrm, 0
457 ; CHECK-NEXT: vsetvli zero, a0, e32, m4, ta, ma
458 ; CHECK-NEXT: vssrl.vv v8, v8, v12
461 %0 = call <vscale x 8 x i32> @llvm.riscv.vssrl.nxv8i32.nxv8i32.i64(<vscale x 8 x i32> poison, <vscale x 8 x i32> %op1, <vscale x 8 x i32> %shift, i64 0, i64 %vl)
462 ret <vscale x 8 x i32> %0
465 declare <vscale x 8 x i32> @llvm.riscv.vssrl.nxv8i32.nxv8i32.i64(<vscale x 8 x i32>, <vscale x 8 x i32>, <vscale x 8 x i32>, i64 immarg, i64)
467 define <vscale x 8 x i32> @test_vssrl_vx_u32m4(<vscale x 8 x i32> %op1, i64 %shift, i64 %vl) {
468 ; CHECK-LABEL: test_vssrl_vx_u32m4:
469 ; CHECK: # %bb.0: # %entry
470 ; CHECK-NEXT: csrwi vxrm, 0
471 ; CHECK-NEXT: vsetvli zero, a1, e32, m4, ta, ma
472 ; CHECK-NEXT: vssrl.vx v8, v8, a0
475 %0 = call <vscale x 8 x i32> @llvm.riscv.vssrl.nxv8i32.i64.i64(<vscale x 8 x i32> poison, <vscale x 8 x i32> %op1, i64 %shift, i64 0, i64 %vl)
476 ret <vscale x 8 x i32> %0
479 declare <vscale x 8 x i32> @llvm.riscv.vssrl.nxv8i32.i64.i64(<vscale x 8 x i32>, <vscale x 8 x i32>, i64, i64 immarg, i64)
481 define <vscale x 16 x i32> @test_vssrl_vv_u32m8(<vscale x 16 x i32> %op1, <vscale x 16 x i32> %shift, i64 %vl) {
482 ; CHECK-LABEL: test_vssrl_vv_u32m8:
483 ; CHECK: # %bb.0: # %entry
484 ; CHECK-NEXT: csrwi vxrm, 0
485 ; CHECK-NEXT: vsetvli zero, a0, e32, m8, ta, ma
486 ; CHECK-NEXT: vssrl.vv v8, v8, v16
489 %0 = call <vscale x 16 x i32> @llvm.riscv.vssrl.nxv16i32.nxv16i32.i64(<vscale x 16 x i32> poison, <vscale x 16 x i32> %op1, <vscale x 16 x i32> %shift, i64 0, i64 %vl)
490 ret <vscale x 16 x i32> %0
493 declare <vscale x 16 x i32> @llvm.riscv.vssrl.nxv16i32.nxv16i32.i64(<vscale x 16 x i32>, <vscale x 16 x i32>, <vscale x 16 x i32>, i64 immarg, i64)
495 define <vscale x 16 x i32> @test_vssrl_vx_u32m8(<vscale x 16 x i32> %op1, i64 %shift, i64 %vl) {
496 ; CHECK-LABEL: test_vssrl_vx_u32m8:
497 ; CHECK: # %bb.0: # %entry
498 ; CHECK-NEXT: csrwi vxrm, 0
499 ; CHECK-NEXT: vsetvli zero, a1, e32, m8, ta, ma
500 ; CHECK-NEXT: vssrl.vx v8, v8, a0
503 %0 = call <vscale x 16 x i32> @llvm.riscv.vssrl.nxv16i32.i64.i64(<vscale x 16 x i32> poison, <vscale x 16 x i32> %op1, i64 %shift, i64 0, i64 %vl)
504 ret <vscale x 16 x i32> %0
507 declare <vscale x 16 x i32> @llvm.riscv.vssrl.nxv16i32.i64.i64(<vscale x 16 x i32>, <vscale x 16 x i32>, i64, i64 immarg, i64)
509 define <vscale x 1 x i64> @test_vssrl_vv_u64m1(<vscale x 1 x i64> %op1, <vscale x 1 x i64> %shift, i64 %vl) {
510 ; CHECK-LABEL: test_vssrl_vv_u64m1:
511 ; CHECK: # %bb.0: # %entry
512 ; CHECK-NEXT: csrwi vxrm, 0
513 ; CHECK-NEXT: vsetvli zero, a0, e64, m1, ta, ma
514 ; CHECK-NEXT: vssrl.vv v8, v8, v9
517 %0 = call <vscale x 1 x i64> @llvm.riscv.vssrl.nxv1i64.nxv1i64.i64(<vscale x 1 x i64> poison, <vscale x 1 x i64> %op1, <vscale x 1 x i64> %shift, i64 0, i64 %vl)
518 ret <vscale x 1 x i64> %0
521 declare <vscale x 1 x i64> @llvm.riscv.vssrl.nxv1i64.nxv1i64.i64(<vscale x 1 x i64>, <vscale x 1 x i64>, <vscale x 1 x i64>, i64 immarg, i64)
523 define <vscale x 1 x i64> @test_vssrl_vx_u64m1(<vscale x 1 x i64> %op1, i64 %shift, i64 %vl) {
524 ; CHECK-LABEL: test_vssrl_vx_u64m1:
525 ; CHECK: # %bb.0: # %entry
526 ; CHECK-NEXT: csrwi vxrm, 0
527 ; CHECK-NEXT: vsetvli zero, a1, e64, m1, ta, ma
528 ; CHECK-NEXT: vssrl.vx v8, v8, a0
531 %0 = call <vscale x 1 x i64> @llvm.riscv.vssrl.nxv1i64.i64.i64(<vscale x 1 x i64> poison, <vscale x 1 x i64> %op1, i64 %shift, i64 0, i64 %vl)
532 ret <vscale x 1 x i64> %0
535 declare <vscale x 1 x i64> @llvm.riscv.vssrl.nxv1i64.i64.i64(<vscale x 1 x i64>, <vscale x 1 x i64>, i64, i64 immarg, i64)
537 define <vscale x 2 x i64> @test_vssrl_vv_u64m2(<vscale x 2 x i64> %op1, <vscale x 2 x i64> %shift, i64 %vl) {
538 ; CHECK-LABEL: test_vssrl_vv_u64m2:
539 ; CHECK: # %bb.0: # %entry
540 ; CHECK-NEXT: csrwi vxrm, 0
541 ; CHECK-NEXT: vsetvli zero, a0, e64, m2, ta, ma
542 ; CHECK-NEXT: vssrl.vv v8, v8, v10
545 %0 = call <vscale x 2 x i64> @llvm.riscv.vssrl.nxv2i64.nxv2i64.i64(<vscale x 2 x i64> poison, <vscale x 2 x i64> %op1, <vscale x 2 x i64> %shift, i64 0, i64 %vl)
546 ret <vscale x 2 x i64> %0
549 declare <vscale x 2 x i64> @llvm.riscv.vssrl.nxv2i64.nxv2i64.i64(<vscale x 2 x i64>, <vscale x 2 x i64>, <vscale x 2 x i64>, i64 immarg, i64)
551 define <vscale x 2 x i64> @test_vssrl_vx_u64m2(<vscale x 2 x i64> %op1, i64 %shift, i64 %vl) {
552 ; CHECK-LABEL: test_vssrl_vx_u64m2:
553 ; CHECK: # %bb.0: # %entry
554 ; CHECK-NEXT: csrwi vxrm, 0
555 ; CHECK-NEXT: vsetvli zero, a1, e64, m2, ta, ma
556 ; CHECK-NEXT: vssrl.vx v8, v8, a0
559 %0 = call <vscale x 2 x i64> @llvm.riscv.vssrl.nxv2i64.i64.i64(<vscale x 2 x i64> poison, <vscale x 2 x i64> %op1, i64 %shift, i64 0, i64 %vl)
560 ret <vscale x 2 x i64> %0
563 declare <vscale x 2 x i64> @llvm.riscv.vssrl.nxv2i64.i64.i64(<vscale x 2 x i64>, <vscale x 2 x i64>, i64, i64 immarg, i64)
565 define <vscale x 4 x i64> @test_vssrl_vv_u64m4(<vscale x 4 x i64> %op1, <vscale x 4 x i64> %shift, i64 %vl) {
566 ; CHECK-LABEL: test_vssrl_vv_u64m4:
567 ; CHECK: # %bb.0: # %entry
568 ; CHECK-NEXT: csrwi vxrm, 0
569 ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma
570 ; CHECK-NEXT: vssrl.vv v8, v8, v12
573 %0 = call <vscale x 4 x i64> @llvm.riscv.vssrl.nxv4i64.nxv4i64.i64(<vscale x 4 x i64> poison, <vscale x 4 x i64> %op1, <vscale x 4 x i64> %shift, i64 0, i64 %vl)
574 ret <vscale x 4 x i64> %0
577 declare <vscale x 4 x i64> @llvm.riscv.vssrl.nxv4i64.nxv4i64.i64(<vscale x 4 x i64>, <vscale x 4 x i64>, <vscale x 4 x i64>, i64 immarg, i64)
579 define <vscale x 4 x i64> @test_vssrl_vx_u64m4(<vscale x 4 x i64> %op1, i64 %shift, i64 %vl) {
580 ; CHECK-LABEL: test_vssrl_vx_u64m4:
581 ; CHECK: # %bb.0: # %entry
582 ; CHECK-NEXT: csrwi vxrm, 0
583 ; CHECK-NEXT: vsetvli zero, a1, e64, m4, ta, ma
584 ; CHECK-NEXT: vssrl.vx v8, v8, a0
587 %0 = call <vscale x 4 x i64> @llvm.riscv.vssrl.nxv4i64.i64.i64(<vscale x 4 x i64> poison, <vscale x 4 x i64> %op1, i64 %shift, i64 0, i64 %vl)
588 ret <vscale x 4 x i64> %0
591 declare <vscale x 4 x i64> @llvm.riscv.vssrl.nxv4i64.i64.i64(<vscale x 4 x i64>, <vscale x 4 x i64>, i64, i64 immarg, i64)
593 define <vscale x 8 x i64> @test_vssrl_vv_u64m8(<vscale x 8 x i64> %op1, <vscale x 8 x i64> %shift, i64 %vl) {
594 ; CHECK-LABEL: test_vssrl_vv_u64m8:
595 ; CHECK: # %bb.0: # %entry
596 ; CHECK-NEXT: csrwi vxrm, 0
597 ; CHECK-NEXT: vsetvli zero, a0, e64, m8, ta, ma
598 ; CHECK-NEXT: vssrl.vv v8, v8, v16
601 %0 = call <vscale x 8 x i64> @llvm.riscv.vssrl.nxv8i64.nxv8i64.i64(<vscale x 8 x i64> poison, <vscale x 8 x i64> %op1, <vscale x 8 x i64> %shift, i64 0, i64 %vl)
602 ret <vscale x 8 x i64> %0
605 declare <vscale x 8 x i64> @llvm.riscv.vssrl.nxv8i64.nxv8i64.i64(<vscale x 8 x i64>, <vscale x 8 x i64>, <vscale x 8 x i64>, i64 immarg, i64)
607 define <vscale x 8 x i64> @test_vssrl_vx_u64m8(<vscale x 8 x i64> %op1, i64 %shift, i64 %vl) {
608 ; CHECK-LABEL: test_vssrl_vx_u64m8:
609 ; CHECK: # %bb.0: # %entry
610 ; CHECK-NEXT: csrwi vxrm, 0
611 ; CHECK-NEXT: vsetvli zero, a1, e64, m8, ta, ma
612 ; CHECK-NEXT: vssrl.vx v8, v8, a0
615 %0 = call <vscale x 8 x i64> @llvm.riscv.vssrl.nxv8i64.i64.i64(<vscale x 8 x i64> poison, <vscale x 8 x i64> %op1, i64 %shift, i64 0, i64 %vl)
616 ret <vscale x 8 x i64> %0
619 declare <vscale x 8 x i64> @llvm.riscv.vssrl.nxv8i64.i64.i64(<vscale x 8 x i64>, <vscale x 8 x i64>, i64, i64 immarg, i64)
621 define <vscale x 1 x i8> @test_vssrl_vv_u8mf8_m(<vscale x 1 x i1> %mask, <vscale x 1 x i8> %op1, <vscale x 1 x i8> %shift, i64 %vl) {
622 ; CHECK-LABEL: test_vssrl_vv_u8mf8_m:
623 ; CHECK: # %bb.0: # %entry
624 ; CHECK-NEXT: csrwi vxrm, 0
625 ; CHECK-NEXT: vsetvli zero, a0, e8, mf8, ta, ma
626 ; CHECK-NEXT: vssrl.vv v8, v8, v9, v0.t
629 %0 = call <vscale x 1 x i8> @llvm.riscv.vssrl.mask.nxv1i8.nxv1i8.i64(<vscale x 1 x i8> poison, <vscale x 1 x i8> %op1, <vscale x 1 x i8> %shift, <vscale x 1 x i1> %mask, i64 0, i64 %vl, i64 3)
630 ret <vscale x 1 x i8> %0
633 declare <vscale x 1 x i8> @llvm.riscv.vssrl.mask.nxv1i8.nxv1i8.i64(<vscale x 1 x i8>, <vscale x 1 x i8>, <vscale x 1 x i8>, <vscale x 1 x i1>, i64 immarg, i64, i64 immarg)
635 define <vscale x 1 x i8> @test_vssrl_vx_u8mf8_m(<vscale x 1 x i1> %mask, <vscale x 1 x i8> %op1, i64 %shift, i64 %vl) {
636 ; CHECK-LABEL: test_vssrl_vx_u8mf8_m:
637 ; CHECK: # %bb.0: # %entry
638 ; CHECK-NEXT: csrwi vxrm, 0
639 ; CHECK-NEXT: vsetvli zero, a1, e8, mf8, ta, ma
640 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
643 %0 = call <vscale x 1 x i8> @llvm.riscv.vssrl.mask.nxv1i8.i64.i64(<vscale x 1 x i8> poison, <vscale x 1 x i8> %op1, i64 %shift, <vscale x 1 x i1> %mask, i64 0, i64 %vl, i64 3)
644 ret <vscale x 1 x i8> %0
647 declare <vscale x 1 x i8> @llvm.riscv.vssrl.mask.nxv1i8.i64.i64(<vscale x 1 x i8>, <vscale x 1 x i8>, i64, <vscale x 1 x i1>, i64 immarg, i64, i64 immarg)
649 define <vscale x 2 x i8> @test_vssrl_vv_u8mf4_m(<vscale x 2 x i1> %mask, <vscale x 2 x i8> %op1, <vscale x 2 x i8> %shift, i64 %vl) {
650 ; CHECK-LABEL: test_vssrl_vv_u8mf4_m:
651 ; CHECK: # %bb.0: # %entry
652 ; CHECK-NEXT: csrwi vxrm, 0
653 ; CHECK-NEXT: vsetvli zero, a0, e8, mf4, ta, ma
654 ; CHECK-NEXT: vssrl.vv v8, v8, v9, v0.t
657 %0 = call <vscale x 2 x i8> @llvm.riscv.vssrl.mask.nxv2i8.nxv2i8.i64(<vscale x 2 x i8> poison, <vscale x 2 x i8> %op1, <vscale x 2 x i8> %shift, <vscale x 2 x i1> %mask, i64 0, i64 %vl, i64 3)
658 ret <vscale x 2 x i8> %0
661 declare <vscale x 2 x i8> @llvm.riscv.vssrl.mask.nxv2i8.nxv2i8.i64(<vscale x 2 x i8>, <vscale x 2 x i8>, <vscale x 2 x i8>, <vscale x 2 x i1>, i64 immarg, i64, i64 immarg)
663 define <vscale x 2 x i8> @test_vssrl_vx_u8mf4_m(<vscale x 2 x i1> %mask, <vscale x 2 x i8> %op1, i64 %shift, i64 %vl) {
664 ; CHECK-LABEL: test_vssrl_vx_u8mf4_m:
665 ; CHECK: # %bb.0: # %entry
666 ; CHECK-NEXT: csrwi vxrm, 0
667 ; CHECK-NEXT: vsetvli zero, a1, e8, mf4, ta, ma
668 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
671 %0 = call <vscale x 2 x i8> @llvm.riscv.vssrl.mask.nxv2i8.i64.i64(<vscale x 2 x i8> poison, <vscale x 2 x i8> %op1, i64 %shift, <vscale x 2 x i1> %mask, i64 0, i64 %vl, i64 3)
672 ret <vscale x 2 x i8> %0
675 declare <vscale x 2 x i8> @llvm.riscv.vssrl.mask.nxv2i8.i64.i64(<vscale x 2 x i8>, <vscale x 2 x i8>, i64, <vscale x 2 x i1>, i64 immarg, i64, i64 immarg)
677 define <vscale x 4 x i8> @test_vssrl_vv_u8mf2_m(<vscale x 4 x i1> %mask, <vscale x 4 x i8> %op1, <vscale x 4 x i8> %shift, i64 %vl) {
678 ; CHECK-LABEL: test_vssrl_vv_u8mf2_m:
679 ; CHECK: # %bb.0: # %entry
680 ; CHECK-NEXT: csrwi vxrm, 0
681 ; CHECK-NEXT: vsetvli zero, a0, e8, mf2, ta, ma
682 ; CHECK-NEXT: vssrl.vv v8, v8, v9, v0.t
685 %0 = call <vscale x 4 x i8> @llvm.riscv.vssrl.mask.nxv4i8.nxv4i8.i64(<vscale x 4 x i8> poison, <vscale x 4 x i8> %op1, <vscale x 4 x i8> %shift, <vscale x 4 x i1> %mask, i64 0, i64 %vl, i64 3)
686 ret <vscale x 4 x i8> %0
689 declare <vscale x 4 x i8> @llvm.riscv.vssrl.mask.nxv4i8.nxv4i8.i64(<vscale x 4 x i8>, <vscale x 4 x i8>, <vscale x 4 x i8>, <vscale x 4 x i1>, i64 immarg, i64, i64 immarg)
691 define <vscale x 4 x i8> @test_vssrl_vx_u8mf2_m(<vscale x 4 x i1> %mask, <vscale x 4 x i8> %op1, i64 %shift, i64 %vl) {
692 ; CHECK-LABEL: test_vssrl_vx_u8mf2_m:
693 ; CHECK: # %bb.0: # %entry
694 ; CHECK-NEXT: csrwi vxrm, 0
695 ; CHECK-NEXT: vsetvli zero, a1, e8, mf2, ta, ma
696 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
699 %0 = call <vscale x 4 x i8> @llvm.riscv.vssrl.mask.nxv4i8.i64.i64(<vscale x 4 x i8> poison, <vscale x 4 x i8> %op1, i64 %shift, <vscale x 4 x i1> %mask, i64 0, i64 %vl, i64 3)
700 ret <vscale x 4 x i8> %0
703 declare <vscale x 4 x i8> @llvm.riscv.vssrl.mask.nxv4i8.i64.i64(<vscale x 4 x i8>, <vscale x 4 x i8>, i64, <vscale x 4 x i1>, i64 immarg, i64, i64 immarg)
705 define <vscale x 8 x i8> @test_vssrl_vv_u8m1_m(<vscale x 8 x i1> %mask, <vscale x 8 x i8> %op1, <vscale x 8 x i8> %shift, i64 %vl) {
706 ; CHECK-LABEL: test_vssrl_vv_u8m1_m:
707 ; CHECK: # %bb.0: # %entry
708 ; CHECK-NEXT: csrwi vxrm, 0
709 ; CHECK-NEXT: vsetvli zero, a0, e8, m1, ta, ma
710 ; CHECK-NEXT: vssrl.vv v8, v8, v9, v0.t
713 %0 = call <vscale x 8 x i8> @llvm.riscv.vssrl.mask.nxv8i8.nxv8i8.i64(<vscale x 8 x i8> poison, <vscale x 8 x i8> %op1, <vscale x 8 x i8> %shift, <vscale x 8 x i1> %mask, i64 0, i64 %vl, i64 3)
714 ret <vscale x 8 x i8> %0
717 declare <vscale x 8 x i8> @llvm.riscv.vssrl.mask.nxv8i8.nxv8i8.i64(<vscale x 8 x i8>, <vscale x 8 x i8>, <vscale x 8 x i8>, <vscale x 8 x i1>, i64 immarg, i64, i64 immarg)
719 define <vscale x 8 x i8> @test_vssrl_vx_u8m1_m(<vscale x 8 x i1> %mask, <vscale x 8 x i8> %op1, i64 %shift, i64 %vl) {
720 ; CHECK-LABEL: test_vssrl_vx_u8m1_m:
721 ; CHECK: # %bb.0: # %entry
722 ; CHECK-NEXT: csrwi vxrm, 0
723 ; CHECK-NEXT: vsetvli zero, a1, e8, m1, ta, ma
724 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
727 %0 = call <vscale x 8 x i8> @llvm.riscv.vssrl.mask.nxv8i8.i64.i64(<vscale x 8 x i8> poison, <vscale x 8 x i8> %op1, i64 %shift, <vscale x 8 x i1> %mask, i64 0, i64 %vl, i64 3)
728 ret <vscale x 8 x i8> %0
731 declare <vscale x 8 x i8> @llvm.riscv.vssrl.mask.nxv8i8.i64.i64(<vscale x 8 x i8>, <vscale x 8 x i8>, i64, <vscale x 8 x i1>, i64 immarg, i64, i64 immarg)
733 define <vscale x 16 x i8> @test_vssrl_vv_u8m2_m(<vscale x 16 x i1> %mask, <vscale x 16 x i8> %op1, <vscale x 16 x i8> %shift, i64 %vl) {
734 ; CHECK-LABEL: test_vssrl_vv_u8m2_m:
735 ; CHECK: # %bb.0: # %entry
736 ; CHECK-NEXT: csrwi vxrm, 0
737 ; CHECK-NEXT: vsetvli zero, a0, e8, m2, ta, ma
738 ; CHECK-NEXT: vssrl.vv v8, v8, v10, v0.t
741 %0 = call <vscale x 16 x i8> @llvm.riscv.vssrl.mask.nxv16i8.nxv16i8.i64(<vscale x 16 x i8> poison, <vscale x 16 x i8> %op1, <vscale x 16 x i8> %shift, <vscale x 16 x i1> %mask, i64 0, i64 %vl, i64 3)
742 ret <vscale x 16 x i8> %0
745 declare <vscale x 16 x i8> @llvm.riscv.vssrl.mask.nxv16i8.nxv16i8.i64(<vscale x 16 x i8>, <vscale x 16 x i8>, <vscale x 16 x i8>, <vscale x 16 x i1>, i64 immarg, i64, i64 immarg)
747 define <vscale x 16 x i8> @test_vssrl_vx_u8m2_m(<vscale x 16 x i1> %mask, <vscale x 16 x i8> %op1, i64 %shift, i64 %vl) {
748 ; CHECK-LABEL: test_vssrl_vx_u8m2_m:
749 ; CHECK: # %bb.0: # %entry
750 ; CHECK-NEXT: csrwi vxrm, 0
751 ; CHECK-NEXT: vsetvli zero, a1, e8, m2, ta, ma
752 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
755 %0 = call <vscale x 16 x i8> @llvm.riscv.vssrl.mask.nxv16i8.i64.i64(<vscale x 16 x i8> poison, <vscale x 16 x i8> %op1, i64 %shift, <vscale x 16 x i1> %mask, i64 0, i64 %vl, i64 3)
756 ret <vscale x 16 x i8> %0
759 declare <vscale x 16 x i8> @llvm.riscv.vssrl.mask.nxv16i8.i64.i64(<vscale x 16 x i8>, <vscale x 16 x i8>, i64, <vscale x 16 x i1>, i64 immarg, i64, i64 immarg)
761 define <vscale x 32 x i8> @test_vssrl_vv_u8m4_m(<vscale x 32 x i1> %mask, <vscale x 32 x i8> %op1, <vscale x 32 x i8> %shift, i64 %vl) {
762 ; CHECK-LABEL: test_vssrl_vv_u8m4_m:
763 ; CHECK: # %bb.0: # %entry
764 ; CHECK-NEXT: csrwi vxrm, 0
765 ; CHECK-NEXT: vsetvli zero, a0, e8, m4, ta, ma
766 ; CHECK-NEXT: vssrl.vv v8, v8, v12, v0.t
769 %0 = call <vscale x 32 x i8> @llvm.riscv.vssrl.mask.nxv32i8.nxv32i8.i64(<vscale x 32 x i8> poison, <vscale x 32 x i8> %op1, <vscale x 32 x i8> %shift, <vscale x 32 x i1> %mask, i64 0, i64 %vl, i64 3)
770 ret <vscale x 32 x i8> %0
773 declare <vscale x 32 x i8> @llvm.riscv.vssrl.mask.nxv32i8.nxv32i8.i64(<vscale x 32 x i8>, <vscale x 32 x i8>, <vscale x 32 x i8>, <vscale x 32 x i1>, i64 immarg, i64, i64 immarg)
775 define <vscale x 32 x i8> @test_vssrl_vx_u8m4_m(<vscale x 32 x i1> %mask, <vscale x 32 x i8> %op1, i64 %shift, i64 %vl) {
776 ; CHECK-LABEL: test_vssrl_vx_u8m4_m:
777 ; CHECK: # %bb.0: # %entry
778 ; CHECK-NEXT: csrwi vxrm, 0
779 ; CHECK-NEXT: vsetvli zero, a1, e8, m4, ta, ma
780 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
783 %0 = call <vscale x 32 x i8> @llvm.riscv.vssrl.mask.nxv32i8.i64.i64(<vscale x 32 x i8> poison, <vscale x 32 x i8> %op1, i64 %shift, <vscale x 32 x i1> %mask, i64 0, i64 %vl, i64 3)
784 ret <vscale x 32 x i8> %0
787 declare <vscale x 32 x i8> @llvm.riscv.vssrl.mask.nxv32i8.i64.i64(<vscale x 32 x i8>, <vscale x 32 x i8>, i64, <vscale x 32 x i1>, i64 immarg, i64, i64 immarg)
789 define <vscale x 64 x i8> @test_vssrl_vv_u8m8_m(<vscale x 64 x i1> %mask, <vscale x 64 x i8> %op1, <vscale x 64 x i8> %shift, i64 %vl) {
790 ; CHECK-LABEL: test_vssrl_vv_u8m8_m:
791 ; CHECK: # %bb.0: # %entry
792 ; CHECK-NEXT: csrwi vxrm, 0
793 ; CHECK-NEXT: vsetvli zero, a0, e8, m8, ta, ma
794 ; CHECK-NEXT: vssrl.vv v8, v8, v16, v0.t
797 %0 = call <vscale x 64 x i8> @llvm.riscv.vssrl.mask.nxv64i8.nxv64i8.i64(<vscale x 64 x i8> poison, <vscale x 64 x i8> %op1, <vscale x 64 x i8> %shift, <vscale x 64 x i1> %mask, i64 0, i64 %vl, i64 3)
798 ret <vscale x 64 x i8> %0
801 declare <vscale x 64 x i8> @llvm.riscv.vssrl.mask.nxv64i8.nxv64i8.i64(<vscale x 64 x i8>, <vscale x 64 x i8>, <vscale x 64 x i8>, <vscale x 64 x i1>, i64 immarg, i64, i64 immarg)
803 define <vscale x 64 x i8> @test_vssrl_vx_u8m8_m(<vscale x 64 x i1> %mask, <vscale x 64 x i8> %op1, i64 %shift, i64 %vl) {
804 ; CHECK-LABEL: test_vssrl_vx_u8m8_m:
805 ; CHECK: # %bb.0: # %entry
806 ; CHECK-NEXT: csrwi vxrm, 0
807 ; CHECK-NEXT: vsetvli zero, a1, e8, m8, ta, ma
808 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
811 %0 = call <vscale x 64 x i8> @llvm.riscv.vssrl.mask.nxv64i8.i64.i64(<vscale x 64 x i8> poison, <vscale x 64 x i8> %op1, i64 %shift, <vscale x 64 x i1> %mask, i64 0, i64 %vl, i64 3)
812 ret <vscale x 64 x i8> %0
815 declare <vscale x 64 x i8> @llvm.riscv.vssrl.mask.nxv64i8.i64.i64(<vscale x 64 x i8>, <vscale x 64 x i8>, i64, <vscale x 64 x i1>, i64 immarg, i64, i64 immarg)
817 define <vscale x 1 x i16> @test_vssrl_vv_u16mf4_m(<vscale x 1 x i1> %mask, <vscale x 1 x i16> %op1, <vscale x 1 x i16> %shift, i64 %vl) {
818 ; CHECK-LABEL: test_vssrl_vv_u16mf4_m:
819 ; CHECK: # %bb.0: # %entry
820 ; CHECK-NEXT: csrwi vxrm, 0
821 ; CHECK-NEXT: vsetvli zero, a0, e16, mf4, ta, ma
822 ; CHECK-NEXT: vssrl.vv v8, v8, v9, v0.t
825 %0 = call <vscale x 1 x i16> @llvm.riscv.vssrl.mask.nxv1i16.nxv1i16.i64(<vscale x 1 x i16> poison, <vscale x 1 x i16> %op1, <vscale x 1 x i16> %shift, <vscale x 1 x i1> %mask, i64 0, i64 %vl, i64 3)
826 ret <vscale x 1 x i16> %0
829 declare <vscale x 1 x i16> @llvm.riscv.vssrl.mask.nxv1i16.nxv1i16.i64(<vscale x 1 x i16>, <vscale x 1 x i16>, <vscale x 1 x i16>, <vscale x 1 x i1>, i64 immarg, i64, i64 immarg)
831 define <vscale x 1 x i16> @test_vssrl_vx_u16mf4_m(<vscale x 1 x i1> %mask, <vscale x 1 x i16> %op1, i64 %shift, i64 %vl) {
832 ; CHECK-LABEL: test_vssrl_vx_u16mf4_m:
833 ; CHECK: # %bb.0: # %entry
834 ; CHECK-NEXT: csrwi vxrm, 0
835 ; CHECK-NEXT: vsetvli zero, a1, e16, mf4, ta, ma
836 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
839 %0 = call <vscale x 1 x i16> @llvm.riscv.vssrl.mask.nxv1i16.i64.i64(<vscale x 1 x i16> poison, <vscale x 1 x i16> %op1, i64 %shift, <vscale x 1 x i1> %mask, i64 0, i64 %vl, i64 3)
840 ret <vscale x 1 x i16> %0
843 declare <vscale x 1 x i16> @llvm.riscv.vssrl.mask.nxv1i16.i64.i64(<vscale x 1 x i16>, <vscale x 1 x i16>, i64, <vscale x 1 x i1>, i64 immarg, i64, i64 immarg)
845 define <vscale x 2 x i16> @test_vssrl_vv_u16mf2_m(<vscale x 2 x i1> %mask, <vscale x 2 x i16> %op1, <vscale x 2 x i16> %shift, i64 %vl) {
846 ; CHECK-LABEL: test_vssrl_vv_u16mf2_m:
847 ; CHECK: # %bb.0: # %entry
848 ; CHECK-NEXT: csrwi vxrm, 0
849 ; CHECK-NEXT: vsetvli zero, a0, e16, mf2, ta, ma
850 ; CHECK-NEXT: vssrl.vv v8, v8, v9, v0.t
853 %0 = call <vscale x 2 x i16> @llvm.riscv.vssrl.mask.nxv2i16.nxv2i16.i64(<vscale x 2 x i16> poison, <vscale x 2 x i16> %op1, <vscale x 2 x i16> %shift, <vscale x 2 x i1> %mask, i64 0, i64 %vl, i64 3)
854 ret <vscale x 2 x i16> %0
857 declare <vscale x 2 x i16> @llvm.riscv.vssrl.mask.nxv2i16.nxv2i16.i64(<vscale x 2 x i16>, <vscale x 2 x i16>, <vscale x 2 x i16>, <vscale x 2 x i1>, i64 immarg, i64, i64 immarg)
859 define <vscale x 2 x i16> @test_vssrl_vx_u16mf2_m(<vscale x 2 x i1> %mask, <vscale x 2 x i16> %op1, i64 %shift, i64 %vl) {
860 ; CHECK-LABEL: test_vssrl_vx_u16mf2_m:
861 ; CHECK: # %bb.0: # %entry
862 ; CHECK-NEXT: csrwi vxrm, 0
863 ; CHECK-NEXT: vsetvli zero, a1, e16, mf2, ta, ma
864 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
867 %0 = call <vscale x 2 x i16> @llvm.riscv.vssrl.mask.nxv2i16.i64.i64(<vscale x 2 x i16> poison, <vscale x 2 x i16> %op1, i64 %shift, <vscale x 2 x i1> %mask, i64 0, i64 %vl, i64 3)
868 ret <vscale x 2 x i16> %0
871 declare <vscale x 2 x i16> @llvm.riscv.vssrl.mask.nxv2i16.i64.i64(<vscale x 2 x i16>, <vscale x 2 x i16>, i64, <vscale x 2 x i1>, i64 immarg, i64, i64 immarg)
873 define <vscale x 4 x i16> @test_vssrl_vv_u16m1_m(<vscale x 4 x i1> %mask, <vscale x 4 x i16> %op1, <vscale x 4 x i16> %shift, i64 %vl) {
874 ; CHECK-LABEL: test_vssrl_vv_u16m1_m:
875 ; CHECK: # %bb.0: # %entry
876 ; CHECK-NEXT: csrwi vxrm, 0
877 ; CHECK-NEXT: vsetvli zero, a0, e16, m1, ta, ma
878 ; CHECK-NEXT: vssrl.vv v8, v8, v9, v0.t
881 %0 = call <vscale x 4 x i16> @llvm.riscv.vssrl.mask.nxv4i16.nxv4i16.i64(<vscale x 4 x i16> poison, <vscale x 4 x i16> %op1, <vscale x 4 x i16> %shift, <vscale x 4 x i1> %mask, i64 0, i64 %vl, i64 3)
882 ret <vscale x 4 x i16> %0
885 declare <vscale x 4 x i16> @llvm.riscv.vssrl.mask.nxv4i16.nxv4i16.i64(<vscale x 4 x i16>, <vscale x 4 x i16>, <vscale x 4 x i16>, <vscale x 4 x i1>, i64 immarg, i64, i64 immarg)
887 define <vscale x 4 x i16> @test_vssrl_vx_u16m1_m(<vscale x 4 x i1> %mask, <vscale x 4 x i16> %op1, i64 %shift, i64 %vl) {
888 ; CHECK-LABEL: test_vssrl_vx_u16m1_m:
889 ; CHECK: # %bb.0: # %entry
890 ; CHECK-NEXT: csrwi vxrm, 0
891 ; CHECK-NEXT: vsetvli zero, a1, e16, m1, ta, ma
892 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
895 %0 = call <vscale x 4 x i16> @llvm.riscv.vssrl.mask.nxv4i16.i64.i64(<vscale x 4 x i16> poison, <vscale x 4 x i16> %op1, i64 %shift, <vscale x 4 x i1> %mask, i64 0, i64 %vl, i64 3)
896 ret <vscale x 4 x i16> %0
899 declare <vscale x 4 x i16> @llvm.riscv.vssrl.mask.nxv4i16.i64.i64(<vscale x 4 x i16>, <vscale x 4 x i16>, i64, <vscale x 4 x i1>, i64 immarg, i64, i64 immarg)
901 define <vscale x 8 x i16> @test_vssrl_vv_u16m2_m(<vscale x 8 x i1> %mask, <vscale x 8 x i16> %op1, <vscale x 8 x i16> %shift, i64 %vl) {
902 ; CHECK-LABEL: test_vssrl_vv_u16m2_m:
903 ; CHECK: # %bb.0: # %entry
904 ; CHECK-NEXT: csrwi vxrm, 0
905 ; CHECK-NEXT: vsetvli zero, a0, e16, m2, ta, ma
906 ; CHECK-NEXT: vssrl.vv v8, v8, v10, v0.t
909 %0 = call <vscale x 8 x i16> @llvm.riscv.vssrl.mask.nxv8i16.nxv8i16.i64(<vscale x 8 x i16> poison, <vscale x 8 x i16> %op1, <vscale x 8 x i16> %shift, <vscale x 8 x i1> %mask, i64 0, i64 %vl, i64 3)
910 ret <vscale x 8 x i16> %0
913 declare <vscale x 8 x i16> @llvm.riscv.vssrl.mask.nxv8i16.nxv8i16.i64(<vscale x 8 x i16>, <vscale x 8 x i16>, <vscale x 8 x i16>, <vscale x 8 x i1>, i64 immarg, i64, i64 immarg)
915 define <vscale x 8 x i16> @test_vssrl_vx_u16m2_m(<vscale x 8 x i1> %mask, <vscale x 8 x i16> %op1, i64 %shift, i64 %vl) {
916 ; CHECK-LABEL: test_vssrl_vx_u16m2_m:
917 ; CHECK: # %bb.0: # %entry
918 ; CHECK-NEXT: csrwi vxrm, 0
919 ; CHECK-NEXT: vsetvli zero, a1, e16, m2, ta, ma
920 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
923 %0 = call <vscale x 8 x i16> @llvm.riscv.vssrl.mask.nxv8i16.i64.i64(<vscale x 8 x i16> poison, <vscale x 8 x i16> %op1, i64 %shift, <vscale x 8 x i1> %mask, i64 0, i64 %vl, i64 3)
924 ret <vscale x 8 x i16> %0
927 declare <vscale x 8 x i16> @llvm.riscv.vssrl.mask.nxv8i16.i64.i64(<vscale x 8 x i16>, <vscale x 8 x i16>, i64, <vscale x 8 x i1>, i64 immarg, i64, i64 immarg)
929 define <vscale x 16 x i16> @test_vssrl_vv_u16m4_m(<vscale x 16 x i1> %mask, <vscale x 16 x i16> %op1, <vscale x 16 x i16> %shift, i64 %vl) {
930 ; CHECK-LABEL: test_vssrl_vv_u16m4_m:
931 ; CHECK: # %bb.0: # %entry
932 ; CHECK-NEXT: csrwi vxrm, 0
933 ; CHECK-NEXT: vsetvli zero, a0, e16, m4, ta, ma
934 ; CHECK-NEXT: vssrl.vv v8, v8, v12, v0.t
937 %0 = call <vscale x 16 x i16> @llvm.riscv.vssrl.mask.nxv16i16.nxv16i16.i64(<vscale x 16 x i16> poison, <vscale x 16 x i16> %op1, <vscale x 16 x i16> %shift, <vscale x 16 x i1> %mask, i64 0, i64 %vl, i64 3)
938 ret <vscale x 16 x i16> %0
941 declare <vscale x 16 x i16> @llvm.riscv.vssrl.mask.nxv16i16.nxv16i16.i64(<vscale x 16 x i16>, <vscale x 16 x i16>, <vscale x 16 x i16>, <vscale x 16 x i1>, i64 immarg, i64, i64 immarg)
943 define <vscale x 16 x i16> @test_vssrl_vx_u16m4_m(<vscale x 16 x i1> %mask, <vscale x 16 x i16> %op1, i64 %shift, i64 %vl) {
944 ; CHECK-LABEL: test_vssrl_vx_u16m4_m:
945 ; CHECK: # %bb.0: # %entry
946 ; CHECK-NEXT: csrwi vxrm, 0
947 ; CHECK-NEXT: vsetvli zero, a1, e16, m4, ta, ma
948 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
951 %0 = call <vscale x 16 x i16> @llvm.riscv.vssrl.mask.nxv16i16.i64.i64(<vscale x 16 x i16> poison, <vscale x 16 x i16> %op1, i64 %shift, <vscale x 16 x i1> %mask, i64 0, i64 %vl, i64 3)
952 ret <vscale x 16 x i16> %0
955 declare <vscale x 16 x i16> @llvm.riscv.vssrl.mask.nxv16i16.i64.i64(<vscale x 16 x i16>, <vscale x 16 x i16>, i64, <vscale x 16 x i1>, i64 immarg, i64, i64 immarg)
957 define <vscale x 32 x i16> @test_vssrl_vv_u16m8_m(<vscale x 32 x i1> %mask, <vscale x 32 x i16> %op1, <vscale x 32 x i16> %shift, i64 %vl) {
958 ; CHECK-LABEL: test_vssrl_vv_u16m8_m:
959 ; CHECK: # %bb.0: # %entry
960 ; CHECK-NEXT: csrwi vxrm, 0
961 ; CHECK-NEXT: vsetvli zero, a0, e16, m8, ta, ma
962 ; CHECK-NEXT: vssrl.vv v8, v8, v16, v0.t
965 %0 = call <vscale x 32 x i16> @llvm.riscv.vssrl.mask.nxv32i16.nxv32i16.i64(<vscale x 32 x i16> poison, <vscale x 32 x i16> %op1, <vscale x 32 x i16> %shift, <vscale x 32 x i1> %mask, i64 0, i64 %vl, i64 3)
966 ret <vscale x 32 x i16> %0
969 declare <vscale x 32 x i16> @llvm.riscv.vssrl.mask.nxv32i16.nxv32i16.i64(<vscale x 32 x i16>, <vscale x 32 x i16>, <vscale x 32 x i16>, <vscale x 32 x i1>, i64 immarg, i64, i64 immarg)
971 define <vscale x 32 x i16> @test_vssrl_vx_u16m8_m(<vscale x 32 x i1> %mask, <vscale x 32 x i16> %op1, i64 %shift, i64 %vl) {
972 ; CHECK-LABEL: test_vssrl_vx_u16m8_m:
973 ; CHECK: # %bb.0: # %entry
974 ; CHECK-NEXT: csrwi vxrm, 0
975 ; CHECK-NEXT: vsetvli zero, a1, e16, m8, ta, ma
976 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
979 %0 = call <vscale x 32 x i16> @llvm.riscv.vssrl.mask.nxv32i16.i64.i64(<vscale x 32 x i16> poison, <vscale x 32 x i16> %op1, i64 %shift, <vscale x 32 x i1> %mask, i64 0, i64 %vl, i64 3)
980 ret <vscale x 32 x i16> %0
983 declare <vscale x 32 x i16> @llvm.riscv.vssrl.mask.nxv32i16.i64.i64(<vscale x 32 x i16>, <vscale x 32 x i16>, i64, <vscale x 32 x i1>, i64 immarg, i64, i64 immarg)
985 define <vscale x 1 x i32> @test_vssrl_vv_u32mf2_m(<vscale x 1 x i1> %mask, <vscale x 1 x i32> %op1, <vscale x 1 x i32> %shift, i64 %vl) {
986 ; CHECK-LABEL: test_vssrl_vv_u32mf2_m:
987 ; CHECK: # %bb.0: # %entry
988 ; CHECK-NEXT: csrwi vxrm, 0
989 ; CHECK-NEXT: vsetvli zero, a0, e32, mf2, ta, ma
990 ; CHECK-NEXT: vssrl.vv v8, v8, v9, v0.t
993 %0 = call <vscale x 1 x i32> @llvm.riscv.vssrl.mask.nxv1i32.nxv1i32.i64(<vscale x 1 x i32> poison, <vscale x 1 x i32> %op1, <vscale x 1 x i32> %shift, <vscale x 1 x i1> %mask, i64 0, i64 %vl, i64 3)
994 ret <vscale x 1 x i32> %0
997 declare <vscale x 1 x i32> @llvm.riscv.vssrl.mask.nxv1i32.nxv1i32.i64(<vscale x 1 x i32>, <vscale x 1 x i32>, <vscale x 1 x i32>, <vscale x 1 x i1>, i64 immarg, i64, i64 immarg)
999 define <vscale x 1 x i32> @test_vssrl_vx_u32mf2_m(<vscale x 1 x i1> %mask, <vscale x 1 x i32> %op1, i64 %shift, i64 %vl) {
1000 ; CHECK-LABEL: test_vssrl_vx_u32mf2_m:
1001 ; CHECK: # %bb.0: # %entry
1002 ; CHECK-NEXT: csrwi vxrm, 0
1003 ; CHECK-NEXT: vsetvli zero, a1, e32, mf2, ta, ma
1004 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
1007 %0 = call <vscale x 1 x i32> @llvm.riscv.vssrl.mask.nxv1i32.i64.i64(<vscale x 1 x i32> poison, <vscale x 1 x i32> %op1, i64 %shift, <vscale x 1 x i1> %mask, i64 0, i64 %vl, i64 3)
1008 ret <vscale x 1 x i32> %0
1011 declare <vscale x 1 x i32> @llvm.riscv.vssrl.mask.nxv1i32.i64.i64(<vscale x 1 x i32>, <vscale x 1 x i32>, i64, <vscale x 1 x i1>, i64 immarg, i64, i64 immarg)
1013 define <vscale x 2 x i32> @test_vssrl_vv_u32m1_m(<vscale x 2 x i1> %mask, <vscale x 2 x i32> %op1, <vscale x 2 x i32> %shift, i64 %vl) {
1014 ; CHECK-LABEL: test_vssrl_vv_u32m1_m:
1015 ; CHECK: # %bb.0: # %entry
1016 ; CHECK-NEXT: csrwi vxrm, 0
1017 ; CHECK-NEXT: vsetvli zero, a0, e32, m1, ta, ma
1018 ; CHECK-NEXT: vssrl.vv v8, v8, v9, v0.t
1021 %0 = call <vscale x 2 x i32> @llvm.riscv.vssrl.mask.nxv2i32.nxv2i32.i64(<vscale x 2 x i32> poison, <vscale x 2 x i32> %op1, <vscale x 2 x i32> %shift, <vscale x 2 x i1> %mask, i64 0, i64 %vl, i64 3)
1022 ret <vscale x 2 x i32> %0
1025 declare <vscale x 2 x i32> @llvm.riscv.vssrl.mask.nxv2i32.nxv2i32.i64(<vscale x 2 x i32>, <vscale x 2 x i32>, <vscale x 2 x i32>, <vscale x 2 x i1>, i64 immarg, i64, i64 immarg)
1027 define <vscale x 2 x i32> @test_vssrl_vx_u32m1_m(<vscale x 2 x i1> %mask, <vscale x 2 x i32> %op1, i64 %shift, i64 %vl) {
1028 ; CHECK-LABEL: test_vssrl_vx_u32m1_m:
1029 ; CHECK: # %bb.0: # %entry
1030 ; CHECK-NEXT: csrwi vxrm, 0
1031 ; CHECK-NEXT: vsetvli zero, a1, e32, m1, ta, ma
1032 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
1035 %0 = call <vscale x 2 x i32> @llvm.riscv.vssrl.mask.nxv2i32.i64.i64(<vscale x 2 x i32> poison, <vscale x 2 x i32> %op1, i64 %shift, <vscale x 2 x i1> %mask, i64 0, i64 %vl, i64 3)
1036 ret <vscale x 2 x i32> %0
1039 declare <vscale x 2 x i32> @llvm.riscv.vssrl.mask.nxv2i32.i64.i64(<vscale x 2 x i32>, <vscale x 2 x i32>, i64, <vscale x 2 x i1>, i64 immarg, i64, i64 immarg)
1041 define <vscale x 4 x i32> @test_vssrl_vv_u32m2_m(<vscale x 4 x i1> %mask, <vscale x 4 x i32> %op1, <vscale x 4 x i32> %shift, i64 %vl) {
1042 ; CHECK-LABEL: test_vssrl_vv_u32m2_m:
1043 ; CHECK: # %bb.0: # %entry
1044 ; CHECK-NEXT: csrwi vxrm, 0
1045 ; CHECK-NEXT: vsetvli zero, a0, e32, m2, ta, ma
1046 ; CHECK-NEXT: vssrl.vv v8, v8, v10, v0.t
1049 %0 = call <vscale x 4 x i32> @llvm.riscv.vssrl.mask.nxv4i32.nxv4i32.i64(<vscale x 4 x i32> poison, <vscale x 4 x i32> %op1, <vscale x 4 x i32> %shift, <vscale x 4 x i1> %mask, i64 0, i64 %vl, i64 3)
1050 ret <vscale x 4 x i32> %0
1053 declare <vscale x 4 x i32> @llvm.riscv.vssrl.mask.nxv4i32.nxv4i32.i64(<vscale x 4 x i32>, <vscale x 4 x i32>, <vscale x 4 x i32>, <vscale x 4 x i1>, i64 immarg, i64, i64 immarg)
1055 define <vscale x 4 x i32> @test_vssrl_vx_u32m2_m(<vscale x 4 x i1> %mask, <vscale x 4 x i32> %op1, i64 %shift, i64 %vl) {
1056 ; CHECK-LABEL: test_vssrl_vx_u32m2_m:
1057 ; CHECK: # %bb.0: # %entry
1058 ; CHECK-NEXT: csrwi vxrm, 0
1059 ; CHECK-NEXT: vsetvli zero, a1, e32, m2, ta, ma
1060 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
1063 %0 = call <vscale x 4 x i32> @llvm.riscv.vssrl.mask.nxv4i32.i64.i64(<vscale x 4 x i32> poison, <vscale x 4 x i32> %op1, i64 %shift, <vscale x 4 x i1> %mask, i64 0, i64 %vl, i64 3)
1064 ret <vscale x 4 x i32> %0
1067 declare <vscale x 4 x i32> @llvm.riscv.vssrl.mask.nxv4i32.i64.i64(<vscale x 4 x i32>, <vscale x 4 x i32>, i64, <vscale x 4 x i1>, i64 immarg, i64, i64 immarg)
1069 define <vscale x 8 x i32> @test_vssrl_vv_u32m4_m(<vscale x 8 x i1> %mask, <vscale x 8 x i32> %op1, <vscale x 8 x i32> %shift, i64 %vl) {
1070 ; CHECK-LABEL: test_vssrl_vv_u32m4_m:
1071 ; CHECK: # %bb.0: # %entry
1072 ; CHECK-NEXT: csrwi vxrm, 0
1073 ; CHECK-NEXT: vsetvli zero, a0, e32, m4, ta, ma
1074 ; CHECK-NEXT: vssrl.vv v8, v8, v12, v0.t
1077 %0 = call <vscale x 8 x i32> @llvm.riscv.vssrl.mask.nxv8i32.nxv8i32.i64(<vscale x 8 x i32> poison, <vscale x 8 x i32> %op1, <vscale x 8 x i32> %shift, <vscale x 8 x i1> %mask, i64 0, i64 %vl, i64 3)
1078 ret <vscale x 8 x i32> %0
1081 declare <vscale x 8 x i32> @llvm.riscv.vssrl.mask.nxv8i32.nxv8i32.i64(<vscale x 8 x i32>, <vscale x 8 x i32>, <vscale x 8 x i32>, <vscale x 8 x i1>, i64 immarg, i64, i64 immarg)
1083 define <vscale x 8 x i32> @test_vssrl_vx_u32m4_m(<vscale x 8 x i1> %mask, <vscale x 8 x i32> %op1, i64 %shift, i64 %vl) {
1084 ; CHECK-LABEL: test_vssrl_vx_u32m4_m:
1085 ; CHECK: # %bb.0: # %entry
1086 ; CHECK-NEXT: csrwi vxrm, 0
1087 ; CHECK-NEXT: vsetvli zero, a1, e32, m4, ta, ma
1088 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
1091 %0 = call <vscale x 8 x i32> @llvm.riscv.vssrl.mask.nxv8i32.i64.i64(<vscale x 8 x i32> poison, <vscale x 8 x i32> %op1, i64 %shift, <vscale x 8 x i1> %mask, i64 0, i64 %vl, i64 3)
1092 ret <vscale x 8 x i32> %0
1095 declare <vscale x 8 x i32> @llvm.riscv.vssrl.mask.nxv8i32.i64.i64(<vscale x 8 x i32>, <vscale x 8 x i32>, i64, <vscale x 8 x i1>, i64 immarg, i64, i64 immarg)
1097 define <vscale x 16 x i32> @test_vssrl_vv_u32m8_m(<vscale x 16 x i1> %mask, <vscale x 16 x i32> %op1, <vscale x 16 x i32> %shift, i64 %vl) {
1098 ; CHECK-LABEL: test_vssrl_vv_u32m8_m:
1099 ; CHECK: # %bb.0: # %entry
1100 ; CHECK-NEXT: csrwi vxrm, 0
1101 ; CHECK-NEXT: vsetvli zero, a0, e32, m8, ta, ma
1102 ; CHECK-NEXT: vssrl.vv v8, v8, v16, v0.t
1105 %0 = call <vscale x 16 x i32> @llvm.riscv.vssrl.mask.nxv16i32.nxv16i32.i64(<vscale x 16 x i32> poison, <vscale x 16 x i32> %op1, <vscale x 16 x i32> %shift, <vscale x 16 x i1> %mask, i64 0, i64 %vl, i64 3)
1106 ret <vscale x 16 x i32> %0
1109 declare <vscale x 16 x i32> @llvm.riscv.vssrl.mask.nxv16i32.nxv16i32.i64(<vscale x 16 x i32>, <vscale x 16 x i32>, <vscale x 16 x i32>, <vscale x 16 x i1>, i64 immarg, i64, i64 immarg)
1111 define <vscale x 16 x i32> @test_vssrl_vx_u32m8_m(<vscale x 16 x i1> %mask, <vscale x 16 x i32> %op1, i64 %shift, i64 %vl) {
1112 ; CHECK-LABEL: test_vssrl_vx_u32m8_m:
1113 ; CHECK: # %bb.0: # %entry
1114 ; CHECK-NEXT: csrwi vxrm, 0
1115 ; CHECK-NEXT: vsetvli zero, a1, e32, m8, ta, ma
1116 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
1119 %0 = call <vscale x 16 x i32> @llvm.riscv.vssrl.mask.nxv16i32.i64.i64(<vscale x 16 x i32> poison, <vscale x 16 x i32> %op1, i64 %shift, <vscale x 16 x i1> %mask, i64 0, i64 %vl, i64 3)
1120 ret <vscale x 16 x i32> %0
1123 declare <vscale x 16 x i32> @llvm.riscv.vssrl.mask.nxv16i32.i64.i64(<vscale x 16 x i32>, <vscale x 16 x i32>, i64, <vscale x 16 x i1>, i64 immarg, i64, i64 immarg)
1125 define <vscale x 1 x i64> @test_vssrl_vv_u64m1_m(<vscale x 1 x i1> %mask, <vscale x 1 x i64> %op1, <vscale x 1 x i64> %shift, i64 %vl) {
1126 ; CHECK-LABEL: test_vssrl_vv_u64m1_m:
1127 ; CHECK: # %bb.0: # %entry
1128 ; CHECK-NEXT: csrwi vxrm, 0
1129 ; CHECK-NEXT: vsetvli zero, a0, e64, m1, ta, ma
1130 ; CHECK-NEXT: vssrl.vv v8, v8, v9, v0.t
1133 %0 = call <vscale x 1 x i64> @llvm.riscv.vssrl.mask.nxv1i64.nxv1i64.i64(<vscale x 1 x i64> poison, <vscale x 1 x i64> %op1, <vscale x 1 x i64> %shift, <vscale x 1 x i1> %mask, i64 0, i64 %vl, i64 3)
1134 ret <vscale x 1 x i64> %0
1137 declare <vscale x 1 x i64> @llvm.riscv.vssrl.mask.nxv1i64.nxv1i64.i64(<vscale x 1 x i64>, <vscale x 1 x i64>, <vscale x 1 x i64>, <vscale x 1 x i1>, i64 immarg, i64, i64 immarg)
1139 define <vscale x 1 x i64> @test_vssrl_vx_u64m1_m(<vscale x 1 x i1> %mask, <vscale x 1 x i64> %op1, i64 %shift, i64 %vl) {
1140 ; CHECK-LABEL: test_vssrl_vx_u64m1_m:
1141 ; CHECK: # %bb.0: # %entry
1142 ; CHECK-NEXT: csrwi vxrm, 0
1143 ; CHECK-NEXT: vsetvli zero, a1, e64, m1, ta, ma
1144 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
1147 %0 = call <vscale x 1 x i64> @llvm.riscv.vssrl.mask.nxv1i64.i64.i64(<vscale x 1 x i64> poison, <vscale x 1 x i64> %op1, i64 %shift, <vscale x 1 x i1> %mask, i64 0, i64 %vl, i64 3)
1148 ret <vscale x 1 x i64> %0
1151 declare <vscale x 1 x i64> @llvm.riscv.vssrl.mask.nxv1i64.i64.i64(<vscale x 1 x i64>, <vscale x 1 x i64>, i64, <vscale x 1 x i1>, i64 immarg, i64, i64 immarg)
1153 define <vscale x 2 x i64> @test_vssrl_vv_u64m2_m(<vscale x 2 x i1> %mask, <vscale x 2 x i64> %op1, <vscale x 2 x i64> %shift, i64 %vl) {
1154 ; CHECK-LABEL: test_vssrl_vv_u64m2_m:
1155 ; CHECK: # %bb.0: # %entry
1156 ; CHECK-NEXT: csrwi vxrm, 0
1157 ; CHECK-NEXT: vsetvli zero, a0, e64, m2, ta, ma
1158 ; CHECK-NEXT: vssrl.vv v8, v8, v10, v0.t
1161 %0 = call <vscale x 2 x i64> @llvm.riscv.vssrl.mask.nxv2i64.nxv2i64.i64(<vscale x 2 x i64> poison, <vscale x 2 x i64> %op1, <vscale x 2 x i64> %shift, <vscale x 2 x i1> %mask, i64 0, i64 %vl, i64 3)
1162 ret <vscale x 2 x i64> %0
1165 declare <vscale x 2 x i64> @llvm.riscv.vssrl.mask.nxv2i64.nxv2i64.i64(<vscale x 2 x i64>, <vscale x 2 x i64>, <vscale x 2 x i64>, <vscale x 2 x i1>, i64 immarg, i64, i64 immarg)
1167 define <vscale x 2 x i64> @test_vssrl_vx_u64m2_m(<vscale x 2 x i1> %mask, <vscale x 2 x i64> %op1, i64 %shift, i64 %vl) {
1168 ; CHECK-LABEL: test_vssrl_vx_u64m2_m:
1169 ; CHECK: # %bb.0: # %entry
1170 ; CHECK-NEXT: csrwi vxrm, 0
1171 ; CHECK-NEXT: vsetvli zero, a1, e64, m2, ta, ma
1172 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
1175 %0 = call <vscale x 2 x i64> @llvm.riscv.vssrl.mask.nxv2i64.i64.i64(<vscale x 2 x i64> poison, <vscale x 2 x i64> %op1, i64 %shift, <vscale x 2 x i1> %mask, i64 0, i64 %vl, i64 3)
1176 ret <vscale x 2 x i64> %0
1179 declare <vscale x 2 x i64> @llvm.riscv.vssrl.mask.nxv2i64.i64.i64(<vscale x 2 x i64>, <vscale x 2 x i64>, i64, <vscale x 2 x i1>, i64 immarg, i64, i64 immarg)
1181 define <vscale x 4 x i64> @test_vssrl_vv_u64m4_m(<vscale x 4 x i1> %mask, <vscale x 4 x i64> %op1, <vscale x 4 x i64> %shift, i64 %vl) {
1182 ; CHECK-LABEL: test_vssrl_vv_u64m4_m:
1183 ; CHECK: # %bb.0: # %entry
1184 ; CHECK-NEXT: csrwi vxrm, 0
1185 ; CHECK-NEXT: vsetvli zero, a0, e64, m4, ta, ma
1186 ; CHECK-NEXT: vssrl.vv v8, v8, v12, v0.t
1189 %0 = call <vscale x 4 x i64> @llvm.riscv.vssrl.mask.nxv4i64.nxv4i64.i64(<vscale x 4 x i64> poison, <vscale x 4 x i64> %op1, <vscale x 4 x i64> %shift, <vscale x 4 x i1> %mask, i64 0, i64 %vl, i64 3)
1190 ret <vscale x 4 x i64> %0
1193 declare <vscale x 4 x i64> @llvm.riscv.vssrl.mask.nxv4i64.nxv4i64.i64(<vscale x 4 x i64>, <vscale x 4 x i64>, <vscale x 4 x i64>, <vscale x 4 x i1>, i64 immarg, i64, i64 immarg)
1195 define <vscale x 4 x i64> @test_vssrl_vx_u64m4_m(<vscale x 4 x i1> %mask, <vscale x 4 x i64> %op1, i64 %shift, i64 %vl) {
1196 ; CHECK-LABEL: test_vssrl_vx_u64m4_m:
1197 ; CHECK: # %bb.0: # %entry
1198 ; CHECK-NEXT: csrwi vxrm, 0
1199 ; CHECK-NEXT: vsetvli zero, a1, e64, m4, ta, ma
1200 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
1203 %0 = call <vscale x 4 x i64> @llvm.riscv.vssrl.mask.nxv4i64.i64.i64(<vscale x 4 x i64> poison, <vscale x 4 x i64> %op1, i64 %shift, <vscale x 4 x i1> %mask, i64 0, i64 %vl, i64 3)
1204 ret <vscale x 4 x i64> %0
1207 declare <vscale x 4 x i64> @llvm.riscv.vssrl.mask.nxv4i64.i64.i64(<vscale x 4 x i64>, <vscale x 4 x i64>, i64, <vscale x 4 x i1>, i64 immarg, i64, i64 immarg)
1209 define <vscale x 8 x i64> @test_vssrl_vv_u64m8_m(<vscale x 8 x i1> %mask, <vscale x 8 x i64> %op1, <vscale x 8 x i64> %shift, i64 %vl) {
1210 ; CHECK-LABEL: test_vssrl_vv_u64m8_m:
1211 ; CHECK: # %bb.0: # %entry
1212 ; CHECK-NEXT: csrwi vxrm, 0
1213 ; CHECK-NEXT: vsetvli zero, a0, e64, m8, ta, ma
1214 ; CHECK-NEXT: vssrl.vv v8, v8, v16, v0.t
1217 %0 = call <vscale x 8 x i64> @llvm.riscv.vssrl.mask.nxv8i64.nxv8i64.i64(<vscale x 8 x i64> poison, <vscale x 8 x i64> %op1, <vscale x 8 x i64> %shift, <vscale x 8 x i1> %mask, i64 0, i64 %vl, i64 3)
1218 ret <vscale x 8 x i64> %0
1221 declare <vscale x 8 x i64> @llvm.riscv.vssrl.mask.nxv8i64.nxv8i64.i64(<vscale x 8 x i64>, <vscale x 8 x i64>, <vscale x 8 x i64>, <vscale x 8 x i1>, i64 immarg, i64, i64 immarg)
1223 define <vscale x 8 x i64> @test_vssrl_vx_u64m8_m(<vscale x 8 x i1> %mask, <vscale x 8 x i64> %op1, i64 %shift, i64 %vl) {
1224 ; CHECK-LABEL: test_vssrl_vx_u64m8_m:
1225 ; CHECK: # %bb.0: # %entry
1226 ; CHECK-NEXT: csrwi vxrm, 0
1227 ; CHECK-NEXT: vsetvli zero, a1, e64, m8, ta, ma
1228 ; CHECK-NEXT: vssrl.vx v8, v8, a0, v0.t
1231 %0 = call <vscale x 8 x i64> @llvm.riscv.vssrl.mask.nxv8i64.i64.i64(<vscale x 8 x i64> poison, <vscale x 8 x i64> %op1, i64 %shift, <vscale x 8 x i1> %mask, i64 0, i64 %vl, i64 3)
1232 ret <vscale x 8 x i64> %0
1235 declare <vscale x 8 x i64> @llvm.riscv.vssrl.mask.nxv8i64.i64.i64(<vscale x 8 x i64>, <vscale x 8 x i64>, i64, <vscale x 8 x i1>, i64 immarg, i64, i64 immarg)