Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / RISCV / rvv / vssseg-rv64.ll
blob2ef2173696771c3a17099d802dd77e963727c1a6
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -mtriple=riscv64 -mattr=+zve64d,+f,+d,+zfh,+zvfh \
3 ; RUN:     -verify-machineinstrs < %s | FileCheck %s
5 declare void @llvm.riscv.vssseg2.nxv16i16(<vscale x 16 x i16>,<vscale x 16 x i16>, ptr, i64, i64)
6 declare void @llvm.riscv.vssseg2.mask.nxv16i16(<vscale x 16 x i16>,<vscale x 16 x i16>, ptr, i64, <vscale x 16 x i1>, i64)
8 define void @test_vssseg2_nxv16i16(<vscale x 16 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
9 ; CHECK-LABEL: test_vssseg2_nxv16i16:
10 ; CHECK:       # %bb.0: # %entry
11 ; CHECK-NEXT:    vmv4r.v v12, v8
12 ; CHECK-NEXT:    vsetvli zero, a2, e16, m4, ta, ma
13 ; CHECK-NEXT:    vssseg2e16.v v8, (a0), a1
14 ; CHECK-NEXT:    ret
15 entry:
16   tail call void @llvm.riscv.vssseg2.nxv16i16(<vscale x 16 x i16> %val,<vscale x 16 x i16> %val, ptr %base, i64 %offset, i64 %vl)
17   ret void
20 define void @test_vssseg2_mask_nxv16i16(<vscale x 16 x i16> %val, ptr %base, i64 %offset, <vscale x 16 x i1> %mask, i64 %vl) {
21 ; CHECK-LABEL: test_vssseg2_mask_nxv16i16:
22 ; CHECK:       # %bb.0: # %entry
23 ; CHECK-NEXT:    vmv4r.v v12, v8
24 ; CHECK-NEXT:    vsetvli zero, a2, e16, m4, ta, ma
25 ; CHECK-NEXT:    vssseg2e16.v v8, (a0), a1, v0.t
26 ; CHECK-NEXT:    ret
27 entry:
28   tail call void @llvm.riscv.vssseg2.mask.nxv16i16(<vscale x 16 x i16> %val,<vscale x 16 x i16> %val, ptr %base, i64 %offset, <vscale x 16 x i1> %mask, i64 %vl)
29   ret void
32 declare void @llvm.riscv.vssseg2.nxv4i32(<vscale x 4 x i32>,<vscale x 4 x i32>, ptr, i64, i64)
33 declare void @llvm.riscv.vssseg2.mask.nxv4i32(<vscale x 4 x i32>,<vscale x 4 x i32>, ptr, i64, <vscale x 4 x i1>, i64)
35 define void @test_vssseg2_nxv4i32(<vscale x 4 x i32> %val, ptr %base, i64 %offset, i64 %vl) {
36 ; CHECK-LABEL: test_vssseg2_nxv4i32:
37 ; CHECK:       # %bb.0: # %entry
38 ; CHECK-NEXT:    vmv2r.v v10, v8
39 ; CHECK-NEXT:    vsetvli zero, a2, e32, m2, ta, ma
40 ; CHECK-NEXT:    vssseg2e32.v v8, (a0), a1
41 ; CHECK-NEXT:    ret
42 entry:
43   tail call void @llvm.riscv.vssseg2.nxv4i32(<vscale x 4 x i32> %val,<vscale x 4 x i32> %val, ptr %base, i64 %offset, i64 %vl)
44   ret void
47 define void @test_vssseg2_mask_nxv4i32(<vscale x 4 x i32> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
48 ; CHECK-LABEL: test_vssseg2_mask_nxv4i32:
49 ; CHECK:       # %bb.0: # %entry
50 ; CHECK-NEXT:    vmv2r.v v10, v8
51 ; CHECK-NEXT:    vsetvli zero, a2, e32, m2, ta, ma
52 ; CHECK-NEXT:    vssseg2e32.v v8, (a0), a1, v0.t
53 ; CHECK-NEXT:    ret
54 entry:
55   tail call void @llvm.riscv.vssseg2.mask.nxv4i32(<vscale x 4 x i32> %val,<vscale x 4 x i32> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
56   ret void
59 declare void @llvm.riscv.vssseg3.nxv4i32(<vscale x 4 x i32>,<vscale x 4 x i32>,<vscale x 4 x i32>, ptr, i64, i64)
60 declare void @llvm.riscv.vssseg3.mask.nxv4i32(<vscale x 4 x i32>,<vscale x 4 x i32>,<vscale x 4 x i32>, ptr, i64, <vscale x 4 x i1>, i64)
62 define void @test_vssseg3_nxv4i32(<vscale x 4 x i32> %val, ptr %base, i64 %offset, i64 %vl) {
63 ; CHECK-LABEL: test_vssseg3_nxv4i32:
64 ; CHECK:       # %bb.0: # %entry
65 ; CHECK-NEXT:    vmv2r.v v10, v8
66 ; CHECK-NEXT:    vmv2r.v v12, v8
67 ; CHECK-NEXT:    vsetvli zero, a2, e32, m2, ta, ma
68 ; CHECK-NEXT:    vssseg3e32.v v8, (a0), a1
69 ; CHECK-NEXT:    ret
70 entry:
71   tail call void @llvm.riscv.vssseg3.nxv4i32(<vscale x 4 x i32> %val,<vscale x 4 x i32> %val,<vscale x 4 x i32> %val, ptr %base, i64 %offset, i64 %vl)
72   ret void
75 define void @test_vssseg3_mask_nxv4i32(<vscale x 4 x i32> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
76 ; CHECK-LABEL: test_vssseg3_mask_nxv4i32:
77 ; CHECK:       # %bb.0: # %entry
78 ; CHECK-NEXT:    vmv2r.v v10, v8
79 ; CHECK-NEXT:    vmv2r.v v12, v8
80 ; CHECK-NEXT:    vsetvli zero, a2, e32, m2, ta, ma
81 ; CHECK-NEXT:    vssseg3e32.v v8, (a0), a1, v0.t
82 ; CHECK-NEXT:    ret
83 entry:
84   tail call void @llvm.riscv.vssseg3.mask.nxv4i32(<vscale x 4 x i32> %val,<vscale x 4 x i32> %val,<vscale x 4 x i32> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
85   ret void
88 declare void @llvm.riscv.vssseg4.nxv4i32(<vscale x 4 x i32>,<vscale x 4 x i32>,<vscale x 4 x i32>,<vscale x 4 x i32>, ptr, i64, i64)
89 declare void @llvm.riscv.vssseg4.mask.nxv4i32(<vscale x 4 x i32>,<vscale x 4 x i32>,<vscale x 4 x i32>,<vscale x 4 x i32>, ptr, i64, <vscale x 4 x i1>, i64)
91 define void @test_vssseg4_nxv4i32(<vscale x 4 x i32> %val, ptr %base, i64 %offset, i64 %vl) {
92 ; CHECK-LABEL: test_vssseg4_nxv4i32:
93 ; CHECK:       # %bb.0: # %entry
94 ; CHECK-NEXT:    vmv2r.v v10, v8
95 ; CHECK-NEXT:    vmv2r.v v12, v8
96 ; CHECK-NEXT:    vmv2r.v v14, v8
97 ; CHECK-NEXT:    vsetvli zero, a2, e32, m2, ta, ma
98 ; CHECK-NEXT:    vssseg4e32.v v8, (a0), a1
99 ; CHECK-NEXT:    ret
100 entry:
101   tail call void @llvm.riscv.vssseg4.nxv4i32(<vscale x 4 x i32> %val,<vscale x 4 x i32> %val,<vscale x 4 x i32> %val,<vscale x 4 x i32> %val, ptr %base, i64 %offset, i64 %vl)
102   ret void
105 define void @test_vssseg4_mask_nxv4i32(<vscale x 4 x i32> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
106 ; CHECK-LABEL: test_vssseg4_mask_nxv4i32:
107 ; CHECK:       # %bb.0: # %entry
108 ; CHECK-NEXT:    vmv2r.v v10, v8
109 ; CHECK-NEXT:    vmv2r.v v12, v8
110 ; CHECK-NEXT:    vmv2r.v v14, v8
111 ; CHECK-NEXT:    vsetvli zero, a2, e32, m2, ta, ma
112 ; CHECK-NEXT:    vssseg4e32.v v8, (a0), a1, v0.t
113 ; CHECK-NEXT:    ret
114 entry:
115   tail call void @llvm.riscv.vssseg4.mask.nxv4i32(<vscale x 4 x i32> %val,<vscale x 4 x i32> %val,<vscale x 4 x i32> %val,<vscale x 4 x i32> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
116   ret void
119 declare void @llvm.riscv.vssseg2.nxv16i8(<vscale x 16 x i8>,<vscale x 16 x i8>, ptr, i64, i64)
120 declare void @llvm.riscv.vssseg2.mask.nxv16i8(<vscale x 16 x i8>,<vscale x 16 x i8>, ptr, i64, <vscale x 16 x i1>, i64)
122 define void @test_vssseg2_nxv16i8(<vscale x 16 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
123 ; CHECK-LABEL: test_vssseg2_nxv16i8:
124 ; CHECK:       # %bb.0: # %entry
125 ; CHECK-NEXT:    vmv2r.v v10, v8
126 ; CHECK-NEXT:    vsetvli zero, a2, e8, m2, ta, ma
127 ; CHECK-NEXT:    vssseg2e8.v v8, (a0), a1
128 ; CHECK-NEXT:    ret
129 entry:
130   tail call void @llvm.riscv.vssseg2.nxv16i8(<vscale x 16 x i8> %val,<vscale x 16 x i8> %val, ptr %base, i64 %offset, i64 %vl)
131   ret void
134 define void @test_vssseg2_mask_nxv16i8(<vscale x 16 x i8> %val, ptr %base, i64 %offset, <vscale x 16 x i1> %mask, i64 %vl) {
135 ; CHECK-LABEL: test_vssseg2_mask_nxv16i8:
136 ; CHECK:       # %bb.0: # %entry
137 ; CHECK-NEXT:    vmv2r.v v10, v8
138 ; CHECK-NEXT:    vsetvli zero, a2, e8, m2, ta, ma
139 ; CHECK-NEXT:    vssseg2e8.v v8, (a0), a1, v0.t
140 ; CHECK-NEXT:    ret
141 entry:
142   tail call void @llvm.riscv.vssseg2.mask.nxv16i8(<vscale x 16 x i8> %val,<vscale x 16 x i8> %val, ptr %base, i64 %offset, <vscale x 16 x i1> %mask, i64 %vl)
143   ret void
146 declare void @llvm.riscv.vssseg3.nxv16i8(<vscale x 16 x i8>,<vscale x 16 x i8>,<vscale x 16 x i8>, ptr, i64, i64)
147 declare void @llvm.riscv.vssseg3.mask.nxv16i8(<vscale x 16 x i8>,<vscale x 16 x i8>,<vscale x 16 x i8>, ptr, i64, <vscale x 16 x i1>, i64)
149 define void @test_vssseg3_nxv16i8(<vscale x 16 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
150 ; CHECK-LABEL: test_vssseg3_nxv16i8:
151 ; CHECK:       # %bb.0: # %entry
152 ; CHECK-NEXT:    vmv2r.v v10, v8
153 ; CHECK-NEXT:    vmv2r.v v12, v8
154 ; CHECK-NEXT:    vsetvli zero, a2, e8, m2, ta, ma
155 ; CHECK-NEXT:    vssseg3e8.v v8, (a0), a1
156 ; CHECK-NEXT:    ret
157 entry:
158   tail call void @llvm.riscv.vssseg3.nxv16i8(<vscale x 16 x i8> %val,<vscale x 16 x i8> %val,<vscale x 16 x i8> %val, ptr %base, i64 %offset, i64 %vl)
159   ret void
162 define void @test_vssseg3_mask_nxv16i8(<vscale x 16 x i8> %val, ptr %base, i64 %offset, <vscale x 16 x i1> %mask, i64 %vl) {
163 ; CHECK-LABEL: test_vssseg3_mask_nxv16i8:
164 ; CHECK:       # %bb.0: # %entry
165 ; CHECK-NEXT:    vmv2r.v v10, v8
166 ; CHECK-NEXT:    vmv2r.v v12, v8
167 ; CHECK-NEXT:    vsetvli zero, a2, e8, m2, ta, ma
168 ; CHECK-NEXT:    vssseg3e8.v v8, (a0), a1, v0.t
169 ; CHECK-NEXT:    ret
170 entry:
171   tail call void @llvm.riscv.vssseg3.mask.nxv16i8(<vscale x 16 x i8> %val,<vscale x 16 x i8> %val,<vscale x 16 x i8> %val, ptr %base, i64 %offset, <vscale x 16 x i1> %mask, i64 %vl)
172   ret void
175 declare void @llvm.riscv.vssseg4.nxv16i8(<vscale x 16 x i8>,<vscale x 16 x i8>,<vscale x 16 x i8>,<vscale x 16 x i8>, ptr, i64, i64)
176 declare void @llvm.riscv.vssseg4.mask.nxv16i8(<vscale x 16 x i8>,<vscale x 16 x i8>,<vscale x 16 x i8>,<vscale x 16 x i8>, ptr, i64, <vscale x 16 x i1>, i64)
178 define void @test_vssseg4_nxv16i8(<vscale x 16 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
179 ; CHECK-LABEL: test_vssseg4_nxv16i8:
180 ; CHECK:       # %bb.0: # %entry
181 ; CHECK-NEXT:    vmv2r.v v10, v8
182 ; CHECK-NEXT:    vmv2r.v v12, v8
183 ; CHECK-NEXT:    vmv2r.v v14, v8
184 ; CHECK-NEXT:    vsetvli zero, a2, e8, m2, ta, ma
185 ; CHECK-NEXT:    vssseg4e8.v v8, (a0), a1
186 ; CHECK-NEXT:    ret
187 entry:
188   tail call void @llvm.riscv.vssseg4.nxv16i8(<vscale x 16 x i8> %val,<vscale x 16 x i8> %val,<vscale x 16 x i8> %val,<vscale x 16 x i8> %val, ptr %base, i64 %offset, i64 %vl)
189   ret void
192 define void @test_vssseg4_mask_nxv16i8(<vscale x 16 x i8> %val, ptr %base, i64 %offset, <vscale x 16 x i1> %mask, i64 %vl) {
193 ; CHECK-LABEL: test_vssseg4_mask_nxv16i8:
194 ; CHECK:       # %bb.0: # %entry
195 ; CHECK-NEXT:    vmv2r.v v10, v8
196 ; CHECK-NEXT:    vmv2r.v v12, v8
197 ; CHECK-NEXT:    vmv2r.v v14, v8
198 ; CHECK-NEXT:    vsetvli zero, a2, e8, m2, ta, ma
199 ; CHECK-NEXT:    vssseg4e8.v v8, (a0), a1, v0.t
200 ; CHECK-NEXT:    ret
201 entry:
202   tail call void @llvm.riscv.vssseg4.mask.nxv16i8(<vscale x 16 x i8> %val,<vscale x 16 x i8> %val,<vscale x 16 x i8> %val,<vscale x 16 x i8> %val, ptr %base, i64 %offset, <vscale x 16 x i1> %mask, i64 %vl)
203   ret void
206 declare void @llvm.riscv.vssseg2.nxv1i64(<vscale x 1 x i64>,<vscale x 1 x i64>, ptr, i64, i64)
207 declare void @llvm.riscv.vssseg2.mask.nxv1i64(<vscale x 1 x i64>,<vscale x 1 x i64>, ptr, i64, <vscale x 1 x i1>, i64)
209 define void @test_vssseg2_nxv1i64(<vscale x 1 x i64> %val, ptr %base, i64 %offset, i64 %vl) {
210 ; CHECK-LABEL: test_vssseg2_nxv1i64:
211 ; CHECK:       # %bb.0: # %entry
212 ; CHECK-NEXT:    vmv1r.v v9, v8
213 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
214 ; CHECK-NEXT:    vssseg2e64.v v8, (a0), a1
215 ; CHECK-NEXT:    ret
216 entry:
217   tail call void @llvm.riscv.vssseg2.nxv1i64(<vscale x 1 x i64> %val,<vscale x 1 x i64> %val, ptr %base, i64 %offset, i64 %vl)
218   ret void
221 define void @test_vssseg2_mask_nxv1i64(<vscale x 1 x i64> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
222 ; CHECK-LABEL: test_vssseg2_mask_nxv1i64:
223 ; CHECK:       # %bb.0: # %entry
224 ; CHECK-NEXT:    vmv1r.v v9, v8
225 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
226 ; CHECK-NEXT:    vssseg2e64.v v8, (a0), a1, v0.t
227 ; CHECK-NEXT:    ret
228 entry:
229   tail call void @llvm.riscv.vssseg2.mask.nxv1i64(<vscale x 1 x i64> %val,<vscale x 1 x i64> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
230   ret void
233 declare void @llvm.riscv.vssseg3.nxv1i64(<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>, ptr, i64, i64)
234 declare void @llvm.riscv.vssseg3.mask.nxv1i64(<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>, ptr, i64, <vscale x 1 x i1>, i64)
236 define void @test_vssseg3_nxv1i64(<vscale x 1 x i64> %val, ptr %base, i64 %offset, i64 %vl) {
237 ; CHECK-LABEL: test_vssseg3_nxv1i64:
238 ; CHECK:       # %bb.0: # %entry
239 ; CHECK-NEXT:    vmv1r.v v9, v8
240 ; CHECK-NEXT:    vmv1r.v v10, v8
241 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
242 ; CHECK-NEXT:    vssseg3e64.v v8, (a0), a1
243 ; CHECK-NEXT:    ret
244 entry:
245   tail call void @llvm.riscv.vssseg3.nxv1i64(<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val, ptr %base, i64 %offset, i64 %vl)
246   ret void
249 define void @test_vssseg3_mask_nxv1i64(<vscale x 1 x i64> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
250 ; CHECK-LABEL: test_vssseg3_mask_nxv1i64:
251 ; CHECK:       # %bb.0: # %entry
252 ; CHECK-NEXT:    vmv1r.v v9, v8
253 ; CHECK-NEXT:    vmv1r.v v10, v8
254 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
255 ; CHECK-NEXT:    vssseg3e64.v v8, (a0), a1, v0.t
256 ; CHECK-NEXT:    ret
257 entry:
258   tail call void @llvm.riscv.vssseg3.mask.nxv1i64(<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
259   ret void
262 declare void @llvm.riscv.vssseg4.nxv1i64(<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>, ptr, i64, i64)
263 declare void @llvm.riscv.vssseg4.mask.nxv1i64(<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>, ptr, i64, <vscale x 1 x i1>, i64)
265 define void @test_vssseg4_nxv1i64(<vscale x 1 x i64> %val, ptr %base, i64 %offset, i64 %vl) {
266 ; CHECK-LABEL: test_vssseg4_nxv1i64:
267 ; CHECK:       # %bb.0: # %entry
268 ; CHECK-NEXT:    vmv1r.v v9, v8
269 ; CHECK-NEXT:    vmv1r.v v10, v8
270 ; CHECK-NEXT:    vmv1r.v v11, v8
271 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
272 ; CHECK-NEXT:    vssseg4e64.v v8, (a0), a1
273 ; CHECK-NEXT:    ret
274 entry:
275   tail call void @llvm.riscv.vssseg4.nxv1i64(<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val, ptr %base, i64 %offset, i64 %vl)
276   ret void
279 define void @test_vssseg4_mask_nxv1i64(<vscale x 1 x i64> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
280 ; CHECK-LABEL: test_vssseg4_mask_nxv1i64:
281 ; CHECK:       # %bb.0: # %entry
282 ; CHECK-NEXT:    vmv1r.v v9, v8
283 ; CHECK-NEXT:    vmv1r.v v10, v8
284 ; CHECK-NEXT:    vmv1r.v v11, v8
285 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
286 ; CHECK-NEXT:    vssseg4e64.v v8, (a0), a1, v0.t
287 ; CHECK-NEXT:    ret
288 entry:
289   tail call void @llvm.riscv.vssseg4.mask.nxv1i64(<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
290   ret void
293 declare void @llvm.riscv.vssseg5.nxv1i64(<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>, ptr, i64, i64)
294 declare void @llvm.riscv.vssseg5.mask.nxv1i64(<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>, ptr, i64, <vscale x 1 x i1>, i64)
296 define void @test_vssseg5_nxv1i64(<vscale x 1 x i64> %val, ptr %base, i64 %offset, i64 %vl) {
297 ; CHECK-LABEL: test_vssseg5_nxv1i64:
298 ; CHECK:       # %bb.0: # %entry
299 ; CHECK-NEXT:    vmv1r.v v9, v8
300 ; CHECK-NEXT:    vmv1r.v v10, v8
301 ; CHECK-NEXT:    vmv1r.v v11, v8
302 ; CHECK-NEXT:    vmv1r.v v12, v8
303 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
304 ; CHECK-NEXT:    vssseg5e64.v v8, (a0), a1
305 ; CHECK-NEXT:    ret
306 entry:
307   tail call void @llvm.riscv.vssseg5.nxv1i64(<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val, ptr %base, i64 %offset, i64 %vl)
308   ret void
311 define void @test_vssseg5_mask_nxv1i64(<vscale x 1 x i64> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
312 ; CHECK-LABEL: test_vssseg5_mask_nxv1i64:
313 ; CHECK:       # %bb.0: # %entry
314 ; CHECK-NEXT:    vmv1r.v v9, v8
315 ; CHECK-NEXT:    vmv1r.v v10, v8
316 ; CHECK-NEXT:    vmv1r.v v11, v8
317 ; CHECK-NEXT:    vmv1r.v v12, v8
318 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
319 ; CHECK-NEXT:    vssseg5e64.v v8, (a0), a1, v0.t
320 ; CHECK-NEXT:    ret
321 entry:
322   tail call void @llvm.riscv.vssseg5.mask.nxv1i64(<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
323   ret void
326 declare void @llvm.riscv.vssseg6.nxv1i64(<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>, ptr, i64, i64)
327 declare void @llvm.riscv.vssseg6.mask.nxv1i64(<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>, ptr, i64, <vscale x 1 x i1>, i64)
329 define void @test_vssseg6_nxv1i64(<vscale x 1 x i64> %val, ptr %base, i64 %offset, i64 %vl) {
330 ; CHECK-LABEL: test_vssseg6_nxv1i64:
331 ; CHECK:       # %bb.0: # %entry
332 ; CHECK-NEXT:    vmv1r.v v9, v8
333 ; CHECK-NEXT:    vmv1r.v v10, v8
334 ; CHECK-NEXT:    vmv1r.v v11, v8
335 ; CHECK-NEXT:    vmv1r.v v12, v8
336 ; CHECK-NEXT:    vmv1r.v v13, v8
337 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
338 ; CHECK-NEXT:    vssseg6e64.v v8, (a0), a1
339 ; CHECK-NEXT:    ret
340 entry:
341   tail call void @llvm.riscv.vssseg6.nxv1i64(<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val, ptr %base, i64 %offset, i64 %vl)
342   ret void
345 define void @test_vssseg6_mask_nxv1i64(<vscale x 1 x i64> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
346 ; CHECK-LABEL: test_vssseg6_mask_nxv1i64:
347 ; CHECK:       # %bb.0: # %entry
348 ; CHECK-NEXT:    vmv1r.v v9, v8
349 ; CHECK-NEXT:    vmv1r.v v10, v8
350 ; CHECK-NEXT:    vmv1r.v v11, v8
351 ; CHECK-NEXT:    vmv1r.v v12, v8
352 ; CHECK-NEXT:    vmv1r.v v13, v8
353 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
354 ; CHECK-NEXT:    vssseg6e64.v v8, (a0), a1, v0.t
355 ; CHECK-NEXT:    ret
356 entry:
357   tail call void @llvm.riscv.vssseg6.mask.nxv1i64(<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
358   ret void
361 declare void @llvm.riscv.vssseg7.nxv1i64(<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>, ptr, i64, i64)
362 declare void @llvm.riscv.vssseg7.mask.nxv1i64(<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>, ptr, i64, <vscale x 1 x i1>, i64)
364 define void @test_vssseg7_nxv1i64(<vscale x 1 x i64> %val, ptr %base, i64 %offset, i64 %vl) {
365 ; CHECK-LABEL: test_vssseg7_nxv1i64:
366 ; CHECK:       # %bb.0: # %entry
367 ; CHECK-NEXT:    vmv1r.v v9, v8
368 ; CHECK-NEXT:    vmv1r.v v10, v8
369 ; CHECK-NEXT:    vmv1r.v v11, v8
370 ; CHECK-NEXT:    vmv1r.v v12, v8
371 ; CHECK-NEXT:    vmv1r.v v13, v8
372 ; CHECK-NEXT:    vmv1r.v v14, v8
373 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
374 ; CHECK-NEXT:    vssseg7e64.v v8, (a0), a1
375 ; CHECK-NEXT:    ret
376 entry:
377   tail call void @llvm.riscv.vssseg7.nxv1i64(<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val, ptr %base, i64 %offset, i64 %vl)
378   ret void
381 define void @test_vssseg7_mask_nxv1i64(<vscale x 1 x i64> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
382 ; CHECK-LABEL: test_vssseg7_mask_nxv1i64:
383 ; CHECK:       # %bb.0: # %entry
384 ; CHECK-NEXT:    vmv1r.v v9, v8
385 ; CHECK-NEXT:    vmv1r.v v10, v8
386 ; CHECK-NEXT:    vmv1r.v v11, v8
387 ; CHECK-NEXT:    vmv1r.v v12, v8
388 ; CHECK-NEXT:    vmv1r.v v13, v8
389 ; CHECK-NEXT:    vmv1r.v v14, v8
390 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
391 ; CHECK-NEXT:    vssseg7e64.v v8, (a0), a1, v0.t
392 ; CHECK-NEXT:    ret
393 entry:
394   tail call void @llvm.riscv.vssseg7.mask.nxv1i64(<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
395   ret void
398 declare void @llvm.riscv.vssseg8.nxv1i64(<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>, ptr, i64, i64)
399 declare void @llvm.riscv.vssseg8.mask.nxv1i64(<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>,<vscale x 1 x i64>, ptr, i64, <vscale x 1 x i1>, i64)
401 define void @test_vssseg8_nxv1i64(<vscale x 1 x i64> %val, ptr %base, i64 %offset, i64 %vl) {
402 ; CHECK-LABEL: test_vssseg8_nxv1i64:
403 ; CHECK:       # %bb.0: # %entry
404 ; CHECK-NEXT:    vmv1r.v v9, v8
405 ; CHECK-NEXT:    vmv1r.v v10, v8
406 ; CHECK-NEXT:    vmv1r.v v11, v8
407 ; CHECK-NEXT:    vmv1r.v v12, v8
408 ; CHECK-NEXT:    vmv1r.v v13, v8
409 ; CHECK-NEXT:    vmv1r.v v14, v8
410 ; CHECK-NEXT:    vmv1r.v v15, v8
411 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
412 ; CHECK-NEXT:    vssseg8e64.v v8, (a0), a1
413 ; CHECK-NEXT:    ret
414 entry:
415   tail call void @llvm.riscv.vssseg8.nxv1i64(<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val, ptr %base, i64 %offset, i64 %vl)
416   ret void
419 define void @test_vssseg8_mask_nxv1i64(<vscale x 1 x i64> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
420 ; CHECK-LABEL: test_vssseg8_mask_nxv1i64:
421 ; CHECK:       # %bb.0: # %entry
422 ; CHECK-NEXT:    vmv1r.v v9, v8
423 ; CHECK-NEXT:    vmv1r.v v10, v8
424 ; CHECK-NEXT:    vmv1r.v v11, v8
425 ; CHECK-NEXT:    vmv1r.v v12, v8
426 ; CHECK-NEXT:    vmv1r.v v13, v8
427 ; CHECK-NEXT:    vmv1r.v v14, v8
428 ; CHECK-NEXT:    vmv1r.v v15, v8
429 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
430 ; CHECK-NEXT:    vssseg8e64.v v8, (a0), a1, v0.t
431 ; CHECK-NEXT:    ret
432 entry:
433   tail call void @llvm.riscv.vssseg8.mask.nxv1i64(<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val,<vscale x 1 x i64> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
434   ret void
437 declare void @llvm.riscv.vssseg2.nxv1i32(<vscale x 1 x i32>,<vscale x 1 x i32>, ptr, i64, i64)
438 declare void @llvm.riscv.vssseg2.mask.nxv1i32(<vscale x 1 x i32>,<vscale x 1 x i32>, ptr, i64, <vscale x 1 x i1>, i64)
440 define void @test_vssseg2_nxv1i32(<vscale x 1 x i32> %val, ptr %base, i64 %offset, i64 %vl) {
441 ; CHECK-LABEL: test_vssseg2_nxv1i32:
442 ; CHECK:       # %bb.0: # %entry
443 ; CHECK-NEXT:    vmv1r.v v9, v8
444 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
445 ; CHECK-NEXT:    vssseg2e32.v v8, (a0), a1
446 ; CHECK-NEXT:    ret
447 entry:
448   tail call void @llvm.riscv.vssseg2.nxv1i32(<vscale x 1 x i32> %val,<vscale x 1 x i32> %val, ptr %base, i64 %offset, i64 %vl)
449   ret void
452 define void @test_vssseg2_mask_nxv1i32(<vscale x 1 x i32> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
453 ; CHECK-LABEL: test_vssseg2_mask_nxv1i32:
454 ; CHECK:       # %bb.0: # %entry
455 ; CHECK-NEXT:    vmv1r.v v9, v8
456 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
457 ; CHECK-NEXT:    vssseg2e32.v v8, (a0), a1, v0.t
458 ; CHECK-NEXT:    ret
459 entry:
460   tail call void @llvm.riscv.vssseg2.mask.nxv1i32(<vscale x 1 x i32> %val,<vscale x 1 x i32> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
461   ret void
464 declare void @llvm.riscv.vssseg3.nxv1i32(<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>, ptr, i64, i64)
465 declare void @llvm.riscv.vssseg3.mask.nxv1i32(<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>, ptr, i64, <vscale x 1 x i1>, i64)
467 define void @test_vssseg3_nxv1i32(<vscale x 1 x i32> %val, ptr %base, i64 %offset, i64 %vl) {
468 ; CHECK-LABEL: test_vssseg3_nxv1i32:
469 ; CHECK:       # %bb.0: # %entry
470 ; CHECK-NEXT:    vmv1r.v v9, v8
471 ; CHECK-NEXT:    vmv1r.v v10, v8
472 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
473 ; CHECK-NEXT:    vssseg3e32.v v8, (a0), a1
474 ; CHECK-NEXT:    ret
475 entry:
476   tail call void @llvm.riscv.vssseg3.nxv1i32(<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val, ptr %base, i64 %offset, i64 %vl)
477   ret void
480 define void @test_vssseg3_mask_nxv1i32(<vscale x 1 x i32> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
481 ; CHECK-LABEL: test_vssseg3_mask_nxv1i32:
482 ; CHECK:       # %bb.0: # %entry
483 ; CHECK-NEXT:    vmv1r.v v9, v8
484 ; CHECK-NEXT:    vmv1r.v v10, v8
485 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
486 ; CHECK-NEXT:    vssseg3e32.v v8, (a0), a1, v0.t
487 ; CHECK-NEXT:    ret
488 entry:
489   tail call void @llvm.riscv.vssseg3.mask.nxv1i32(<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
490   ret void
493 declare void @llvm.riscv.vssseg4.nxv1i32(<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>, ptr, i64, i64)
494 declare void @llvm.riscv.vssseg4.mask.nxv1i32(<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>, ptr, i64, <vscale x 1 x i1>, i64)
496 define void @test_vssseg4_nxv1i32(<vscale x 1 x i32> %val, ptr %base, i64 %offset, i64 %vl) {
497 ; CHECK-LABEL: test_vssseg4_nxv1i32:
498 ; CHECK:       # %bb.0: # %entry
499 ; CHECK-NEXT:    vmv1r.v v9, v8
500 ; CHECK-NEXT:    vmv1r.v v10, v8
501 ; CHECK-NEXT:    vmv1r.v v11, v8
502 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
503 ; CHECK-NEXT:    vssseg4e32.v v8, (a0), a1
504 ; CHECK-NEXT:    ret
505 entry:
506   tail call void @llvm.riscv.vssseg4.nxv1i32(<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val, ptr %base, i64 %offset, i64 %vl)
507   ret void
510 define void @test_vssseg4_mask_nxv1i32(<vscale x 1 x i32> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
511 ; CHECK-LABEL: test_vssseg4_mask_nxv1i32:
512 ; CHECK:       # %bb.0: # %entry
513 ; CHECK-NEXT:    vmv1r.v v9, v8
514 ; CHECK-NEXT:    vmv1r.v v10, v8
515 ; CHECK-NEXT:    vmv1r.v v11, v8
516 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
517 ; CHECK-NEXT:    vssseg4e32.v v8, (a0), a1, v0.t
518 ; CHECK-NEXT:    ret
519 entry:
520   tail call void @llvm.riscv.vssseg4.mask.nxv1i32(<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
521   ret void
524 declare void @llvm.riscv.vssseg5.nxv1i32(<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>, ptr, i64, i64)
525 declare void @llvm.riscv.vssseg5.mask.nxv1i32(<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>, ptr, i64, <vscale x 1 x i1>, i64)
527 define void @test_vssseg5_nxv1i32(<vscale x 1 x i32> %val, ptr %base, i64 %offset, i64 %vl) {
528 ; CHECK-LABEL: test_vssseg5_nxv1i32:
529 ; CHECK:       # %bb.0: # %entry
530 ; CHECK-NEXT:    vmv1r.v v9, v8
531 ; CHECK-NEXT:    vmv1r.v v10, v8
532 ; CHECK-NEXT:    vmv1r.v v11, v8
533 ; CHECK-NEXT:    vmv1r.v v12, v8
534 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
535 ; CHECK-NEXT:    vssseg5e32.v v8, (a0), a1
536 ; CHECK-NEXT:    ret
537 entry:
538   tail call void @llvm.riscv.vssseg5.nxv1i32(<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val, ptr %base, i64 %offset, i64 %vl)
539   ret void
542 define void @test_vssseg5_mask_nxv1i32(<vscale x 1 x i32> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
543 ; CHECK-LABEL: test_vssseg5_mask_nxv1i32:
544 ; CHECK:       # %bb.0: # %entry
545 ; CHECK-NEXT:    vmv1r.v v9, v8
546 ; CHECK-NEXT:    vmv1r.v v10, v8
547 ; CHECK-NEXT:    vmv1r.v v11, v8
548 ; CHECK-NEXT:    vmv1r.v v12, v8
549 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
550 ; CHECK-NEXT:    vssseg5e32.v v8, (a0), a1, v0.t
551 ; CHECK-NEXT:    ret
552 entry:
553   tail call void @llvm.riscv.vssseg5.mask.nxv1i32(<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
554   ret void
557 declare void @llvm.riscv.vssseg6.nxv1i32(<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>, ptr, i64, i64)
558 declare void @llvm.riscv.vssseg6.mask.nxv1i32(<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>, ptr, i64, <vscale x 1 x i1>, i64)
560 define void @test_vssseg6_nxv1i32(<vscale x 1 x i32> %val, ptr %base, i64 %offset, i64 %vl) {
561 ; CHECK-LABEL: test_vssseg6_nxv1i32:
562 ; CHECK:       # %bb.0: # %entry
563 ; CHECK-NEXT:    vmv1r.v v9, v8
564 ; CHECK-NEXT:    vmv1r.v v10, v8
565 ; CHECK-NEXT:    vmv1r.v v11, v8
566 ; CHECK-NEXT:    vmv1r.v v12, v8
567 ; CHECK-NEXT:    vmv1r.v v13, v8
568 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
569 ; CHECK-NEXT:    vssseg6e32.v v8, (a0), a1
570 ; CHECK-NEXT:    ret
571 entry:
572   tail call void @llvm.riscv.vssseg6.nxv1i32(<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val, ptr %base, i64 %offset, i64 %vl)
573   ret void
576 define void @test_vssseg6_mask_nxv1i32(<vscale x 1 x i32> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
577 ; CHECK-LABEL: test_vssseg6_mask_nxv1i32:
578 ; CHECK:       # %bb.0: # %entry
579 ; CHECK-NEXT:    vmv1r.v v9, v8
580 ; CHECK-NEXT:    vmv1r.v v10, v8
581 ; CHECK-NEXT:    vmv1r.v v11, v8
582 ; CHECK-NEXT:    vmv1r.v v12, v8
583 ; CHECK-NEXT:    vmv1r.v v13, v8
584 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
585 ; CHECK-NEXT:    vssseg6e32.v v8, (a0), a1, v0.t
586 ; CHECK-NEXT:    ret
587 entry:
588   tail call void @llvm.riscv.vssseg6.mask.nxv1i32(<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
589   ret void
592 declare void @llvm.riscv.vssseg7.nxv1i32(<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>, ptr, i64, i64)
593 declare void @llvm.riscv.vssseg7.mask.nxv1i32(<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>, ptr, i64, <vscale x 1 x i1>, i64)
595 define void @test_vssseg7_nxv1i32(<vscale x 1 x i32> %val, ptr %base, i64 %offset, i64 %vl) {
596 ; CHECK-LABEL: test_vssseg7_nxv1i32:
597 ; CHECK:       # %bb.0: # %entry
598 ; CHECK-NEXT:    vmv1r.v v9, v8
599 ; CHECK-NEXT:    vmv1r.v v10, v8
600 ; CHECK-NEXT:    vmv1r.v v11, v8
601 ; CHECK-NEXT:    vmv1r.v v12, v8
602 ; CHECK-NEXT:    vmv1r.v v13, v8
603 ; CHECK-NEXT:    vmv1r.v v14, v8
604 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
605 ; CHECK-NEXT:    vssseg7e32.v v8, (a0), a1
606 ; CHECK-NEXT:    ret
607 entry:
608   tail call void @llvm.riscv.vssseg7.nxv1i32(<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val, ptr %base, i64 %offset, i64 %vl)
609   ret void
612 define void @test_vssseg7_mask_nxv1i32(<vscale x 1 x i32> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
613 ; CHECK-LABEL: test_vssseg7_mask_nxv1i32:
614 ; CHECK:       # %bb.0: # %entry
615 ; CHECK-NEXT:    vmv1r.v v9, v8
616 ; CHECK-NEXT:    vmv1r.v v10, v8
617 ; CHECK-NEXT:    vmv1r.v v11, v8
618 ; CHECK-NEXT:    vmv1r.v v12, v8
619 ; CHECK-NEXT:    vmv1r.v v13, v8
620 ; CHECK-NEXT:    vmv1r.v v14, v8
621 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
622 ; CHECK-NEXT:    vssseg7e32.v v8, (a0), a1, v0.t
623 ; CHECK-NEXT:    ret
624 entry:
625   tail call void @llvm.riscv.vssseg7.mask.nxv1i32(<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
626   ret void
629 declare void @llvm.riscv.vssseg8.nxv1i32(<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>, ptr, i64, i64)
630 declare void @llvm.riscv.vssseg8.mask.nxv1i32(<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>,<vscale x 1 x i32>, ptr, i64, <vscale x 1 x i1>, i64)
632 define void @test_vssseg8_nxv1i32(<vscale x 1 x i32> %val, ptr %base, i64 %offset, i64 %vl) {
633 ; CHECK-LABEL: test_vssseg8_nxv1i32:
634 ; CHECK:       # %bb.0: # %entry
635 ; CHECK-NEXT:    vmv1r.v v9, v8
636 ; CHECK-NEXT:    vmv1r.v v10, v8
637 ; CHECK-NEXT:    vmv1r.v v11, v8
638 ; CHECK-NEXT:    vmv1r.v v12, v8
639 ; CHECK-NEXT:    vmv1r.v v13, v8
640 ; CHECK-NEXT:    vmv1r.v v14, v8
641 ; CHECK-NEXT:    vmv1r.v v15, v8
642 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
643 ; CHECK-NEXT:    vssseg8e32.v v8, (a0), a1
644 ; CHECK-NEXT:    ret
645 entry:
646   tail call void @llvm.riscv.vssseg8.nxv1i32(<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val, ptr %base, i64 %offset, i64 %vl)
647   ret void
650 define void @test_vssseg8_mask_nxv1i32(<vscale x 1 x i32> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
651 ; CHECK-LABEL: test_vssseg8_mask_nxv1i32:
652 ; CHECK:       # %bb.0: # %entry
653 ; CHECK-NEXT:    vmv1r.v v9, v8
654 ; CHECK-NEXT:    vmv1r.v v10, v8
655 ; CHECK-NEXT:    vmv1r.v v11, v8
656 ; CHECK-NEXT:    vmv1r.v v12, v8
657 ; CHECK-NEXT:    vmv1r.v v13, v8
658 ; CHECK-NEXT:    vmv1r.v v14, v8
659 ; CHECK-NEXT:    vmv1r.v v15, v8
660 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
661 ; CHECK-NEXT:    vssseg8e32.v v8, (a0), a1, v0.t
662 ; CHECK-NEXT:    ret
663 entry:
664   tail call void @llvm.riscv.vssseg8.mask.nxv1i32(<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val,<vscale x 1 x i32> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
665   ret void
668 declare void @llvm.riscv.vssseg2.nxv8i16(<vscale x 8 x i16>,<vscale x 8 x i16>, ptr, i64, i64)
669 declare void @llvm.riscv.vssseg2.mask.nxv8i16(<vscale x 8 x i16>,<vscale x 8 x i16>, ptr, i64, <vscale x 8 x i1>, i64)
671 define void @test_vssseg2_nxv8i16(<vscale x 8 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
672 ; CHECK-LABEL: test_vssseg2_nxv8i16:
673 ; CHECK:       # %bb.0: # %entry
674 ; CHECK-NEXT:    vmv2r.v v10, v8
675 ; CHECK-NEXT:    vsetvli zero, a2, e16, m2, ta, ma
676 ; CHECK-NEXT:    vssseg2e16.v v8, (a0), a1
677 ; CHECK-NEXT:    ret
678 entry:
679   tail call void @llvm.riscv.vssseg2.nxv8i16(<vscale x 8 x i16> %val,<vscale x 8 x i16> %val, ptr %base, i64 %offset, i64 %vl)
680   ret void
683 define void @test_vssseg2_mask_nxv8i16(<vscale x 8 x i16> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl) {
684 ; CHECK-LABEL: test_vssseg2_mask_nxv8i16:
685 ; CHECK:       # %bb.0: # %entry
686 ; CHECK-NEXT:    vmv2r.v v10, v8
687 ; CHECK-NEXT:    vsetvli zero, a2, e16, m2, ta, ma
688 ; CHECK-NEXT:    vssseg2e16.v v8, (a0), a1, v0.t
689 ; CHECK-NEXT:    ret
690 entry:
691   tail call void @llvm.riscv.vssseg2.mask.nxv8i16(<vscale x 8 x i16> %val,<vscale x 8 x i16> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl)
692   ret void
695 declare void @llvm.riscv.vssseg3.nxv8i16(<vscale x 8 x i16>,<vscale x 8 x i16>,<vscale x 8 x i16>, ptr, i64, i64)
696 declare void @llvm.riscv.vssseg3.mask.nxv8i16(<vscale x 8 x i16>,<vscale x 8 x i16>,<vscale x 8 x i16>, ptr, i64, <vscale x 8 x i1>, i64)
698 define void @test_vssseg3_nxv8i16(<vscale x 8 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
699 ; CHECK-LABEL: test_vssseg3_nxv8i16:
700 ; CHECK:       # %bb.0: # %entry
701 ; CHECK-NEXT:    vmv2r.v v10, v8
702 ; CHECK-NEXT:    vmv2r.v v12, v8
703 ; CHECK-NEXT:    vsetvli zero, a2, e16, m2, ta, ma
704 ; CHECK-NEXT:    vssseg3e16.v v8, (a0), a1
705 ; CHECK-NEXT:    ret
706 entry:
707   tail call void @llvm.riscv.vssseg3.nxv8i16(<vscale x 8 x i16> %val,<vscale x 8 x i16> %val,<vscale x 8 x i16> %val, ptr %base, i64 %offset, i64 %vl)
708   ret void
711 define void @test_vssseg3_mask_nxv8i16(<vscale x 8 x i16> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl) {
712 ; CHECK-LABEL: test_vssseg3_mask_nxv8i16:
713 ; CHECK:       # %bb.0: # %entry
714 ; CHECK-NEXT:    vmv2r.v v10, v8
715 ; CHECK-NEXT:    vmv2r.v v12, v8
716 ; CHECK-NEXT:    vsetvli zero, a2, e16, m2, ta, ma
717 ; CHECK-NEXT:    vssseg3e16.v v8, (a0), a1, v0.t
718 ; CHECK-NEXT:    ret
719 entry:
720   tail call void @llvm.riscv.vssseg3.mask.nxv8i16(<vscale x 8 x i16> %val,<vscale x 8 x i16> %val,<vscale x 8 x i16> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl)
721   ret void
724 declare void @llvm.riscv.vssseg4.nxv8i16(<vscale x 8 x i16>,<vscale x 8 x i16>,<vscale x 8 x i16>,<vscale x 8 x i16>, ptr, i64, i64)
725 declare void @llvm.riscv.vssseg4.mask.nxv8i16(<vscale x 8 x i16>,<vscale x 8 x i16>,<vscale x 8 x i16>,<vscale x 8 x i16>, ptr, i64, <vscale x 8 x i1>, i64)
727 define void @test_vssseg4_nxv8i16(<vscale x 8 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
728 ; CHECK-LABEL: test_vssseg4_nxv8i16:
729 ; CHECK:       # %bb.0: # %entry
730 ; CHECK-NEXT:    vmv2r.v v10, v8
731 ; CHECK-NEXT:    vmv2r.v v12, v8
732 ; CHECK-NEXT:    vmv2r.v v14, v8
733 ; CHECK-NEXT:    vsetvli zero, a2, e16, m2, ta, ma
734 ; CHECK-NEXT:    vssseg4e16.v v8, (a0), a1
735 ; CHECK-NEXT:    ret
736 entry:
737   tail call void @llvm.riscv.vssseg4.nxv8i16(<vscale x 8 x i16> %val,<vscale x 8 x i16> %val,<vscale x 8 x i16> %val,<vscale x 8 x i16> %val, ptr %base, i64 %offset, i64 %vl)
738   ret void
741 define void @test_vssseg4_mask_nxv8i16(<vscale x 8 x i16> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl) {
742 ; CHECK-LABEL: test_vssseg4_mask_nxv8i16:
743 ; CHECK:       # %bb.0: # %entry
744 ; CHECK-NEXT:    vmv2r.v v10, v8
745 ; CHECK-NEXT:    vmv2r.v v12, v8
746 ; CHECK-NEXT:    vmv2r.v v14, v8
747 ; CHECK-NEXT:    vsetvli zero, a2, e16, m2, ta, ma
748 ; CHECK-NEXT:    vssseg4e16.v v8, (a0), a1, v0.t
749 ; CHECK-NEXT:    ret
750 entry:
751   tail call void @llvm.riscv.vssseg4.mask.nxv8i16(<vscale x 8 x i16> %val,<vscale x 8 x i16> %val,<vscale x 8 x i16> %val,<vscale x 8 x i16> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl)
752   ret void
755 declare void @llvm.riscv.vssseg2.nxv4i8(<vscale x 4 x i8>,<vscale x 4 x i8>, ptr, i64, i64)
756 declare void @llvm.riscv.vssseg2.mask.nxv4i8(<vscale x 4 x i8>,<vscale x 4 x i8>, ptr, i64, <vscale x 4 x i1>, i64)
758 define void @test_vssseg2_nxv4i8(<vscale x 4 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
759 ; CHECK-LABEL: test_vssseg2_nxv4i8:
760 ; CHECK:       # %bb.0: # %entry
761 ; CHECK-NEXT:    vmv1r.v v9, v8
762 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf2, ta, ma
763 ; CHECK-NEXT:    vssseg2e8.v v8, (a0), a1
764 ; CHECK-NEXT:    ret
765 entry:
766   tail call void @llvm.riscv.vssseg2.nxv4i8(<vscale x 4 x i8> %val,<vscale x 4 x i8> %val, ptr %base, i64 %offset, i64 %vl)
767   ret void
770 define void @test_vssseg2_mask_nxv4i8(<vscale x 4 x i8> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
771 ; CHECK-LABEL: test_vssseg2_mask_nxv4i8:
772 ; CHECK:       # %bb.0: # %entry
773 ; CHECK-NEXT:    vmv1r.v v9, v8
774 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf2, ta, ma
775 ; CHECK-NEXT:    vssseg2e8.v v8, (a0), a1, v0.t
776 ; CHECK-NEXT:    ret
777 entry:
778   tail call void @llvm.riscv.vssseg2.mask.nxv4i8(<vscale x 4 x i8> %val,<vscale x 4 x i8> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
779   ret void
782 declare void @llvm.riscv.vssseg3.nxv4i8(<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>, ptr, i64, i64)
783 declare void @llvm.riscv.vssseg3.mask.nxv4i8(<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>, ptr, i64, <vscale x 4 x i1>, i64)
785 define void @test_vssseg3_nxv4i8(<vscale x 4 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
786 ; CHECK-LABEL: test_vssseg3_nxv4i8:
787 ; CHECK:       # %bb.0: # %entry
788 ; CHECK-NEXT:    vmv1r.v v9, v8
789 ; CHECK-NEXT:    vmv1r.v v10, v8
790 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf2, ta, ma
791 ; CHECK-NEXT:    vssseg3e8.v v8, (a0), a1
792 ; CHECK-NEXT:    ret
793 entry:
794   tail call void @llvm.riscv.vssseg3.nxv4i8(<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val, ptr %base, i64 %offset, i64 %vl)
795   ret void
798 define void @test_vssseg3_mask_nxv4i8(<vscale x 4 x i8> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
799 ; CHECK-LABEL: test_vssseg3_mask_nxv4i8:
800 ; CHECK:       # %bb.0: # %entry
801 ; CHECK-NEXT:    vmv1r.v v9, v8
802 ; CHECK-NEXT:    vmv1r.v v10, v8
803 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf2, ta, ma
804 ; CHECK-NEXT:    vssseg3e8.v v8, (a0), a1, v0.t
805 ; CHECK-NEXT:    ret
806 entry:
807   tail call void @llvm.riscv.vssseg3.mask.nxv4i8(<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
808   ret void
811 declare void @llvm.riscv.vssseg4.nxv4i8(<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>, ptr, i64, i64)
812 declare void @llvm.riscv.vssseg4.mask.nxv4i8(<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>, ptr, i64, <vscale x 4 x i1>, i64)
814 define void @test_vssseg4_nxv4i8(<vscale x 4 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
815 ; CHECK-LABEL: test_vssseg4_nxv4i8:
816 ; CHECK:       # %bb.0: # %entry
817 ; CHECK-NEXT:    vmv1r.v v9, v8
818 ; CHECK-NEXT:    vmv1r.v v10, v8
819 ; CHECK-NEXT:    vmv1r.v v11, v8
820 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf2, ta, ma
821 ; CHECK-NEXT:    vssseg4e8.v v8, (a0), a1
822 ; CHECK-NEXT:    ret
823 entry:
824   tail call void @llvm.riscv.vssseg4.nxv4i8(<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val, ptr %base, i64 %offset, i64 %vl)
825   ret void
828 define void @test_vssseg4_mask_nxv4i8(<vscale x 4 x i8> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
829 ; CHECK-LABEL: test_vssseg4_mask_nxv4i8:
830 ; CHECK:       # %bb.0: # %entry
831 ; CHECK-NEXT:    vmv1r.v v9, v8
832 ; CHECK-NEXT:    vmv1r.v v10, v8
833 ; CHECK-NEXT:    vmv1r.v v11, v8
834 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf2, ta, ma
835 ; CHECK-NEXT:    vssseg4e8.v v8, (a0), a1, v0.t
836 ; CHECK-NEXT:    ret
837 entry:
838   tail call void @llvm.riscv.vssseg4.mask.nxv4i8(<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
839   ret void
842 declare void @llvm.riscv.vssseg5.nxv4i8(<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>, ptr, i64, i64)
843 declare void @llvm.riscv.vssseg5.mask.nxv4i8(<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>, ptr, i64, <vscale x 4 x i1>, i64)
845 define void @test_vssseg5_nxv4i8(<vscale x 4 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
846 ; CHECK-LABEL: test_vssseg5_nxv4i8:
847 ; CHECK:       # %bb.0: # %entry
848 ; CHECK-NEXT:    vmv1r.v v9, v8
849 ; CHECK-NEXT:    vmv1r.v v10, v8
850 ; CHECK-NEXT:    vmv1r.v v11, v8
851 ; CHECK-NEXT:    vmv1r.v v12, v8
852 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf2, ta, ma
853 ; CHECK-NEXT:    vssseg5e8.v v8, (a0), a1
854 ; CHECK-NEXT:    ret
855 entry:
856   tail call void @llvm.riscv.vssseg5.nxv4i8(<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val, ptr %base, i64 %offset, i64 %vl)
857   ret void
860 define void @test_vssseg5_mask_nxv4i8(<vscale x 4 x i8> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
861 ; CHECK-LABEL: test_vssseg5_mask_nxv4i8:
862 ; CHECK:       # %bb.0: # %entry
863 ; CHECK-NEXT:    vmv1r.v v9, v8
864 ; CHECK-NEXT:    vmv1r.v v10, v8
865 ; CHECK-NEXT:    vmv1r.v v11, v8
866 ; CHECK-NEXT:    vmv1r.v v12, v8
867 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf2, ta, ma
868 ; CHECK-NEXT:    vssseg5e8.v v8, (a0), a1, v0.t
869 ; CHECK-NEXT:    ret
870 entry:
871   tail call void @llvm.riscv.vssseg5.mask.nxv4i8(<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
872   ret void
875 declare void @llvm.riscv.vssseg6.nxv4i8(<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>, ptr, i64, i64)
876 declare void @llvm.riscv.vssseg6.mask.nxv4i8(<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>, ptr, i64, <vscale x 4 x i1>, i64)
878 define void @test_vssseg6_nxv4i8(<vscale x 4 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
879 ; CHECK-LABEL: test_vssseg6_nxv4i8:
880 ; CHECK:       # %bb.0: # %entry
881 ; CHECK-NEXT:    vmv1r.v v9, v8
882 ; CHECK-NEXT:    vmv1r.v v10, v8
883 ; CHECK-NEXT:    vmv1r.v v11, v8
884 ; CHECK-NEXT:    vmv1r.v v12, v8
885 ; CHECK-NEXT:    vmv1r.v v13, v8
886 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf2, ta, ma
887 ; CHECK-NEXT:    vssseg6e8.v v8, (a0), a1
888 ; CHECK-NEXT:    ret
889 entry:
890   tail call void @llvm.riscv.vssseg6.nxv4i8(<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val, ptr %base, i64 %offset, i64 %vl)
891   ret void
894 define void @test_vssseg6_mask_nxv4i8(<vscale x 4 x i8> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
895 ; CHECK-LABEL: test_vssseg6_mask_nxv4i8:
896 ; CHECK:       # %bb.0: # %entry
897 ; CHECK-NEXT:    vmv1r.v v9, v8
898 ; CHECK-NEXT:    vmv1r.v v10, v8
899 ; CHECK-NEXT:    vmv1r.v v11, v8
900 ; CHECK-NEXT:    vmv1r.v v12, v8
901 ; CHECK-NEXT:    vmv1r.v v13, v8
902 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf2, ta, ma
903 ; CHECK-NEXT:    vssseg6e8.v v8, (a0), a1, v0.t
904 ; CHECK-NEXT:    ret
905 entry:
906   tail call void @llvm.riscv.vssseg6.mask.nxv4i8(<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
907   ret void
910 declare void @llvm.riscv.vssseg7.nxv4i8(<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>, ptr, i64, i64)
911 declare void @llvm.riscv.vssseg7.mask.nxv4i8(<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>, ptr, i64, <vscale x 4 x i1>, i64)
913 define void @test_vssseg7_nxv4i8(<vscale x 4 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
914 ; CHECK-LABEL: test_vssseg7_nxv4i8:
915 ; CHECK:       # %bb.0: # %entry
916 ; CHECK-NEXT:    vmv1r.v v9, v8
917 ; CHECK-NEXT:    vmv1r.v v10, v8
918 ; CHECK-NEXT:    vmv1r.v v11, v8
919 ; CHECK-NEXT:    vmv1r.v v12, v8
920 ; CHECK-NEXT:    vmv1r.v v13, v8
921 ; CHECK-NEXT:    vmv1r.v v14, v8
922 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf2, ta, ma
923 ; CHECK-NEXT:    vssseg7e8.v v8, (a0), a1
924 ; CHECK-NEXT:    ret
925 entry:
926   tail call void @llvm.riscv.vssseg7.nxv4i8(<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val, ptr %base, i64 %offset, i64 %vl)
927   ret void
930 define void @test_vssseg7_mask_nxv4i8(<vscale x 4 x i8> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
931 ; CHECK-LABEL: test_vssseg7_mask_nxv4i8:
932 ; CHECK:       # %bb.0: # %entry
933 ; CHECK-NEXT:    vmv1r.v v9, v8
934 ; CHECK-NEXT:    vmv1r.v v10, v8
935 ; CHECK-NEXT:    vmv1r.v v11, v8
936 ; CHECK-NEXT:    vmv1r.v v12, v8
937 ; CHECK-NEXT:    vmv1r.v v13, v8
938 ; CHECK-NEXT:    vmv1r.v v14, v8
939 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf2, ta, ma
940 ; CHECK-NEXT:    vssseg7e8.v v8, (a0), a1, v0.t
941 ; CHECK-NEXT:    ret
942 entry:
943   tail call void @llvm.riscv.vssseg7.mask.nxv4i8(<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
944   ret void
947 declare void @llvm.riscv.vssseg8.nxv4i8(<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>, ptr, i64, i64)
948 declare void @llvm.riscv.vssseg8.mask.nxv4i8(<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>,<vscale x 4 x i8>, ptr, i64, <vscale x 4 x i1>, i64)
950 define void @test_vssseg8_nxv4i8(<vscale x 4 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
951 ; CHECK-LABEL: test_vssseg8_nxv4i8:
952 ; CHECK:       # %bb.0: # %entry
953 ; CHECK-NEXT:    vmv1r.v v9, v8
954 ; CHECK-NEXT:    vmv1r.v v10, v8
955 ; CHECK-NEXT:    vmv1r.v v11, v8
956 ; CHECK-NEXT:    vmv1r.v v12, v8
957 ; CHECK-NEXT:    vmv1r.v v13, v8
958 ; CHECK-NEXT:    vmv1r.v v14, v8
959 ; CHECK-NEXT:    vmv1r.v v15, v8
960 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf2, ta, ma
961 ; CHECK-NEXT:    vssseg8e8.v v8, (a0), a1
962 ; CHECK-NEXT:    ret
963 entry:
964   tail call void @llvm.riscv.vssseg8.nxv4i8(<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val, ptr %base, i64 %offset, i64 %vl)
965   ret void
968 define void @test_vssseg8_mask_nxv4i8(<vscale x 4 x i8> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
969 ; CHECK-LABEL: test_vssseg8_mask_nxv4i8:
970 ; CHECK:       # %bb.0: # %entry
971 ; CHECK-NEXT:    vmv1r.v v9, v8
972 ; CHECK-NEXT:    vmv1r.v v10, v8
973 ; CHECK-NEXT:    vmv1r.v v11, v8
974 ; CHECK-NEXT:    vmv1r.v v12, v8
975 ; CHECK-NEXT:    vmv1r.v v13, v8
976 ; CHECK-NEXT:    vmv1r.v v14, v8
977 ; CHECK-NEXT:    vmv1r.v v15, v8
978 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf2, ta, ma
979 ; CHECK-NEXT:    vssseg8e8.v v8, (a0), a1, v0.t
980 ; CHECK-NEXT:    ret
981 entry:
982   tail call void @llvm.riscv.vssseg8.mask.nxv4i8(<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val,<vscale x 4 x i8> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
983   ret void
986 declare void @llvm.riscv.vssseg2.nxv1i16(<vscale x 1 x i16>,<vscale x 1 x i16>, ptr, i64, i64)
987 declare void @llvm.riscv.vssseg2.mask.nxv1i16(<vscale x 1 x i16>,<vscale x 1 x i16>, ptr, i64, <vscale x 1 x i1>, i64)
989 define void @test_vssseg2_nxv1i16(<vscale x 1 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
990 ; CHECK-LABEL: test_vssseg2_nxv1i16:
991 ; CHECK:       # %bb.0: # %entry
992 ; CHECK-NEXT:    vmv1r.v v9, v8
993 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
994 ; CHECK-NEXT:    vssseg2e16.v v8, (a0), a1
995 ; CHECK-NEXT:    ret
996 entry:
997   tail call void @llvm.riscv.vssseg2.nxv1i16(<vscale x 1 x i16> %val,<vscale x 1 x i16> %val, ptr %base, i64 %offset, i64 %vl)
998   ret void
1001 define void @test_vssseg2_mask_nxv1i16(<vscale x 1 x i16> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
1002 ; CHECK-LABEL: test_vssseg2_mask_nxv1i16:
1003 ; CHECK:       # %bb.0: # %entry
1004 ; CHECK-NEXT:    vmv1r.v v9, v8
1005 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
1006 ; CHECK-NEXT:    vssseg2e16.v v8, (a0), a1, v0.t
1007 ; CHECK-NEXT:    ret
1008 entry:
1009   tail call void @llvm.riscv.vssseg2.mask.nxv1i16(<vscale x 1 x i16> %val,<vscale x 1 x i16> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
1010   ret void
1013 declare void @llvm.riscv.vssseg3.nxv1i16(<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>, ptr, i64, i64)
1014 declare void @llvm.riscv.vssseg3.mask.nxv1i16(<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>, ptr, i64, <vscale x 1 x i1>, i64)
1016 define void @test_vssseg3_nxv1i16(<vscale x 1 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
1017 ; CHECK-LABEL: test_vssseg3_nxv1i16:
1018 ; CHECK:       # %bb.0: # %entry
1019 ; CHECK-NEXT:    vmv1r.v v9, v8
1020 ; CHECK-NEXT:    vmv1r.v v10, v8
1021 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
1022 ; CHECK-NEXT:    vssseg3e16.v v8, (a0), a1
1023 ; CHECK-NEXT:    ret
1024 entry:
1025   tail call void @llvm.riscv.vssseg3.nxv1i16(<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val, ptr %base, i64 %offset, i64 %vl)
1026   ret void
1029 define void @test_vssseg3_mask_nxv1i16(<vscale x 1 x i16> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
1030 ; CHECK-LABEL: test_vssseg3_mask_nxv1i16:
1031 ; CHECK:       # %bb.0: # %entry
1032 ; CHECK-NEXT:    vmv1r.v v9, v8
1033 ; CHECK-NEXT:    vmv1r.v v10, v8
1034 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
1035 ; CHECK-NEXT:    vssseg3e16.v v8, (a0), a1, v0.t
1036 ; CHECK-NEXT:    ret
1037 entry:
1038   tail call void @llvm.riscv.vssseg3.mask.nxv1i16(<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
1039   ret void
1042 declare void @llvm.riscv.vssseg4.nxv1i16(<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>, ptr, i64, i64)
1043 declare void @llvm.riscv.vssseg4.mask.nxv1i16(<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>, ptr, i64, <vscale x 1 x i1>, i64)
1045 define void @test_vssseg4_nxv1i16(<vscale x 1 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
1046 ; CHECK-LABEL: test_vssseg4_nxv1i16:
1047 ; CHECK:       # %bb.0: # %entry
1048 ; CHECK-NEXT:    vmv1r.v v9, v8
1049 ; CHECK-NEXT:    vmv1r.v v10, v8
1050 ; CHECK-NEXT:    vmv1r.v v11, v8
1051 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
1052 ; CHECK-NEXT:    vssseg4e16.v v8, (a0), a1
1053 ; CHECK-NEXT:    ret
1054 entry:
1055   tail call void @llvm.riscv.vssseg4.nxv1i16(<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val, ptr %base, i64 %offset, i64 %vl)
1056   ret void
1059 define void @test_vssseg4_mask_nxv1i16(<vscale x 1 x i16> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
1060 ; CHECK-LABEL: test_vssseg4_mask_nxv1i16:
1061 ; CHECK:       # %bb.0: # %entry
1062 ; CHECK-NEXT:    vmv1r.v v9, v8
1063 ; CHECK-NEXT:    vmv1r.v v10, v8
1064 ; CHECK-NEXT:    vmv1r.v v11, v8
1065 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
1066 ; CHECK-NEXT:    vssseg4e16.v v8, (a0), a1, v0.t
1067 ; CHECK-NEXT:    ret
1068 entry:
1069   tail call void @llvm.riscv.vssseg4.mask.nxv1i16(<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
1070   ret void
1073 declare void @llvm.riscv.vssseg5.nxv1i16(<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>, ptr, i64, i64)
1074 declare void @llvm.riscv.vssseg5.mask.nxv1i16(<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>, ptr, i64, <vscale x 1 x i1>, i64)
1076 define void @test_vssseg5_nxv1i16(<vscale x 1 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
1077 ; CHECK-LABEL: test_vssseg5_nxv1i16:
1078 ; CHECK:       # %bb.0: # %entry
1079 ; CHECK-NEXT:    vmv1r.v v9, v8
1080 ; CHECK-NEXT:    vmv1r.v v10, v8
1081 ; CHECK-NEXT:    vmv1r.v v11, v8
1082 ; CHECK-NEXT:    vmv1r.v v12, v8
1083 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
1084 ; CHECK-NEXT:    vssseg5e16.v v8, (a0), a1
1085 ; CHECK-NEXT:    ret
1086 entry:
1087   tail call void @llvm.riscv.vssseg5.nxv1i16(<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val, ptr %base, i64 %offset, i64 %vl)
1088   ret void
1091 define void @test_vssseg5_mask_nxv1i16(<vscale x 1 x i16> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
1092 ; CHECK-LABEL: test_vssseg5_mask_nxv1i16:
1093 ; CHECK:       # %bb.0: # %entry
1094 ; CHECK-NEXT:    vmv1r.v v9, v8
1095 ; CHECK-NEXT:    vmv1r.v v10, v8
1096 ; CHECK-NEXT:    vmv1r.v v11, v8
1097 ; CHECK-NEXT:    vmv1r.v v12, v8
1098 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
1099 ; CHECK-NEXT:    vssseg5e16.v v8, (a0), a1, v0.t
1100 ; CHECK-NEXT:    ret
1101 entry:
1102   tail call void @llvm.riscv.vssseg5.mask.nxv1i16(<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
1103   ret void
1106 declare void @llvm.riscv.vssseg6.nxv1i16(<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>, ptr, i64, i64)
1107 declare void @llvm.riscv.vssseg6.mask.nxv1i16(<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>, ptr, i64, <vscale x 1 x i1>, i64)
1109 define void @test_vssseg6_nxv1i16(<vscale x 1 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
1110 ; CHECK-LABEL: test_vssseg6_nxv1i16:
1111 ; CHECK:       # %bb.0: # %entry
1112 ; CHECK-NEXT:    vmv1r.v v9, v8
1113 ; CHECK-NEXT:    vmv1r.v v10, v8
1114 ; CHECK-NEXT:    vmv1r.v v11, v8
1115 ; CHECK-NEXT:    vmv1r.v v12, v8
1116 ; CHECK-NEXT:    vmv1r.v v13, v8
1117 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
1118 ; CHECK-NEXT:    vssseg6e16.v v8, (a0), a1
1119 ; CHECK-NEXT:    ret
1120 entry:
1121   tail call void @llvm.riscv.vssseg6.nxv1i16(<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val, ptr %base, i64 %offset, i64 %vl)
1122   ret void
1125 define void @test_vssseg6_mask_nxv1i16(<vscale x 1 x i16> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
1126 ; CHECK-LABEL: test_vssseg6_mask_nxv1i16:
1127 ; CHECK:       # %bb.0: # %entry
1128 ; CHECK-NEXT:    vmv1r.v v9, v8
1129 ; CHECK-NEXT:    vmv1r.v v10, v8
1130 ; CHECK-NEXT:    vmv1r.v v11, v8
1131 ; CHECK-NEXT:    vmv1r.v v12, v8
1132 ; CHECK-NEXT:    vmv1r.v v13, v8
1133 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
1134 ; CHECK-NEXT:    vssseg6e16.v v8, (a0), a1, v0.t
1135 ; CHECK-NEXT:    ret
1136 entry:
1137   tail call void @llvm.riscv.vssseg6.mask.nxv1i16(<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
1138   ret void
1141 declare void @llvm.riscv.vssseg7.nxv1i16(<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>, ptr, i64, i64)
1142 declare void @llvm.riscv.vssseg7.mask.nxv1i16(<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>, ptr, i64, <vscale x 1 x i1>, i64)
1144 define void @test_vssseg7_nxv1i16(<vscale x 1 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
1145 ; CHECK-LABEL: test_vssseg7_nxv1i16:
1146 ; CHECK:       # %bb.0: # %entry
1147 ; CHECK-NEXT:    vmv1r.v v9, v8
1148 ; CHECK-NEXT:    vmv1r.v v10, v8
1149 ; CHECK-NEXT:    vmv1r.v v11, v8
1150 ; CHECK-NEXT:    vmv1r.v v12, v8
1151 ; CHECK-NEXT:    vmv1r.v v13, v8
1152 ; CHECK-NEXT:    vmv1r.v v14, v8
1153 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
1154 ; CHECK-NEXT:    vssseg7e16.v v8, (a0), a1
1155 ; CHECK-NEXT:    ret
1156 entry:
1157   tail call void @llvm.riscv.vssseg7.nxv1i16(<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val, ptr %base, i64 %offset, i64 %vl)
1158   ret void
1161 define void @test_vssseg7_mask_nxv1i16(<vscale x 1 x i16> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
1162 ; CHECK-LABEL: test_vssseg7_mask_nxv1i16:
1163 ; CHECK:       # %bb.0: # %entry
1164 ; CHECK-NEXT:    vmv1r.v v9, v8
1165 ; CHECK-NEXT:    vmv1r.v v10, v8
1166 ; CHECK-NEXT:    vmv1r.v v11, v8
1167 ; CHECK-NEXT:    vmv1r.v v12, v8
1168 ; CHECK-NEXT:    vmv1r.v v13, v8
1169 ; CHECK-NEXT:    vmv1r.v v14, v8
1170 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
1171 ; CHECK-NEXT:    vssseg7e16.v v8, (a0), a1, v0.t
1172 ; CHECK-NEXT:    ret
1173 entry:
1174   tail call void @llvm.riscv.vssseg7.mask.nxv1i16(<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
1175   ret void
1178 declare void @llvm.riscv.vssseg8.nxv1i16(<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>, ptr, i64, i64)
1179 declare void @llvm.riscv.vssseg8.mask.nxv1i16(<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>,<vscale x 1 x i16>, ptr, i64, <vscale x 1 x i1>, i64)
1181 define void @test_vssseg8_nxv1i16(<vscale x 1 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
1182 ; CHECK-LABEL: test_vssseg8_nxv1i16:
1183 ; CHECK:       # %bb.0: # %entry
1184 ; CHECK-NEXT:    vmv1r.v v9, v8
1185 ; CHECK-NEXT:    vmv1r.v v10, v8
1186 ; CHECK-NEXT:    vmv1r.v v11, v8
1187 ; CHECK-NEXT:    vmv1r.v v12, v8
1188 ; CHECK-NEXT:    vmv1r.v v13, v8
1189 ; CHECK-NEXT:    vmv1r.v v14, v8
1190 ; CHECK-NEXT:    vmv1r.v v15, v8
1191 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
1192 ; CHECK-NEXT:    vssseg8e16.v v8, (a0), a1
1193 ; CHECK-NEXT:    ret
1194 entry:
1195   tail call void @llvm.riscv.vssseg8.nxv1i16(<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val, ptr %base, i64 %offset, i64 %vl)
1196   ret void
1199 define void @test_vssseg8_mask_nxv1i16(<vscale x 1 x i16> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
1200 ; CHECK-LABEL: test_vssseg8_mask_nxv1i16:
1201 ; CHECK:       # %bb.0: # %entry
1202 ; CHECK-NEXT:    vmv1r.v v9, v8
1203 ; CHECK-NEXT:    vmv1r.v v10, v8
1204 ; CHECK-NEXT:    vmv1r.v v11, v8
1205 ; CHECK-NEXT:    vmv1r.v v12, v8
1206 ; CHECK-NEXT:    vmv1r.v v13, v8
1207 ; CHECK-NEXT:    vmv1r.v v14, v8
1208 ; CHECK-NEXT:    vmv1r.v v15, v8
1209 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
1210 ; CHECK-NEXT:    vssseg8e16.v v8, (a0), a1, v0.t
1211 ; CHECK-NEXT:    ret
1212 entry:
1213   tail call void @llvm.riscv.vssseg8.mask.nxv1i16(<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val,<vscale x 1 x i16> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
1214   ret void
1217 declare void @llvm.riscv.vssseg2.nxv2i32(<vscale x 2 x i32>,<vscale x 2 x i32>, ptr, i64, i64)
1218 declare void @llvm.riscv.vssseg2.mask.nxv2i32(<vscale x 2 x i32>,<vscale x 2 x i32>, ptr, i64, <vscale x 2 x i1>, i64)
1220 define void @test_vssseg2_nxv2i32(<vscale x 2 x i32> %val, ptr %base, i64 %offset, i64 %vl) {
1221 ; CHECK-LABEL: test_vssseg2_nxv2i32:
1222 ; CHECK:       # %bb.0: # %entry
1223 ; CHECK-NEXT:    vmv1r.v v9, v8
1224 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
1225 ; CHECK-NEXT:    vssseg2e32.v v8, (a0), a1
1226 ; CHECK-NEXT:    ret
1227 entry:
1228   tail call void @llvm.riscv.vssseg2.nxv2i32(<vscale x 2 x i32> %val,<vscale x 2 x i32> %val, ptr %base, i64 %offset, i64 %vl)
1229   ret void
1232 define void @test_vssseg2_mask_nxv2i32(<vscale x 2 x i32> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
1233 ; CHECK-LABEL: test_vssseg2_mask_nxv2i32:
1234 ; CHECK:       # %bb.0: # %entry
1235 ; CHECK-NEXT:    vmv1r.v v9, v8
1236 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
1237 ; CHECK-NEXT:    vssseg2e32.v v8, (a0), a1, v0.t
1238 ; CHECK-NEXT:    ret
1239 entry:
1240   tail call void @llvm.riscv.vssseg2.mask.nxv2i32(<vscale x 2 x i32> %val,<vscale x 2 x i32> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
1241   ret void
1244 declare void @llvm.riscv.vssseg3.nxv2i32(<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>, ptr, i64, i64)
1245 declare void @llvm.riscv.vssseg3.mask.nxv2i32(<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>, ptr, i64, <vscale x 2 x i1>, i64)
1247 define void @test_vssseg3_nxv2i32(<vscale x 2 x i32> %val, ptr %base, i64 %offset, i64 %vl) {
1248 ; CHECK-LABEL: test_vssseg3_nxv2i32:
1249 ; CHECK:       # %bb.0: # %entry
1250 ; CHECK-NEXT:    vmv1r.v v9, v8
1251 ; CHECK-NEXT:    vmv1r.v v10, v8
1252 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
1253 ; CHECK-NEXT:    vssseg3e32.v v8, (a0), a1
1254 ; CHECK-NEXT:    ret
1255 entry:
1256   tail call void @llvm.riscv.vssseg3.nxv2i32(<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val, ptr %base, i64 %offset, i64 %vl)
1257   ret void
1260 define void @test_vssseg3_mask_nxv2i32(<vscale x 2 x i32> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
1261 ; CHECK-LABEL: test_vssseg3_mask_nxv2i32:
1262 ; CHECK:       # %bb.0: # %entry
1263 ; CHECK-NEXT:    vmv1r.v v9, v8
1264 ; CHECK-NEXT:    vmv1r.v v10, v8
1265 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
1266 ; CHECK-NEXT:    vssseg3e32.v v8, (a0), a1, v0.t
1267 ; CHECK-NEXT:    ret
1268 entry:
1269   tail call void @llvm.riscv.vssseg3.mask.nxv2i32(<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
1270   ret void
1273 declare void @llvm.riscv.vssseg4.nxv2i32(<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>, ptr, i64, i64)
1274 declare void @llvm.riscv.vssseg4.mask.nxv2i32(<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>, ptr, i64, <vscale x 2 x i1>, i64)
1276 define void @test_vssseg4_nxv2i32(<vscale x 2 x i32> %val, ptr %base, i64 %offset, i64 %vl) {
1277 ; CHECK-LABEL: test_vssseg4_nxv2i32:
1278 ; CHECK:       # %bb.0: # %entry
1279 ; CHECK-NEXT:    vmv1r.v v9, v8
1280 ; CHECK-NEXT:    vmv1r.v v10, v8
1281 ; CHECK-NEXT:    vmv1r.v v11, v8
1282 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
1283 ; CHECK-NEXT:    vssseg4e32.v v8, (a0), a1
1284 ; CHECK-NEXT:    ret
1285 entry:
1286   tail call void @llvm.riscv.vssseg4.nxv2i32(<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val, ptr %base, i64 %offset, i64 %vl)
1287   ret void
1290 define void @test_vssseg4_mask_nxv2i32(<vscale x 2 x i32> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
1291 ; CHECK-LABEL: test_vssseg4_mask_nxv2i32:
1292 ; CHECK:       # %bb.0: # %entry
1293 ; CHECK-NEXT:    vmv1r.v v9, v8
1294 ; CHECK-NEXT:    vmv1r.v v10, v8
1295 ; CHECK-NEXT:    vmv1r.v v11, v8
1296 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
1297 ; CHECK-NEXT:    vssseg4e32.v v8, (a0), a1, v0.t
1298 ; CHECK-NEXT:    ret
1299 entry:
1300   tail call void @llvm.riscv.vssseg4.mask.nxv2i32(<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
1301   ret void
1304 declare void @llvm.riscv.vssseg5.nxv2i32(<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>, ptr, i64, i64)
1305 declare void @llvm.riscv.vssseg5.mask.nxv2i32(<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>, ptr, i64, <vscale x 2 x i1>, i64)
1307 define void @test_vssseg5_nxv2i32(<vscale x 2 x i32> %val, ptr %base, i64 %offset, i64 %vl) {
1308 ; CHECK-LABEL: test_vssseg5_nxv2i32:
1309 ; CHECK:       # %bb.0: # %entry
1310 ; CHECK-NEXT:    vmv1r.v v9, v8
1311 ; CHECK-NEXT:    vmv1r.v v10, v8
1312 ; CHECK-NEXT:    vmv1r.v v11, v8
1313 ; CHECK-NEXT:    vmv1r.v v12, v8
1314 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
1315 ; CHECK-NEXT:    vssseg5e32.v v8, (a0), a1
1316 ; CHECK-NEXT:    ret
1317 entry:
1318   tail call void @llvm.riscv.vssseg5.nxv2i32(<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val, ptr %base, i64 %offset, i64 %vl)
1319   ret void
1322 define void @test_vssseg5_mask_nxv2i32(<vscale x 2 x i32> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
1323 ; CHECK-LABEL: test_vssseg5_mask_nxv2i32:
1324 ; CHECK:       # %bb.0: # %entry
1325 ; CHECK-NEXT:    vmv1r.v v9, v8
1326 ; CHECK-NEXT:    vmv1r.v v10, v8
1327 ; CHECK-NEXT:    vmv1r.v v11, v8
1328 ; CHECK-NEXT:    vmv1r.v v12, v8
1329 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
1330 ; CHECK-NEXT:    vssseg5e32.v v8, (a0), a1, v0.t
1331 ; CHECK-NEXT:    ret
1332 entry:
1333   tail call void @llvm.riscv.vssseg5.mask.nxv2i32(<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
1334   ret void
1337 declare void @llvm.riscv.vssseg6.nxv2i32(<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>, ptr, i64, i64)
1338 declare void @llvm.riscv.vssseg6.mask.nxv2i32(<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>, ptr, i64, <vscale x 2 x i1>, i64)
1340 define void @test_vssseg6_nxv2i32(<vscale x 2 x i32> %val, ptr %base, i64 %offset, i64 %vl) {
1341 ; CHECK-LABEL: test_vssseg6_nxv2i32:
1342 ; CHECK:       # %bb.0: # %entry
1343 ; CHECK-NEXT:    vmv1r.v v9, v8
1344 ; CHECK-NEXT:    vmv1r.v v10, v8
1345 ; CHECK-NEXT:    vmv1r.v v11, v8
1346 ; CHECK-NEXT:    vmv1r.v v12, v8
1347 ; CHECK-NEXT:    vmv1r.v v13, v8
1348 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
1349 ; CHECK-NEXT:    vssseg6e32.v v8, (a0), a1
1350 ; CHECK-NEXT:    ret
1351 entry:
1352   tail call void @llvm.riscv.vssseg6.nxv2i32(<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val, ptr %base, i64 %offset, i64 %vl)
1353   ret void
1356 define void @test_vssseg6_mask_nxv2i32(<vscale x 2 x i32> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
1357 ; CHECK-LABEL: test_vssseg6_mask_nxv2i32:
1358 ; CHECK:       # %bb.0: # %entry
1359 ; CHECK-NEXT:    vmv1r.v v9, v8
1360 ; CHECK-NEXT:    vmv1r.v v10, v8
1361 ; CHECK-NEXT:    vmv1r.v v11, v8
1362 ; CHECK-NEXT:    vmv1r.v v12, v8
1363 ; CHECK-NEXT:    vmv1r.v v13, v8
1364 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
1365 ; CHECK-NEXT:    vssseg6e32.v v8, (a0), a1, v0.t
1366 ; CHECK-NEXT:    ret
1367 entry:
1368   tail call void @llvm.riscv.vssseg6.mask.nxv2i32(<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
1369   ret void
1372 declare void @llvm.riscv.vssseg7.nxv2i32(<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>, ptr, i64, i64)
1373 declare void @llvm.riscv.vssseg7.mask.nxv2i32(<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>, ptr, i64, <vscale x 2 x i1>, i64)
1375 define void @test_vssseg7_nxv2i32(<vscale x 2 x i32> %val, ptr %base, i64 %offset, i64 %vl) {
1376 ; CHECK-LABEL: test_vssseg7_nxv2i32:
1377 ; CHECK:       # %bb.0: # %entry
1378 ; CHECK-NEXT:    vmv1r.v v9, v8
1379 ; CHECK-NEXT:    vmv1r.v v10, v8
1380 ; CHECK-NEXT:    vmv1r.v v11, v8
1381 ; CHECK-NEXT:    vmv1r.v v12, v8
1382 ; CHECK-NEXT:    vmv1r.v v13, v8
1383 ; CHECK-NEXT:    vmv1r.v v14, v8
1384 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
1385 ; CHECK-NEXT:    vssseg7e32.v v8, (a0), a1
1386 ; CHECK-NEXT:    ret
1387 entry:
1388   tail call void @llvm.riscv.vssseg7.nxv2i32(<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val, ptr %base, i64 %offset, i64 %vl)
1389   ret void
1392 define void @test_vssseg7_mask_nxv2i32(<vscale x 2 x i32> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
1393 ; CHECK-LABEL: test_vssseg7_mask_nxv2i32:
1394 ; CHECK:       # %bb.0: # %entry
1395 ; CHECK-NEXT:    vmv1r.v v9, v8
1396 ; CHECK-NEXT:    vmv1r.v v10, v8
1397 ; CHECK-NEXT:    vmv1r.v v11, v8
1398 ; CHECK-NEXT:    vmv1r.v v12, v8
1399 ; CHECK-NEXT:    vmv1r.v v13, v8
1400 ; CHECK-NEXT:    vmv1r.v v14, v8
1401 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
1402 ; CHECK-NEXT:    vssseg7e32.v v8, (a0), a1, v0.t
1403 ; CHECK-NEXT:    ret
1404 entry:
1405   tail call void @llvm.riscv.vssseg7.mask.nxv2i32(<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
1406   ret void
1409 declare void @llvm.riscv.vssseg8.nxv2i32(<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>, ptr, i64, i64)
1410 declare void @llvm.riscv.vssseg8.mask.nxv2i32(<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>,<vscale x 2 x i32>, ptr, i64, <vscale x 2 x i1>, i64)
1412 define void @test_vssseg8_nxv2i32(<vscale x 2 x i32> %val, ptr %base, i64 %offset, i64 %vl) {
1413 ; CHECK-LABEL: test_vssseg8_nxv2i32:
1414 ; CHECK:       # %bb.0: # %entry
1415 ; CHECK-NEXT:    vmv1r.v v9, v8
1416 ; CHECK-NEXT:    vmv1r.v v10, v8
1417 ; CHECK-NEXT:    vmv1r.v v11, v8
1418 ; CHECK-NEXT:    vmv1r.v v12, v8
1419 ; CHECK-NEXT:    vmv1r.v v13, v8
1420 ; CHECK-NEXT:    vmv1r.v v14, v8
1421 ; CHECK-NEXT:    vmv1r.v v15, v8
1422 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
1423 ; CHECK-NEXT:    vssseg8e32.v v8, (a0), a1
1424 ; CHECK-NEXT:    ret
1425 entry:
1426   tail call void @llvm.riscv.vssseg8.nxv2i32(<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val, ptr %base, i64 %offset, i64 %vl)
1427   ret void
1430 define void @test_vssseg8_mask_nxv2i32(<vscale x 2 x i32> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
1431 ; CHECK-LABEL: test_vssseg8_mask_nxv2i32:
1432 ; CHECK:       # %bb.0: # %entry
1433 ; CHECK-NEXT:    vmv1r.v v9, v8
1434 ; CHECK-NEXT:    vmv1r.v v10, v8
1435 ; CHECK-NEXT:    vmv1r.v v11, v8
1436 ; CHECK-NEXT:    vmv1r.v v12, v8
1437 ; CHECK-NEXT:    vmv1r.v v13, v8
1438 ; CHECK-NEXT:    vmv1r.v v14, v8
1439 ; CHECK-NEXT:    vmv1r.v v15, v8
1440 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
1441 ; CHECK-NEXT:    vssseg8e32.v v8, (a0), a1, v0.t
1442 ; CHECK-NEXT:    ret
1443 entry:
1444   tail call void @llvm.riscv.vssseg8.mask.nxv2i32(<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val,<vscale x 2 x i32> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
1445   ret void
1448 declare void @llvm.riscv.vssseg2.nxv8i8(<vscale x 8 x i8>,<vscale x 8 x i8>, ptr, i64, i64)
1449 declare void @llvm.riscv.vssseg2.mask.nxv8i8(<vscale x 8 x i8>,<vscale x 8 x i8>, ptr, i64, <vscale x 8 x i1>, i64)
1451 define void @test_vssseg2_nxv8i8(<vscale x 8 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
1452 ; CHECK-LABEL: test_vssseg2_nxv8i8:
1453 ; CHECK:       # %bb.0: # %entry
1454 ; CHECK-NEXT:    vmv1r.v v9, v8
1455 ; CHECK-NEXT:    vsetvli zero, a2, e8, m1, ta, ma
1456 ; CHECK-NEXT:    vssseg2e8.v v8, (a0), a1
1457 ; CHECK-NEXT:    ret
1458 entry:
1459   tail call void @llvm.riscv.vssseg2.nxv8i8(<vscale x 8 x i8> %val,<vscale x 8 x i8> %val, ptr %base, i64 %offset, i64 %vl)
1460   ret void
1463 define void @test_vssseg2_mask_nxv8i8(<vscale x 8 x i8> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl) {
1464 ; CHECK-LABEL: test_vssseg2_mask_nxv8i8:
1465 ; CHECK:       # %bb.0: # %entry
1466 ; CHECK-NEXT:    vmv1r.v v9, v8
1467 ; CHECK-NEXT:    vsetvli zero, a2, e8, m1, ta, ma
1468 ; CHECK-NEXT:    vssseg2e8.v v8, (a0), a1, v0.t
1469 ; CHECK-NEXT:    ret
1470 entry:
1471   tail call void @llvm.riscv.vssseg2.mask.nxv8i8(<vscale x 8 x i8> %val,<vscale x 8 x i8> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl)
1472   ret void
1475 declare void @llvm.riscv.vssseg3.nxv8i8(<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>, ptr, i64, i64)
1476 declare void @llvm.riscv.vssseg3.mask.nxv8i8(<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>, ptr, i64, <vscale x 8 x i1>, i64)
1478 define void @test_vssseg3_nxv8i8(<vscale x 8 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
1479 ; CHECK-LABEL: test_vssseg3_nxv8i8:
1480 ; CHECK:       # %bb.0: # %entry
1481 ; CHECK-NEXT:    vmv1r.v v9, v8
1482 ; CHECK-NEXT:    vmv1r.v v10, v8
1483 ; CHECK-NEXT:    vsetvli zero, a2, e8, m1, ta, ma
1484 ; CHECK-NEXT:    vssseg3e8.v v8, (a0), a1
1485 ; CHECK-NEXT:    ret
1486 entry:
1487   tail call void @llvm.riscv.vssseg3.nxv8i8(<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val, ptr %base, i64 %offset, i64 %vl)
1488   ret void
1491 define void @test_vssseg3_mask_nxv8i8(<vscale x 8 x i8> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl) {
1492 ; CHECK-LABEL: test_vssseg3_mask_nxv8i8:
1493 ; CHECK:       # %bb.0: # %entry
1494 ; CHECK-NEXT:    vmv1r.v v9, v8
1495 ; CHECK-NEXT:    vmv1r.v v10, v8
1496 ; CHECK-NEXT:    vsetvli zero, a2, e8, m1, ta, ma
1497 ; CHECK-NEXT:    vssseg3e8.v v8, (a0), a1, v0.t
1498 ; CHECK-NEXT:    ret
1499 entry:
1500   tail call void @llvm.riscv.vssseg3.mask.nxv8i8(<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl)
1501   ret void
1504 declare void @llvm.riscv.vssseg4.nxv8i8(<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>, ptr, i64, i64)
1505 declare void @llvm.riscv.vssseg4.mask.nxv8i8(<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>, ptr, i64, <vscale x 8 x i1>, i64)
1507 define void @test_vssseg4_nxv8i8(<vscale x 8 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
1508 ; CHECK-LABEL: test_vssseg4_nxv8i8:
1509 ; CHECK:       # %bb.0: # %entry
1510 ; CHECK-NEXT:    vmv1r.v v9, v8
1511 ; CHECK-NEXT:    vmv1r.v v10, v8
1512 ; CHECK-NEXT:    vmv1r.v v11, v8
1513 ; CHECK-NEXT:    vsetvli zero, a2, e8, m1, ta, ma
1514 ; CHECK-NEXT:    vssseg4e8.v v8, (a0), a1
1515 ; CHECK-NEXT:    ret
1516 entry:
1517   tail call void @llvm.riscv.vssseg4.nxv8i8(<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val, ptr %base, i64 %offset, i64 %vl)
1518   ret void
1521 define void @test_vssseg4_mask_nxv8i8(<vscale x 8 x i8> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl) {
1522 ; CHECK-LABEL: test_vssseg4_mask_nxv8i8:
1523 ; CHECK:       # %bb.0: # %entry
1524 ; CHECK-NEXT:    vmv1r.v v9, v8
1525 ; CHECK-NEXT:    vmv1r.v v10, v8
1526 ; CHECK-NEXT:    vmv1r.v v11, v8
1527 ; CHECK-NEXT:    vsetvli zero, a2, e8, m1, ta, ma
1528 ; CHECK-NEXT:    vssseg4e8.v v8, (a0), a1, v0.t
1529 ; CHECK-NEXT:    ret
1530 entry:
1531   tail call void @llvm.riscv.vssseg4.mask.nxv8i8(<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl)
1532   ret void
1535 declare void @llvm.riscv.vssseg5.nxv8i8(<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>, ptr, i64, i64)
1536 declare void @llvm.riscv.vssseg5.mask.nxv8i8(<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>, ptr, i64, <vscale x 8 x i1>, i64)
1538 define void @test_vssseg5_nxv8i8(<vscale x 8 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
1539 ; CHECK-LABEL: test_vssseg5_nxv8i8:
1540 ; CHECK:       # %bb.0: # %entry
1541 ; CHECK-NEXT:    vmv1r.v v9, v8
1542 ; CHECK-NEXT:    vmv1r.v v10, v8
1543 ; CHECK-NEXT:    vmv1r.v v11, v8
1544 ; CHECK-NEXT:    vmv1r.v v12, v8
1545 ; CHECK-NEXT:    vsetvli zero, a2, e8, m1, ta, ma
1546 ; CHECK-NEXT:    vssseg5e8.v v8, (a0), a1
1547 ; CHECK-NEXT:    ret
1548 entry:
1549   tail call void @llvm.riscv.vssseg5.nxv8i8(<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val, ptr %base, i64 %offset, i64 %vl)
1550   ret void
1553 define void @test_vssseg5_mask_nxv8i8(<vscale x 8 x i8> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl) {
1554 ; CHECK-LABEL: test_vssseg5_mask_nxv8i8:
1555 ; CHECK:       # %bb.0: # %entry
1556 ; CHECK-NEXT:    vmv1r.v v9, v8
1557 ; CHECK-NEXT:    vmv1r.v v10, v8
1558 ; CHECK-NEXT:    vmv1r.v v11, v8
1559 ; CHECK-NEXT:    vmv1r.v v12, v8
1560 ; CHECK-NEXT:    vsetvli zero, a2, e8, m1, ta, ma
1561 ; CHECK-NEXT:    vssseg5e8.v v8, (a0), a1, v0.t
1562 ; CHECK-NEXT:    ret
1563 entry:
1564   tail call void @llvm.riscv.vssseg5.mask.nxv8i8(<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl)
1565   ret void
1568 declare void @llvm.riscv.vssseg6.nxv8i8(<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>, ptr, i64, i64)
1569 declare void @llvm.riscv.vssseg6.mask.nxv8i8(<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>, ptr, i64, <vscale x 8 x i1>, i64)
1571 define void @test_vssseg6_nxv8i8(<vscale x 8 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
1572 ; CHECK-LABEL: test_vssseg6_nxv8i8:
1573 ; CHECK:       # %bb.0: # %entry
1574 ; CHECK-NEXT:    vmv1r.v v9, v8
1575 ; CHECK-NEXT:    vmv1r.v v10, v8
1576 ; CHECK-NEXT:    vmv1r.v v11, v8
1577 ; CHECK-NEXT:    vmv1r.v v12, v8
1578 ; CHECK-NEXT:    vmv1r.v v13, v8
1579 ; CHECK-NEXT:    vsetvli zero, a2, e8, m1, ta, ma
1580 ; CHECK-NEXT:    vssseg6e8.v v8, (a0), a1
1581 ; CHECK-NEXT:    ret
1582 entry:
1583   tail call void @llvm.riscv.vssseg6.nxv8i8(<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val, ptr %base, i64 %offset, i64 %vl)
1584   ret void
1587 define void @test_vssseg6_mask_nxv8i8(<vscale x 8 x i8> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl) {
1588 ; CHECK-LABEL: test_vssseg6_mask_nxv8i8:
1589 ; CHECK:       # %bb.0: # %entry
1590 ; CHECK-NEXT:    vmv1r.v v9, v8
1591 ; CHECK-NEXT:    vmv1r.v v10, v8
1592 ; CHECK-NEXT:    vmv1r.v v11, v8
1593 ; CHECK-NEXT:    vmv1r.v v12, v8
1594 ; CHECK-NEXT:    vmv1r.v v13, v8
1595 ; CHECK-NEXT:    vsetvli zero, a2, e8, m1, ta, ma
1596 ; CHECK-NEXT:    vssseg6e8.v v8, (a0), a1, v0.t
1597 ; CHECK-NEXT:    ret
1598 entry:
1599   tail call void @llvm.riscv.vssseg6.mask.nxv8i8(<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl)
1600   ret void
1603 declare void @llvm.riscv.vssseg7.nxv8i8(<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>, ptr, i64, i64)
1604 declare void @llvm.riscv.vssseg7.mask.nxv8i8(<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>, ptr, i64, <vscale x 8 x i1>, i64)
1606 define void @test_vssseg7_nxv8i8(<vscale x 8 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
1607 ; CHECK-LABEL: test_vssseg7_nxv8i8:
1608 ; CHECK:       # %bb.0: # %entry
1609 ; CHECK-NEXT:    vmv1r.v v9, v8
1610 ; CHECK-NEXT:    vmv1r.v v10, v8
1611 ; CHECK-NEXT:    vmv1r.v v11, v8
1612 ; CHECK-NEXT:    vmv1r.v v12, v8
1613 ; CHECK-NEXT:    vmv1r.v v13, v8
1614 ; CHECK-NEXT:    vmv1r.v v14, v8
1615 ; CHECK-NEXT:    vsetvli zero, a2, e8, m1, ta, ma
1616 ; CHECK-NEXT:    vssseg7e8.v v8, (a0), a1
1617 ; CHECK-NEXT:    ret
1618 entry:
1619   tail call void @llvm.riscv.vssseg7.nxv8i8(<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val, ptr %base, i64 %offset, i64 %vl)
1620   ret void
1623 define void @test_vssseg7_mask_nxv8i8(<vscale x 8 x i8> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl) {
1624 ; CHECK-LABEL: test_vssseg7_mask_nxv8i8:
1625 ; CHECK:       # %bb.0: # %entry
1626 ; CHECK-NEXT:    vmv1r.v v9, v8
1627 ; CHECK-NEXT:    vmv1r.v v10, v8
1628 ; CHECK-NEXT:    vmv1r.v v11, v8
1629 ; CHECK-NEXT:    vmv1r.v v12, v8
1630 ; CHECK-NEXT:    vmv1r.v v13, v8
1631 ; CHECK-NEXT:    vmv1r.v v14, v8
1632 ; CHECK-NEXT:    vsetvli zero, a2, e8, m1, ta, ma
1633 ; CHECK-NEXT:    vssseg7e8.v v8, (a0), a1, v0.t
1634 ; CHECK-NEXT:    ret
1635 entry:
1636   tail call void @llvm.riscv.vssseg7.mask.nxv8i8(<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl)
1637   ret void
1640 declare void @llvm.riscv.vssseg8.nxv8i8(<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>, ptr, i64, i64)
1641 declare void @llvm.riscv.vssseg8.mask.nxv8i8(<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>,<vscale x 8 x i8>, ptr, i64, <vscale x 8 x i1>, i64)
1643 define void @test_vssseg8_nxv8i8(<vscale x 8 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
1644 ; CHECK-LABEL: test_vssseg8_nxv8i8:
1645 ; CHECK:       # %bb.0: # %entry
1646 ; CHECK-NEXT:    vmv1r.v v9, v8
1647 ; CHECK-NEXT:    vmv1r.v v10, v8
1648 ; CHECK-NEXT:    vmv1r.v v11, v8
1649 ; CHECK-NEXT:    vmv1r.v v12, v8
1650 ; CHECK-NEXT:    vmv1r.v v13, v8
1651 ; CHECK-NEXT:    vmv1r.v v14, v8
1652 ; CHECK-NEXT:    vmv1r.v v15, v8
1653 ; CHECK-NEXT:    vsetvli zero, a2, e8, m1, ta, ma
1654 ; CHECK-NEXT:    vssseg8e8.v v8, (a0), a1
1655 ; CHECK-NEXT:    ret
1656 entry:
1657   tail call void @llvm.riscv.vssseg8.nxv8i8(<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val, ptr %base, i64 %offset, i64 %vl)
1658   ret void
1661 define void @test_vssseg8_mask_nxv8i8(<vscale x 8 x i8> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl) {
1662 ; CHECK-LABEL: test_vssseg8_mask_nxv8i8:
1663 ; CHECK:       # %bb.0: # %entry
1664 ; CHECK-NEXT:    vmv1r.v v9, v8
1665 ; CHECK-NEXT:    vmv1r.v v10, v8
1666 ; CHECK-NEXT:    vmv1r.v v11, v8
1667 ; CHECK-NEXT:    vmv1r.v v12, v8
1668 ; CHECK-NEXT:    vmv1r.v v13, v8
1669 ; CHECK-NEXT:    vmv1r.v v14, v8
1670 ; CHECK-NEXT:    vmv1r.v v15, v8
1671 ; CHECK-NEXT:    vsetvli zero, a2, e8, m1, ta, ma
1672 ; CHECK-NEXT:    vssseg8e8.v v8, (a0), a1, v0.t
1673 ; CHECK-NEXT:    ret
1674 entry:
1675   tail call void @llvm.riscv.vssseg8.mask.nxv8i8(<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val,<vscale x 8 x i8> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl)
1676   ret void
1679 declare void @llvm.riscv.vssseg2.nxv4i64(<vscale x 4 x i64>,<vscale x 4 x i64>, ptr, i64, i64)
1680 declare void @llvm.riscv.vssseg2.mask.nxv4i64(<vscale x 4 x i64>,<vscale x 4 x i64>, ptr, i64, <vscale x 4 x i1>, i64)
1682 define void @test_vssseg2_nxv4i64(<vscale x 4 x i64> %val, ptr %base, i64 %offset, i64 %vl) {
1683 ; CHECK-LABEL: test_vssseg2_nxv4i64:
1684 ; CHECK:       # %bb.0: # %entry
1685 ; CHECK-NEXT:    vmv4r.v v12, v8
1686 ; CHECK-NEXT:    vsetvli zero, a2, e64, m4, ta, ma
1687 ; CHECK-NEXT:    vssseg2e64.v v8, (a0), a1
1688 ; CHECK-NEXT:    ret
1689 entry:
1690   tail call void @llvm.riscv.vssseg2.nxv4i64(<vscale x 4 x i64> %val,<vscale x 4 x i64> %val, ptr %base, i64 %offset, i64 %vl)
1691   ret void
1694 define void @test_vssseg2_mask_nxv4i64(<vscale x 4 x i64> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
1695 ; CHECK-LABEL: test_vssseg2_mask_nxv4i64:
1696 ; CHECK:       # %bb.0: # %entry
1697 ; CHECK-NEXT:    vmv4r.v v12, v8
1698 ; CHECK-NEXT:    vsetvli zero, a2, e64, m4, ta, ma
1699 ; CHECK-NEXT:    vssseg2e64.v v8, (a0), a1, v0.t
1700 ; CHECK-NEXT:    ret
1701 entry:
1702   tail call void @llvm.riscv.vssseg2.mask.nxv4i64(<vscale x 4 x i64> %val,<vscale x 4 x i64> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
1703   ret void
1706 declare void @llvm.riscv.vssseg2.nxv4i16(<vscale x 4 x i16>,<vscale x 4 x i16>, ptr, i64, i64)
1707 declare void @llvm.riscv.vssseg2.mask.nxv4i16(<vscale x 4 x i16>,<vscale x 4 x i16>, ptr, i64, <vscale x 4 x i1>, i64)
1709 define void @test_vssseg2_nxv4i16(<vscale x 4 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
1710 ; CHECK-LABEL: test_vssseg2_nxv4i16:
1711 ; CHECK:       # %bb.0: # %entry
1712 ; CHECK-NEXT:    vmv1r.v v9, v8
1713 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
1714 ; CHECK-NEXT:    vssseg2e16.v v8, (a0), a1
1715 ; CHECK-NEXT:    ret
1716 entry:
1717   tail call void @llvm.riscv.vssseg2.nxv4i16(<vscale x 4 x i16> %val,<vscale x 4 x i16> %val, ptr %base, i64 %offset, i64 %vl)
1718   ret void
1721 define void @test_vssseg2_mask_nxv4i16(<vscale x 4 x i16> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
1722 ; CHECK-LABEL: test_vssseg2_mask_nxv4i16:
1723 ; CHECK:       # %bb.0: # %entry
1724 ; CHECK-NEXT:    vmv1r.v v9, v8
1725 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
1726 ; CHECK-NEXT:    vssseg2e16.v v8, (a0), a1, v0.t
1727 ; CHECK-NEXT:    ret
1728 entry:
1729   tail call void @llvm.riscv.vssseg2.mask.nxv4i16(<vscale x 4 x i16> %val,<vscale x 4 x i16> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
1730   ret void
1733 declare void @llvm.riscv.vssseg3.nxv4i16(<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>, ptr, i64, i64)
1734 declare void @llvm.riscv.vssseg3.mask.nxv4i16(<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>, ptr, i64, <vscale x 4 x i1>, i64)
1736 define void @test_vssseg3_nxv4i16(<vscale x 4 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
1737 ; CHECK-LABEL: test_vssseg3_nxv4i16:
1738 ; CHECK:       # %bb.0: # %entry
1739 ; CHECK-NEXT:    vmv1r.v v9, v8
1740 ; CHECK-NEXT:    vmv1r.v v10, v8
1741 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
1742 ; CHECK-NEXT:    vssseg3e16.v v8, (a0), a1
1743 ; CHECK-NEXT:    ret
1744 entry:
1745   tail call void @llvm.riscv.vssseg3.nxv4i16(<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val, ptr %base, i64 %offset, i64 %vl)
1746   ret void
1749 define void @test_vssseg3_mask_nxv4i16(<vscale x 4 x i16> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
1750 ; CHECK-LABEL: test_vssseg3_mask_nxv4i16:
1751 ; CHECK:       # %bb.0: # %entry
1752 ; CHECK-NEXT:    vmv1r.v v9, v8
1753 ; CHECK-NEXT:    vmv1r.v v10, v8
1754 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
1755 ; CHECK-NEXT:    vssseg3e16.v v8, (a0), a1, v0.t
1756 ; CHECK-NEXT:    ret
1757 entry:
1758   tail call void @llvm.riscv.vssseg3.mask.nxv4i16(<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
1759   ret void
1762 declare void @llvm.riscv.vssseg4.nxv4i16(<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>, ptr, i64, i64)
1763 declare void @llvm.riscv.vssseg4.mask.nxv4i16(<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>, ptr, i64, <vscale x 4 x i1>, i64)
1765 define void @test_vssseg4_nxv4i16(<vscale x 4 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
1766 ; CHECK-LABEL: test_vssseg4_nxv4i16:
1767 ; CHECK:       # %bb.0: # %entry
1768 ; CHECK-NEXT:    vmv1r.v v9, v8
1769 ; CHECK-NEXT:    vmv1r.v v10, v8
1770 ; CHECK-NEXT:    vmv1r.v v11, v8
1771 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
1772 ; CHECK-NEXT:    vssseg4e16.v v8, (a0), a1
1773 ; CHECK-NEXT:    ret
1774 entry:
1775   tail call void @llvm.riscv.vssseg4.nxv4i16(<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val, ptr %base, i64 %offset, i64 %vl)
1776   ret void
1779 define void @test_vssseg4_mask_nxv4i16(<vscale x 4 x i16> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
1780 ; CHECK-LABEL: test_vssseg4_mask_nxv4i16:
1781 ; CHECK:       # %bb.0: # %entry
1782 ; CHECK-NEXT:    vmv1r.v v9, v8
1783 ; CHECK-NEXT:    vmv1r.v v10, v8
1784 ; CHECK-NEXT:    vmv1r.v v11, v8
1785 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
1786 ; CHECK-NEXT:    vssseg4e16.v v8, (a0), a1, v0.t
1787 ; CHECK-NEXT:    ret
1788 entry:
1789   tail call void @llvm.riscv.vssseg4.mask.nxv4i16(<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
1790   ret void
1793 declare void @llvm.riscv.vssseg5.nxv4i16(<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>, ptr, i64, i64)
1794 declare void @llvm.riscv.vssseg5.mask.nxv4i16(<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>, ptr, i64, <vscale x 4 x i1>, i64)
1796 define void @test_vssseg5_nxv4i16(<vscale x 4 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
1797 ; CHECK-LABEL: test_vssseg5_nxv4i16:
1798 ; CHECK:       # %bb.0: # %entry
1799 ; CHECK-NEXT:    vmv1r.v v9, v8
1800 ; CHECK-NEXT:    vmv1r.v v10, v8
1801 ; CHECK-NEXT:    vmv1r.v v11, v8
1802 ; CHECK-NEXT:    vmv1r.v v12, v8
1803 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
1804 ; CHECK-NEXT:    vssseg5e16.v v8, (a0), a1
1805 ; CHECK-NEXT:    ret
1806 entry:
1807   tail call void @llvm.riscv.vssseg5.nxv4i16(<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val, ptr %base, i64 %offset, i64 %vl)
1808   ret void
1811 define void @test_vssseg5_mask_nxv4i16(<vscale x 4 x i16> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
1812 ; CHECK-LABEL: test_vssseg5_mask_nxv4i16:
1813 ; CHECK:       # %bb.0: # %entry
1814 ; CHECK-NEXT:    vmv1r.v v9, v8
1815 ; CHECK-NEXT:    vmv1r.v v10, v8
1816 ; CHECK-NEXT:    vmv1r.v v11, v8
1817 ; CHECK-NEXT:    vmv1r.v v12, v8
1818 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
1819 ; CHECK-NEXT:    vssseg5e16.v v8, (a0), a1, v0.t
1820 ; CHECK-NEXT:    ret
1821 entry:
1822   tail call void @llvm.riscv.vssseg5.mask.nxv4i16(<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
1823   ret void
1826 declare void @llvm.riscv.vssseg6.nxv4i16(<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>, ptr, i64, i64)
1827 declare void @llvm.riscv.vssseg6.mask.nxv4i16(<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>, ptr, i64, <vscale x 4 x i1>, i64)
1829 define void @test_vssseg6_nxv4i16(<vscale x 4 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
1830 ; CHECK-LABEL: test_vssseg6_nxv4i16:
1831 ; CHECK:       # %bb.0: # %entry
1832 ; CHECK-NEXT:    vmv1r.v v9, v8
1833 ; CHECK-NEXT:    vmv1r.v v10, v8
1834 ; CHECK-NEXT:    vmv1r.v v11, v8
1835 ; CHECK-NEXT:    vmv1r.v v12, v8
1836 ; CHECK-NEXT:    vmv1r.v v13, v8
1837 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
1838 ; CHECK-NEXT:    vssseg6e16.v v8, (a0), a1
1839 ; CHECK-NEXT:    ret
1840 entry:
1841   tail call void @llvm.riscv.vssseg6.nxv4i16(<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val, ptr %base, i64 %offset, i64 %vl)
1842   ret void
1845 define void @test_vssseg6_mask_nxv4i16(<vscale x 4 x i16> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
1846 ; CHECK-LABEL: test_vssseg6_mask_nxv4i16:
1847 ; CHECK:       # %bb.0: # %entry
1848 ; CHECK-NEXT:    vmv1r.v v9, v8
1849 ; CHECK-NEXT:    vmv1r.v v10, v8
1850 ; CHECK-NEXT:    vmv1r.v v11, v8
1851 ; CHECK-NEXT:    vmv1r.v v12, v8
1852 ; CHECK-NEXT:    vmv1r.v v13, v8
1853 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
1854 ; CHECK-NEXT:    vssseg6e16.v v8, (a0), a1, v0.t
1855 ; CHECK-NEXT:    ret
1856 entry:
1857   tail call void @llvm.riscv.vssseg6.mask.nxv4i16(<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
1858   ret void
1861 declare void @llvm.riscv.vssseg7.nxv4i16(<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>, ptr, i64, i64)
1862 declare void @llvm.riscv.vssseg7.mask.nxv4i16(<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>, ptr, i64, <vscale x 4 x i1>, i64)
1864 define void @test_vssseg7_nxv4i16(<vscale x 4 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
1865 ; CHECK-LABEL: test_vssseg7_nxv4i16:
1866 ; CHECK:       # %bb.0: # %entry
1867 ; CHECK-NEXT:    vmv1r.v v9, v8
1868 ; CHECK-NEXT:    vmv1r.v v10, v8
1869 ; CHECK-NEXT:    vmv1r.v v11, v8
1870 ; CHECK-NEXT:    vmv1r.v v12, v8
1871 ; CHECK-NEXT:    vmv1r.v v13, v8
1872 ; CHECK-NEXT:    vmv1r.v v14, v8
1873 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
1874 ; CHECK-NEXT:    vssseg7e16.v v8, (a0), a1
1875 ; CHECK-NEXT:    ret
1876 entry:
1877   tail call void @llvm.riscv.vssseg7.nxv4i16(<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val, ptr %base, i64 %offset, i64 %vl)
1878   ret void
1881 define void @test_vssseg7_mask_nxv4i16(<vscale x 4 x i16> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
1882 ; CHECK-LABEL: test_vssseg7_mask_nxv4i16:
1883 ; CHECK:       # %bb.0: # %entry
1884 ; CHECK-NEXT:    vmv1r.v v9, v8
1885 ; CHECK-NEXT:    vmv1r.v v10, v8
1886 ; CHECK-NEXT:    vmv1r.v v11, v8
1887 ; CHECK-NEXT:    vmv1r.v v12, v8
1888 ; CHECK-NEXT:    vmv1r.v v13, v8
1889 ; CHECK-NEXT:    vmv1r.v v14, v8
1890 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
1891 ; CHECK-NEXT:    vssseg7e16.v v8, (a0), a1, v0.t
1892 ; CHECK-NEXT:    ret
1893 entry:
1894   tail call void @llvm.riscv.vssseg7.mask.nxv4i16(<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
1895   ret void
1898 declare void @llvm.riscv.vssseg8.nxv4i16(<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>, ptr, i64, i64)
1899 declare void @llvm.riscv.vssseg8.mask.nxv4i16(<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>,<vscale x 4 x i16>, ptr, i64, <vscale x 4 x i1>, i64)
1901 define void @test_vssseg8_nxv4i16(<vscale x 4 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
1902 ; CHECK-LABEL: test_vssseg8_nxv4i16:
1903 ; CHECK:       # %bb.0: # %entry
1904 ; CHECK-NEXT:    vmv1r.v v9, v8
1905 ; CHECK-NEXT:    vmv1r.v v10, v8
1906 ; CHECK-NEXT:    vmv1r.v v11, v8
1907 ; CHECK-NEXT:    vmv1r.v v12, v8
1908 ; CHECK-NEXT:    vmv1r.v v13, v8
1909 ; CHECK-NEXT:    vmv1r.v v14, v8
1910 ; CHECK-NEXT:    vmv1r.v v15, v8
1911 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
1912 ; CHECK-NEXT:    vssseg8e16.v v8, (a0), a1
1913 ; CHECK-NEXT:    ret
1914 entry:
1915   tail call void @llvm.riscv.vssseg8.nxv4i16(<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val, ptr %base, i64 %offset, i64 %vl)
1916   ret void
1919 define void @test_vssseg8_mask_nxv4i16(<vscale x 4 x i16> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
1920 ; CHECK-LABEL: test_vssseg8_mask_nxv4i16:
1921 ; CHECK:       # %bb.0: # %entry
1922 ; CHECK-NEXT:    vmv1r.v v9, v8
1923 ; CHECK-NEXT:    vmv1r.v v10, v8
1924 ; CHECK-NEXT:    vmv1r.v v11, v8
1925 ; CHECK-NEXT:    vmv1r.v v12, v8
1926 ; CHECK-NEXT:    vmv1r.v v13, v8
1927 ; CHECK-NEXT:    vmv1r.v v14, v8
1928 ; CHECK-NEXT:    vmv1r.v v15, v8
1929 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
1930 ; CHECK-NEXT:    vssseg8e16.v v8, (a0), a1, v0.t
1931 ; CHECK-NEXT:    ret
1932 entry:
1933   tail call void @llvm.riscv.vssseg8.mask.nxv4i16(<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val,<vscale x 4 x i16> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
1934   ret void
1937 declare void @llvm.riscv.vssseg2.nxv1i8(<vscale x 1 x i8>,<vscale x 1 x i8>, ptr, i64, i64)
1938 declare void @llvm.riscv.vssseg2.mask.nxv1i8(<vscale x 1 x i8>,<vscale x 1 x i8>, ptr, i64, <vscale x 1 x i1>, i64)
1940 define void @test_vssseg2_nxv1i8(<vscale x 1 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
1941 ; CHECK-LABEL: test_vssseg2_nxv1i8:
1942 ; CHECK:       # %bb.0: # %entry
1943 ; CHECK-NEXT:    vmv1r.v v9, v8
1944 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf8, ta, ma
1945 ; CHECK-NEXT:    vssseg2e8.v v8, (a0), a1
1946 ; CHECK-NEXT:    ret
1947 entry:
1948   tail call void @llvm.riscv.vssseg2.nxv1i8(<vscale x 1 x i8> %val,<vscale x 1 x i8> %val, ptr %base, i64 %offset, i64 %vl)
1949   ret void
1952 define void @test_vssseg2_mask_nxv1i8(<vscale x 1 x i8> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
1953 ; CHECK-LABEL: test_vssseg2_mask_nxv1i8:
1954 ; CHECK:       # %bb.0: # %entry
1955 ; CHECK-NEXT:    vmv1r.v v9, v8
1956 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf8, ta, ma
1957 ; CHECK-NEXT:    vssseg2e8.v v8, (a0), a1, v0.t
1958 ; CHECK-NEXT:    ret
1959 entry:
1960   tail call void @llvm.riscv.vssseg2.mask.nxv1i8(<vscale x 1 x i8> %val,<vscale x 1 x i8> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
1961   ret void
1964 declare void @llvm.riscv.vssseg3.nxv1i8(<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>, ptr, i64, i64)
1965 declare void @llvm.riscv.vssseg3.mask.nxv1i8(<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>, ptr, i64, <vscale x 1 x i1>, i64)
1967 define void @test_vssseg3_nxv1i8(<vscale x 1 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
1968 ; CHECK-LABEL: test_vssseg3_nxv1i8:
1969 ; CHECK:       # %bb.0: # %entry
1970 ; CHECK-NEXT:    vmv1r.v v9, v8
1971 ; CHECK-NEXT:    vmv1r.v v10, v8
1972 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf8, ta, ma
1973 ; CHECK-NEXT:    vssseg3e8.v v8, (a0), a1
1974 ; CHECK-NEXT:    ret
1975 entry:
1976   tail call void @llvm.riscv.vssseg3.nxv1i8(<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val, ptr %base, i64 %offset, i64 %vl)
1977   ret void
1980 define void @test_vssseg3_mask_nxv1i8(<vscale x 1 x i8> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
1981 ; CHECK-LABEL: test_vssseg3_mask_nxv1i8:
1982 ; CHECK:       # %bb.0: # %entry
1983 ; CHECK-NEXT:    vmv1r.v v9, v8
1984 ; CHECK-NEXT:    vmv1r.v v10, v8
1985 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf8, ta, ma
1986 ; CHECK-NEXT:    vssseg3e8.v v8, (a0), a1, v0.t
1987 ; CHECK-NEXT:    ret
1988 entry:
1989   tail call void @llvm.riscv.vssseg3.mask.nxv1i8(<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
1990   ret void
1993 declare void @llvm.riscv.vssseg4.nxv1i8(<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>, ptr, i64, i64)
1994 declare void @llvm.riscv.vssseg4.mask.nxv1i8(<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>, ptr, i64, <vscale x 1 x i1>, i64)
1996 define void @test_vssseg4_nxv1i8(<vscale x 1 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
1997 ; CHECK-LABEL: test_vssseg4_nxv1i8:
1998 ; CHECK:       # %bb.0: # %entry
1999 ; CHECK-NEXT:    vmv1r.v v9, v8
2000 ; CHECK-NEXT:    vmv1r.v v10, v8
2001 ; CHECK-NEXT:    vmv1r.v v11, v8
2002 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf8, ta, ma
2003 ; CHECK-NEXT:    vssseg4e8.v v8, (a0), a1
2004 ; CHECK-NEXT:    ret
2005 entry:
2006   tail call void @llvm.riscv.vssseg4.nxv1i8(<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val, ptr %base, i64 %offset, i64 %vl)
2007   ret void
2010 define void @test_vssseg4_mask_nxv1i8(<vscale x 1 x i8> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
2011 ; CHECK-LABEL: test_vssseg4_mask_nxv1i8:
2012 ; CHECK:       # %bb.0: # %entry
2013 ; CHECK-NEXT:    vmv1r.v v9, v8
2014 ; CHECK-NEXT:    vmv1r.v v10, v8
2015 ; CHECK-NEXT:    vmv1r.v v11, v8
2016 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf8, ta, ma
2017 ; CHECK-NEXT:    vssseg4e8.v v8, (a0), a1, v0.t
2018 ; CHECK-NEXT:    ret
2019 entry:
2020   tail call void @llvm.riscv.vssseg4.mask.nxv1i8(<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
2021   ret void
2024 declare void @llvm.riscv.vssseg5.nxv1i8(<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>, ptr, i64, i64)
2025 declare void @llvm.riscv.vssseg5.mask.nxv1i8(<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>, ptr, i64, <vscale x 1 x i1>, i64)
2027 define void @test_vssseg5_nxv1i8(<vscale x 1 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
2028 ; CHECK-LABEL: test_vssseg5_nxv1i8:
2029 ; CHECK:       # %bb.0: # %entry
2030 ; CHECK-NEXT:    vmv1r.v v9, v8
2031 ; CHECK-NEXT:    vmv1r.v v10, v8
2032 ; CHECK-NEXT:    vmv1r.v v11, v8
2033 ; CHECK-NEXT:    vmv1r.v v12, v8
2034 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf8, ta, ma
2035 ; CHECK-NEXT:    vssseg5e8.v v8, (a0), a1
2036 ; CHECK-NEXT:    ret
2037 entry:
2038   tail call void @llvm.riscv.vssseg5.nxv1i8(<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val, ptr %base, i64 %offset, i64 %vl)
2039   ret void
2042 define void @test_vssseg5_mask_nxv1i8(<vscale x 1 x i8> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
2043 ; CHECK-LABEL: test_vssseg5_mask_nxv1i8:
2044 ; CHECK:       # %bb.0: # %entry
2045 ; CHECK-NEXT:    vmv1r.v v9, v8
2046 ; CHECK-NEXT:    vmv1r.v v10, v8
2047 ; CHECK-NEXT:    vmv1r.v v11, v8
2048 ; CHECK-NEXT:    vmv1r.v v12, v8
2049 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf8, ta, ma
2050 ; CHECK-NEXT:    vssseg5e8.v v8, (a0), a1, v0.t
2051 ; CHECK-NEXT:    ret
2052 entry:
2053   tail call void @llvm.riscv.vssseg5.mask.nxv1i8(<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
2054   ret void
2057 declare void @llvm.riscv.vssseg6.nxv1i8(<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>, ptr, i64, i64)
2058 declare void @llvm.riscv.vssseg6.mask.nxv1i8(<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>, ptr, i64, <vscale x 1 x i1>, i64)
2060 define void @test_vssseg6_nxv1i8(<vscale x 1 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
2061 ; CHECK-LABEL: test_vssseg6_nxv1i8:
2062 ; CHECK:       # %bb.0: # %entry
2063 ; CHECK-NEXT:    vmv1r.v v9, v8
2064 ; CHECK-NEXT:    vmv1r.v v10, v8
2065 ; CHECK-NEXT:    vmv1r.v v11, v8
2066 ; CHECK-NEXT:    vmv1r.v v12, v8
2067 ; CHECK-NEXT:    vmv1r.v v13, v8
2068 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf8, ta, ma
2069 ; CHECK-NEXT:    vssseg6e8.v v8, (a0), a1
2070 ; CHECK-NEXT:    ret
2071 entry:
2072   tail call void @llvm.riscv.vssseg6.nxv1i8(<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val, ptr %base, i64 %offset, i64 %vl)
2073   ret void
2076 define void @test_vssseg6_mask_nxv1i8(<vscale x 1 x i8> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
2077 ; CHECK-LABEL: test_vssseg6_mask_nxv1i8:
2078 ; CHECK:       # %bb.0: # %entry
2079 ; CHECK-NEXT:    vmv1r.v v9, v8
2080 ; CHECK-NEXT:    vmv1r.v v10, v8
2081 ; CHECK-NEXT:    vmv1r.v v11, v8
2082 ; CHECK-NEXT:    vmv1r.v v12, v8
2083 ; CHECK-NEXT:    vmv1r.v v13, v8
2084 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf8, ta, ma
2085 ; CHECK-NEXT:    vssseg6e8.v v8, (a0), a1, v0.t
2086 ; CHECK-NEXT:    ret
2087 entry:
2088   tail call void @llvm.riscv.vssseg6.mask.nxv1i8(<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
2089   ret void
2092 declare void @llvm.riscv.vssseg7.nxv1i8(<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>, ptr, i64, i64)
2093 declare void @llvm.riscv.vssseg7.mask.nxv1i8(<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>, ptr, i64, <vscale x 1 x i1>, i64)
2095 define void @test_vssseg7_nxv1i8(<vscale x 1 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
2096 ; CHECK-LABEL: test_vssseg7_nxv1i8:
2097 ; CHECK:       # %bb.0: # %entry
2098 ; CHECK-NEXT:    vmv1r.v v9, v8
2099 ; CHECK-NEXT:    vmv1r.v v10, v8
2100 ; CHECK-NEXT:    vmv1r.v v11, v8
2101 ; CHECK-NEXT:    vmv1r.v v12, v8
2102 ; CHECK-NEXT:    vmv1r.v v13, v8
2103 ; CHECK-NEXT:    vmv1r.v v14, v8
2104 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf8, ta, ma
2105 ; CHECK-NEXT:    vssseg7e8.v v8, (a0), a1
2106 ; CHECK-NEXT:    ret
2107 entry:
2108   tail call void @llvm.riscv.vssseg7.nxv1i8(<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val, ptr %base, i64 %offset, i64 %vl)
2109   ret void
2112 define void @test_vssseg7_mask_nxv1i8(<vscale x 1 x i8> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
2113 ; CHECK-LABEL: test_vssseg7_mask_nxv1i8:
2114 ; CHECK:       # %bb.0: # %entry
2115 ; CHECK-NEXT:    vmv1r.v v9, v8
2116 ; CHECK-NEXT:    vmv1r.v v10, v8
2117 ; CHECK-NEXT:    vmv1r.v v11, v8
2118 ; CHECK-NEXT:    vmv1r.v v12, v8
2119 ; CHECK-NEXT:    vmv1r.v v13, v8
2120 ; CHECK-NEXT:    vmv1r.v v14, v8
2121 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf8, ta, ma
2122 ; CHECK-NEXT:    vssseg7e8.v v8, (a0), a1, v0.t
2123 ; CHECK-NEXT:    ret
2124 entry:
2125   tail call void @llvm.riscv.vssseg7.mask.nxv1i8(<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
2126   ret void
2129 declare void @llvm.riscv.vssseg8.nxv1i8(<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>, ptr, i64, i64)
2130 declare void @llvm.riscv.vssseg8.mask.nxv1i8(<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>,<vscale x 1 x i8>, ptr, i64, <vscale x 1 x i1>, i64)
2132 define void @test_vssseg8_nxv1i8(<vscale x 1 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
2133 ; CHECK-LABEL: test_vssseg8_nxv1i8:
2134 ; CHECK:       # %bb.0: # %entry
2135 ; CHECK-NEXT:    vmv1r.v v9, v8
2136 ; CHECK-NEXT:    vmv1r.v v10, v8
2137 ; CHECK-NEXT:    vmv1r.v v11, v8
2138 ; CHECK-NEXT:    vmv1r.v v12, v8
2139 ; CHECK-NEXT:    vmv1r.v v13, v8
2140 ; CHECK-NEXT:    vmv1r.v v14, v8
2141 ; CHECK-NEXT:    vmv1r.v v15, v8
2142 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf8, ta, ma
2143 ; CHECK-NEXT:    vssseg8e8.v v8, (a0), a1
2144 ; CHECK-NEXT:    ret
2145 entry:
2146   tail call void @llvm.riscv.vssseg8.nxv1i8(<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val, ptr %base, i64 %offset, i64 %vl)
2147   ret void
2150 define void @test_vssseg8_mask_nxv1i8(<vscale x 1 x i8> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
2151 ; CHECK-LABEL: test_vssseg8_mask_nxv1i8:
2152 ; CHECK:       # %bb.0: # %entry
2153 ; CHECK-NEXT:    vmv1r.v v9, v8
2154 ; CHECK-NEXT:    vmv1r.v v10, v8
2155 ; CHECK-NEXT:    vmv1r.v v11, v8
2156 ; CHECK-NEXT:    vmv1r.v v12, v8
2157 ; CHECK-NEXT:    vmv1r.v v13, v8
2158 ; CHECK-NEXT:    vmv1r.v v14, v8
2159 ; CHECK-NEXT:    vmv1r.v v15, v8
2160 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf8, ta, ma
2161 ; CHECK-NEXT:    vssseg8e8.v v8, (a0), a1, v0.t
2162 ; CHECK-NEXT:    ret
2163 entry:
2164   tail call void @llvm.riscv.vssseg8.mask.nxv1i8(<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val,<vscale x 1 x i8> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
2165   ret void
2168 declare void @llvm.riscv.vssseg2.nxv2i8(<vscale x 2 x i8>,<vscale x 2 x i8>, ptr, i64, i64)
2169 declare void @llvm.riscv.vssseg2.mask.nxv2i8(<vscale x 2 x i8>,<vscale x 2 x i8>, ptr, i64, <vscale x 2 x i1>, i64)
2171 define void @test_vssseg2_nxv2i8(<vscale x 2 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
2172 ; CHECK-LABEL: test_vssseg2_nxv2i8:
2173 ; CHECK:       # %bb.0: # %entry
2174 ; CHECK-NEXT:    vmv1r.v v9, v8
2175 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf4, ta, ma
2176 ; CHECK-NEXT:    vssseg2e8.v v8, (a0), a1
2177 ; CHECK-NEXT:    ret
2178 entry:
2179   tail call void @llvm.riscv.vssseg2.nxv2i8(<vscale x 2 x i8> %val,<vscale x 2 x i8> %val, ptr %base, i64 %offset, i64 %vl)
2180   ret void
2183 define void @test_vssseg2_mask_nxv2i8(<vscale x 2 x i8> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
2184 ; CHECK-LABEL: test_vssseg2_mask_nxv2i8:
2185 ; CHECK:       # %bb.0: # %entry
2186 ; CHECK-NEXT:    vmv1r.v v9, v8
2187 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf4, ta, ma
2188 ; CHECK-NEXT:    vssseg2e8.v v8, (a0), a1, v0.t
2189 ; CHECK-NEXT:    ret
2190 entry:
2191   tail call void @llvm.riscv.vssseg2.mask.nxv2i8(<vscale x 2 x i8> %val,<vscale x 2 x i8> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
2192   ret void
2195 declare void @llvm.riscv.vssseg3.nxv2i8(<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>, ptr, i64, i64)
2196 declare void @llvm.riscv.vssseg3.mask.nxv2i8(<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>, ptr, i64, <vscale x 2 x i1>, i64)
2198 define void @test_vssseg3_nxv2i8(<vscale x 2 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
2199 ; CHECK-LABEL: test_vssseg3_nxv2i8:
2200 ; CHECK:       # %bb.0: # %entry
2201 ; CHECK-NEXT:    vmv1r.v v9, v8
2202 ; CHECK-NEXT:    vmv1r.v v10, v8
2203 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf4, ta, ma
2204 ; CHECK-NEXT:    vssseg3e8.v v8, (a0), a1
2205 ; CHECK-NEXT:    ret
2206 entry:
2207   tail call void @llvm.riscv.vssseg3.nxv2i8(<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val, ptr %base, i64 %offset, i64 %vl)
2208   ret void
2211 define void @test_vssseg3_mask_nxv2i8(<vscale x 2 x i8> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
2212 ; CHECK-LABEL: test_vssseg3_mask_nxv2i8:
2213 ; CHECK:       # %bb.0: # %entry
2214 ; CHECK-NEXT:    vmv1r.v v9, v8
2215 ; CHECK-NEXT:    vmv1r.v v10, v8
2216 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf4, ta, ma
2217 ; CHECK-NEXT:    vssseg3e8.v v8, (a0), a1, v0.t
2218 ; CHECK-NEXT:    ret
2219 entry:
2220   tail call void @llvm.riscv.vssseg3.mask.nxv2i8(<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
2221   ret void
2224 declare void @llvm.riscv.vssseg4.nxv2i8(<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>, ptr, i64, i64)
2225 declare void @llvm.riscv.vssseg4.mask.nxv2i8(<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>, ptr, i64, <vscale x 2 x i1>, i64)
2227 define void @test_vssseg4_nxv2i8(<vscale x 2 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
2228 ; CHECK-LABEL: test_vssseg4_nxv2i8:
2229 ; CHECK:       # %bb.0: # %entry
2230 ; CHECK-NEXT:    vmv1r.v v9, v8
2231 ; CHECK-NEXT:    vmv1r.v v10, v8
2232 ; CHECK-NEXT:    vmv1r.v v11, v8
2233 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf4, ta, ma
2234 ; CHECK-NEXT:    vssseg4e8.v v8, (a0), a1
2235 ; CHECK-NEXT:    ret
2236 entry:
2237   tail call void @llvm.riscv.vssseg4.nxv2i8(<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val, ptr %base, i64 %offset, i64 %vl)
2238   ret void
2241 define void @test_vssseg4_mask_nxv2i8(<vscale x 2 x i8> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
2242 ; CHECK-LABEL: test_vssseg4_mask_nxv2i8:
2243 ; CHECK:       # %bb.0: # %entry
2244 ; CHECK-NEXT:    vmv1r.v v9, v8
2245 ; CHECK-NEXT:    vmv1r.v v10, v8
2246 ; CHECK-NEXT:    vmv1r.v v11, v8
2247 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf4, ta, ma
2248 ; CHECK-NEXT:    vssseg4e8.v v8, (a0), a1, v0.t
2249 ; CHECK-NEXT:    ret
2250 entry:
2251   tail call void @llvm.riscv.vssseg4.mask.nxv2i8(<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
2252   ret void
2255 declare void @llvm.riscv.vssseg5.nxv2i8(<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>, ptr, i64, i64)
2256 declare void @llvm.riscv.vssseg5.mask.nxv2i8(<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>, ptr, i64, <vscale x 2 x i1>, i64)
2258 define void @test_vssseg5_nxv2i8(<vscale x 2 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
2259 ; CHECK-LABEL: test_vssseg5_nxv2i8:
2260 ; CHECK:       # %bb.0: # %entry
2261 ; CHECK-NEXT:    vmv1r.v v9, v8
2262 ; CHECK-NEXT:    vmv1r.v v10, v8
2263 ; CHECK-NEXT:    vmv1r.v v11, v8
2264 ; CHECK-NEXT:    vmv1r.v v12, v8
2265 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf4, ta, ma
2266 ; CHECK-NEXT:    vssseg5e8.v v8, (a0), a1
2267 ; CHECK-NEXT:    ret
2268 entry:
2269   tail call void @llvm.riscv.vssseg5.nxv2i8(<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val, ptr %base, i64 %offset, i64 %vl)
2270   ret void
2273 define void @test_vssseg5_mask_nxv2i8(<vscale x 2 x i8> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
2274 ; CHECK-LABEL: test_vssseg5_mask_nxv2i8:
2275 ; CHECK:       # %bb.0: # %entry
2276 ; CHECK-NEXT:    vmv1r.v v9, v8
2277 ; CHECK-NEXT:    vmv1r.v v10, v8
2278 ; CHECK-NEXT:    vmv1r.v v11, v8
2279 ; CHECK-NEXT:    vmv1r.v v12, v8
2280 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf4, ta, ma
2281 ; CHECK-NEXT:    vssseg5e8.v v8, (a0), a1, v0.t
2282 ; CHECK-NEXT:    ret
2283 entry:
2284   tail call void @llvm.riscv.vssseg5.mask.nxv2i8(<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
2285   ret void
2288 declare void @llvm.riscv.vssseg6.nxv2i8(<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>, ptr, i64, i64)
2289 declare void @llvm.riscv.vssseg6.mask.nxv2i8(<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>, ptr, i64, <vscale x 2 x i1>, i64)
2291 define void @test_vssseg6_nxv2i8(<vscale x 2 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
2292 ; CHECK-LABEL: test_vssseg6_nxv2i8:
2293 ; CHECK:       # %bb.0: # %entry
2294 ; CHECK-NEXT:    vmv1r.v v9, v8
2295 ; CHECK-NEXT:    vmv1r.v v10, v8
2296 ; CHECK-NEXT:    vmv1r.v v11, v8
2297 ; CHECK-NEXT:    vmv1r.v v12, v8
2298 ; CHECK-NEXT:    vmv1r.v v13, v8
2299 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf4, ta, ma
2300 ; CHECK-NEXT:    vssseg6e8.v v8, (a0), a1
2301 ; CHECK-NEXT:    ret
2302 entry:
2303   tail call void @llvm.riscv.vssseg6.nxv2i8(<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val, ptr %base, i64 %offset, i64 %vl)
2304   ret void
2307 define void @test_vssseg6_mask_nxv2i8(<vscale x 2 x i8> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
2308 ; CHECK-LABEL: test_vssseg6_mask_nxv2i8:
2309 ; CHECK:       # %bb.0: # %entry
2310 ; CHECK-NEXT:    vmv1r.v v9, v8
2311 ; CHECK-NEXT:    vmv1r.v v10, v8
2312 ; CHECK-NEXT:    vmv1r.v v11, v8
2313 ; CHECK-NEXT:    vmv1r.v v12, v8
2314 ; CHECK-NEXT:    vmv1r.v v13, v8
2315 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf4, ta, ma
2316 ; CHECK-NEXT:    vssseg6e8.v v8, (a0), a1, v0.t
2317 ; CHECK-NEXT:    ret
2318 entry:
2319   tail call void @llvm.riscv.vssseg6.mask.nxv2i8(<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
2320   ret void
2323 declare void @llvm.riscv.vssseg7.nxv2i8(<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>, ptr, i64, i64)
2324 declare void @llvm.riscv.vssseg7.mask.nxv2i8(<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>, ptr, i64, <vscale x 2 x i1>, i64)
2326 define void @test_vssseg7_nxv2i8(<vscale x 2 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
2327 ; CHECK-LABEL: test_vssseg7_nxv2i8:
2328 ; CHECK:       # %bb.0: # %entry
2329 ; CHECK-NEXT:    vmv1r.v v9, v8
2330 ; CHECK-NEXT:    vmv1r.v v10, v8
2331 ; CHECK-NEXT:    vmv1r.v v11, v8
2332 ; CHECK-NEXT:    vmv1r.v v12, v8
2333 ; CHECK-NEXT:    vmv1r.v v13, v8
2334 ; CHECK-NEXT:    vmv1r.v v14, v8
2335 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf4, ta, ma
2336 ; CHECK-NEXT:    vssseg7e8.v v8, (a0), a1
2337 ; CHECK-NEXT:    ret
2338 entry:
2339   tail call void @llvm.riscv.vssseg7.nxv2i8(<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val, ptr %base, i64 %offset, i64 %vl)
2340   ret void
2343 define void @test_vssseg7_mask_nxv2i8(<vscale x 2 x i8> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
2344 ; CHECK-LABEL: test_vssseg7_mask_nxv2i8:
2345 ; CHECK:       # %bb.0: # %entry
2346 ; CHECK-NEXT:    vmv1r.v v9, v8
2347 ; CHECK-NEXT:    vmv1r.v v10, v8
2348 ; CHECK-NEXT:    vmv1r.v v11, v8
2349 ; CHECK-NEXT:    vmv1r.v v12, v8
2350 ; CHECK-NEXT:    vmv1r.v v13, v8
2351 ; CHECK-NEXT:    vmv1r.v v14, v8
2352 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf4, ta, ma
2353 ; CHECK-NEXT:    vssseg7e8.v v8, (a0), a1, v0.t
2354 ; CHECK-NEXT:    ret
2355 entry:
2356   tail call void @llvm.riscv.vssseg7.mask.nxv2i8(<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
2357   ret void
2360 declare void @llvm.riscv.vssseg8.nxv2i8(<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>, ptr, i64, i64)
2361 declare void @llvm.riscv.vssseg8.mask.nxv2i8(<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>,<vscale x 2 x i8>, ptr, i64, <vscale x 2 x i1>, i64)
2363 define void @test_vssseg8_nxv2i8(<vscale x 2 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
2364 ; CHECK-LABEL: test_vssseg8_nxv2i8:
2365 ; CHECK:       # %bb.0: # %entry
2366 ; CHECK-NEXT:    vmv1r.v v9, v8
2367 ; CHECK-NEXT:    vmv1r.v v10, v8
2368 ; CHECK-NEXT:    vmv1r.v v11, v8
2369 ; CHECK-NEXT:    vmv1r.v v12, v8
2370 ; CHECK-NEXT:    vmv1r.v v13, v8
2371 ; CHECK-NEXT:    vmv1r.v v14, v8
2372 ; CHECK-NEXT:    vmv1r.v v15, v8
2373 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf4, ta, ma
2374 ; CHECK-NEXT:    vssseg8e8.v v8, (a0), a1
2375 ; CHECK-NEXT:    ret
2376 entry:
2377   tail call void @llvm.riscv.vssseg8.nxv2i8(<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val, ptr %base, i64 %offset, i64 %vl)
2378   ret void
2381 define void @test_vssseg8_mask_nxv2i8(<vscale x 2 x i8> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
2382 ; CHECK-LABEL: test_vssseg8_mask_nxv2i8:
2383 ; CHECK:       # %bb.0: # %entry
2384 ; CHECK-NEXT:    vmv1r.v v9, v8
2385 ; CHECK-NEXT:    vmv1r.v v10, v8
2386 ; CHECK-NEXT:    vmv1r.v v11, v8
2387 ; CHECK-NEXT:    vmv1r.v v12, v8
2388 ; CHECK-NEXT:    vmv1r.v v13, v8
2389 ; CHECK-NEXT:    vmv1r.v v14, v8
2390 ; CHECK-NEXT:    vmv1r.v v15, v8
2391 ; CHECK-NEXT:    vsetvli zero, a2, e8, mf4, ta, ma
2392 ; CHECK-NEXT:    vssseg8e8.v v8, (a0), a1, v0.t
2393 ; CHECK-NEXT:    ret
2394 entry:
2395   tail call void @llvm.riscv.vssseg8.mask.nxv2i8(<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val,<vscale x 2 x i8> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
2396   ret void
2399 declare void @llvm.riscv.vssseg2.nxv8i32(<vscale x 8 x i32>,<vscale x 8 x i32>, ptr, i64, i64)
2400 declare void @llvm.riscv.vssseg2.mask.nxv8i32(<vscale x 8 x i32>,<vscale x 8 x i32>, ptr, i64, <vscale x 8 x i1>, i64)
2402 define void @test_vssseg2_nxv8i32(<vscale x 8 x i32> %val, ptr %base, i64 %offset, i64 %vl) {
2403 ; CHECK-LABEL: test_vssseg2_nxv8i32:
2404 ; CHECK:       # %bb.0: # %entry
2405 ; CHECK-NEXT:    vmv4r.v v12, v8
2406 ; CHECK-NEXT:    vsetvli zero, a2, e32, m4, ta, ma
2407 ; CHECK-NEXT:    vssseg2e32.v v8, (a0), a1
2408 ; CHECK-NEXT:    ret
2409 entry:
2410   tail call void @llvm.riscv.vssseg2.nxv8i32(<vscale x 8 x i32> %val,<vscale x 8 x i32> %val, ptr %base, i64 %offset, i64 %vl)
2411   ret void
2414 define void @test_vssseg2_mask_nxv8i32(<vscale x 8 x i32> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl) {
2415 ; CHECK-LABEL: test_vssseg2_mask_nxv8i32:
2416 ; CHECK:       # %bb.0: # %entry
2417 ; CHECK-NEXT:    vmv4r.v v12, v8
2418 ; CHECK-NEXT:    vsetvli zero, a2, e32, m4, ta, ma
2419 ; CHECK-NEXT:    vssseg2e32.v v8, (a0), a1, v0.t
2420 ; CHECK-NEXT:    ret
2421 entry:
2422   tail call void @llvm.riscv.vssseg2.mask.nxv8i32(<vscale x 8 x i32> %val,<vscale x 8 x i32> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl)
2423   ret void
2426 declare void @llvm.riscv.vssseg2.nxv32i8(<vscale x 32 x i8>,<vscale x 32 x i8>, ptr, i64, i64)
2427 declare void @llvm.riscv.vssseg2.mask.nxv32i8(<vscale x 32 x i8>,<vscale x 32 x i8>, ptr, i64, <vscale x 32 x i1>, i64)
2429 define void @test_vssseg2_nxv32i8(<vscale x 32 x i8> %val, ptr %base, i64 %offset, i64 %vl) {
2430 ; CHECK-LABEL: test_vssseg2_nxv32i8:
2431 ; CHECK:       # %bb.0: # %entry
2432 ; CHECK-NEXT:    vmv4r.v v12, v8
2433 ; CHECK-NEXT:    vsetvli zero, a2, e8, m4, ta, ma
2434 ; CHECK-NEXT:    vssseg2e8.v v8, (a0), a1
2435 ; CHECK-NEXT:    ret
2436 entry:
2437   tail call void @llvm.riscv.vssseg2.nxv32i8(<vscale x 32 x i8> %val,<vscale x 32 x i8> %val, ptr %base, i64 %offset, i64 %vl)
2438   ret void
2441 define void @test_vssseg2_mask_nxv32i8(<vscale x 32 x i8> %val, ptr %base, i64 %offset, <vscale x 32 x i1> %mask, i64 %vl) {
2442 ; CHECK-LABEL: test_vssseg2_mask_nxv32i8:
2443 ; CHECK:       # %bb.0: # %entry
2444 ; CHECK-NEXT:    vmv4r.v v12, v8
2445 ; CHECK-NEXT:    vsetvli zero, a2, e8, m4, ta, ma
2446 ; CHECK-NEXT:    vssseg2e8.v v8, (a0), a1, v0.t
2447 ; CHECK-NEXT:    ret
2448 entry:
2449   tail call void @llvm.riscv.vssseg2.mask.nxv32i8(<vscale x 32 x i8> %val,<vscale x 32 x i8> %val, ptr %base, i64 %offset, <vscale x 32 x i1> %mask, i64 %vl)
2450   ret void
2453 declare void @llvm.riscv.vssseg2.nxv2i16(<vscale x 2 x i16>,<vscale x 2 x i16>, ptr, i64, i64)
2454 declare void @llvm.riscv.vssseg2.mask.nxv2i16(<vscale x 2 x i16>,<vscale x 2 x i16>, ptr, i64, <vscale x 2 x i1>, i64)
2456 define void @test_vssseg2_nxv2i16(<vscale x 2 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
2457 ; CHECK-LABEL: test_vssseg2_nxv2i16:
2458 ; CHECK:       # %bb.0: # %entry
2459 ; CHECK-NEXT:    vmv1r.v v9, v8
2460 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
2461 ; CHECK-NEXT:    vssseg2e16.v v8, (a0), a1
2462 ; CHECK-NEXT:    ret
2463 entry:
2464   tail call void @llvm.riscv.vssseg2.nxv2i16(<vscale x 2 x i16> %val,<vscale x 2 x i16> %val, ptr %base, i64 %offset, i64 %vl)
2465   ret void
2468 define void @test_vssseg2_mask_nxv2i16(<vscale x 2 x i16> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
2469 ; CHECK-LABEL: test_vssseg2_mask_nxv2i16:
2470 ; CHECK:       # %bb.0: # %entry
2471 ; CHECK-NEXT:    vmv1r.v v9, v8
2472 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
2473 ; CHECK-NEXT:    vssseg2e16.v v8, (a0), a1, v0.t
2474 ; CHECK-NEXT:    ret
2475 entry:
2476   tail call void @llvm.riscv.vssseg2.mask.nxv2i16(<vscale x 2 x i16> %val,<vscale x 2 x i16> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
2477   ret void
2480 declare void @llvm.riscv.vssseg3.nxv2i16(<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>, ptr, i64, i64)
2481 declare void @llvm.riscv.vssseg3.mask.nxv2i16(<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>, ptr, i64, <vscale x 2 x i1>, i64)
2483 define void @test_vssseg3_nxv2i16(<vscale x 2 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
2484 ; CHECK-LABEL: test_vssseg3_nxv2i16:
2485 ; CHECK:       # %bb.0: # %entry
2486 ; CHECK-NEXT:    vmv1r.v v9, v8
2487 ; CHECK-NEXT:    vmv1r.v v10, v8
2488 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
2489 ; CHECK-NEXT:    vssseg3e16.v v8, (a0), a1
2490 ; CHECK-NEXT:    ret
2491 entry:
2492   tail call void @llvm.riscv.vssseg3.nxv2i16(<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val, ptr %base, i64 %offset, i64 %vl)
2493   ret void
2496 define void @test_vssseg3_mask_nxv2i16(<vscale x 2 x i16> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
2497 ; CHECK-LABEL: test_vssseg3_mask_nxv2i16:
2498 ; CHECK:       # %bb.0: # %entry
2499 ; CHECK-NEXT:    vmv1r.v v9, v8
2500 ; CHECK-NEXT:    vmv1r.v v10, v8
2501 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
2502 ; CHECK-NEXT:    vssseg3e16.v v8, (a0), a1, v0.t
2503 ; CHECK-NEXT:    ret
2504 entry:
2505   tail call void @llvm.riscv.vssseg3.mask.nxv2i16(<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
2506   ret void
2509 declare void @llvm.riscv.vssseg4.nxv2i16(<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>, ptr, i64, i64)
2510 declare void @llvm.riscv.vssseg4.mask.nxv2i16(<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>, ptr, i64, <vscale x 2 x i1>, i64)
2512 define void @test_vssseg4_nxv2i16(<vscale x 2 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
2513 ; CHECK-LABEL: test_vssseg4_nxv2i16:
2514 ; CHECK:       # %bb.0: # %entry
2515 ; CHECK-NEXT:    vmv1r.v v9, v8
2516 ; CHECK-NEXT:    vmv1r.v v10, v8
2517 ; CHECK-NEXT:    vmv1r.v v11, v8
2518 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
2519 ; CHECK-NEXT:    vssseg4e16.v v8, (a0), a1
2520 ; CHECK-NEXT:    ret
2521 entry:
2522   tail call void @llvm.riscv.vssseg4.nxv2i16(<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val, ptr %base, i64 %offset, i64 %vl)
2523   ret void
2526 define void @test_vssseg4_mask_nxv2i16(<vscale x 2 x i16> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
2527 ; CHECK-LABEL: test_vssseg4_mask_nxv2i16:
2528 ; CHECK:       # %bb.0: # %entry
2529 ; CHECK-NEXT:    vmv1r.v v9, v8
2530 ; CHECK-NEXT:    vmv1r.v v10, v8
2531 ; CHECK-NEXT:    vmv1r.v v11, v8
2532 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
2533 ; CHECK-NEXT:    vssseg4e16.v v8, (a0), a1, v0.t
2534 ; CHECK-NEXT:    ret
2535 entry:
2536   tail call void @llvm.riscv.vssseg4.mask.nxv2i16(<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
2537   ret void
2540 declare void @llvm.riscv.vssseg5.nxv2i16(<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>, ptr, i64, i64)
2541 declare void @llvm.riscv.vssseg5.mask.nxv2i16(<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>, ptr, i64, <vscale x 2 x i1>, i64)
2543 define void @test_vssseg5_nxv2i16(<vscale x 2 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
2544 ; CHECK-LABEL: test_vssseg5_nxv2i16:
2545 ; CHECK:       # %bb.0: # %entry
2546 ; CHECK-NEXT:    vmv1r.v v9, v8
2547 ; CHECK-NEXT:    vmv1r.v v10, v8
2548 ; CHECK-NEXT:    vmv1r.v v11, v8
2549 ; CHECK-NEXT:    vmv1r.v v12, v8
2550 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
2551 ; CHECK-NEXT:    vssseg5e16.v v8, (a0), a1
2552 ; CHECK-NEXT:    ret
2553 entry:
2554   tail call void @llvm.riscv.vssseg5.nxv2i16(<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val, ptr %base, i64 %offset, i64 %vl)
2555   ret void
2558 define void @test_vssseg5_mask_nxv2i16(<vscale x 2 x i16> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
2559 ; CHECK-LABEL: test_vssseg5_mask_nxv2i16:
2560 ; CHECK:       # %bb.0: # %entry
2561 ; CHECK-NEXT:    vmv1r.v v9, v8
2562 ; CHECK-NEXT:    vmv1r.v v10, v8
2563 ; CHECK-NEXT:    vmv1r.v v11, v8
2564 ; CHECK-NEXT:    vmv1r.v v12, v8
2565 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
2566 ; CHECK-NEXT:    vssseg5e16.v v8, (a0), a1, v0.t
2567 ; CHECK-NEXT:    ret
2568 entry:
2569   tail call void @llvm.riscv.vssseg5.mask.nxv2i16(<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
2570   ret void
2573 declare void @llvm.riscv.vssseg6.nxv2i16(<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>, ptr, i64, i64)
2574 declare void @llvm.riscv.vssseg6.mask.nxv2i16(<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>, ptr, i64, <vscale x 2 x i1>, i64)
2576 define void @test_vssseg6_nxv2i16(<vscale x 2 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
2577 ; CHECK-LABEL: test_vssseg6_nxv2i16:
2578 ; CHECK:       # %bb.0: # %entry
2579 ; CHECK-NEXT:    vmv1r.v v9, v8
2580 ; CHECK-NEXT:    vmv1r.v v10, v8
2581 ; CHECK-NEXT:    vmv1r.v v11, v8
2582 ; CHECK-NEXT:    vmv1r.v v12, v8
2583 ; CHECK-NEXT:    vmv1r.v v13, v8
2584 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
2585 ; CHECK-NEXT:    vssseg6e16.v v8, (a0), a1
2586 ; CHECK-NEXT:    ret
2587 entry:
2588   tail call void @llvm.riscv.vssseg6.nxv2i16(<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val, ptr %base, i64 %offset, i64 %vl)
2589   ret void
2592 define void @test_vssseg6_mask_nxv2i16(<vscale x 2 x i16> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
2593 ; CHECK-LABEL: test_vssseg6_mask_nxv2i16:
2594 ; CHECK:       # %bb.0: # %entry
2595 ; CHECK-NEXT:    vmv1r.v v9, v8
2596 ; CHECK-NEXT:    vmv1r.v v10, v8
2597 ; CHECK-NEXT:    vmv1r.v v11, v8
2598 ; CHECK-NEXT:    vmv1r.v v12, v8
2599 ; CHECK-NEXT:    vmv1r.v v13, v8
2600 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
2601 ; CHECK-NEXT:    vssseg6e16.v v8, (a0), a1, v0.t
2602 ; CHECK-NEXT:    ret
2603 entry:
2604   tail call void @llvm.riscv.vssseg6.mask.nxv2i16(<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
2605   ret void
2608 declare void @llvm.riscv.vssseg7.nxv2i16(<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>, ptr, i64, i64)
2609 declare void @llvm.riscv.vssseg7.mask.nxv2i16(<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>, ptr, i64, <vscale x 2 x i1>, i64)
2611 define void @test_vssseg7_nxv2i16(<vscale x 2 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
2612 ; CHECK-LABEL: test_vssseg7_nxv2i16:
2613 ; CHECK:       # %bb.0: # %entry
2614 ; CHECK-NEXT:    vmv1r.v v9, v8
2615 ; CHECK-NEXT:    vmv1r.v v10, v8
2616 ; CHECK-NEXT:    vmv1r.v v11, v8
2617 ; CHECK-NEXT:    vmv1r.v v12, v8
2618 ; CHECK-NEXT:    vmv1r.v v13, v8
2619 ; CHECK-NEXT:    vmv1r.v v14, v8
2620 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
2621 ; CHECK-NEXT:    vssseg7e16.v v8, (a0), a1
2622 ; CHECK-NEXT:    ret
2623 entry:
2624   tail call void @llvm.riscv.vssseg7.nxv2i16(<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val, ptr %base, i64 %offset, i64 %vl)
2625   ret void
2628 define void @test_vssseg7_mask_nxv2i16(<vscale x 2 x i16> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
2629 ; CHECK-LABEL: test_vssseg7_mask_nxv2i16:
2630 ; CHECK:       # %bb.0: # %entry
2631 ; CHECK-NEXT:    vmv1r.v v9, v8
2632 ; CHECK-NEXT:    vmv1r.v v10, v8
2633 ; CHECK-NEXT:    vmv1r.v v11, v8
2634 ; CHECK-NEXT:    vmv1r.v v12, v8
2635 ; CHECK-NEXT:    vmv1r.v v13, v8
2636 ; CHECK-NEXT:    vmv1r.v v14, v8
2637 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
2638 ; CHECK-NEXT:    vssseg7e16.v v8, (a0), a1, v0.t
2639 ; CHECK-NEXT:    ret
2640 entry:
2641   tail call void @llvm.riscv.vssseg7.mask.nxv2i16(<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
2642   ret void
2645 declare void @llvm.riscv.vssseg8.nxv2i16(<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>, ptr, i64, i64)
2646 declare void @llvm.riscv.vssseg8.mask.nxv2i16(<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>,<vscale x 2 x i16>, ptr, i64, <vscale x 2 x i1>, i64)
2648 define void @test_vssseg8_nxv2i16(<vscale x 2 x i16> %val, ptr %base, i64 %offset, i64 %vl) {
2649 ; CHECK-LABEL: test_vssseg8_nxv2i16:
2650 ; CHECK:       # %bb.0: # %entry
2651 ; CHECK-NEXT:    vmv1r.v v9, v8
2652 ; CHECK-NEXT:    vmv1r.v v10, v8
2653 ; CHECK-NEXT:    vmv1r.v v11, v8
2654 ; CHECK-NEXT:    vmv1r.v v12, v8
2655 ; CHECK-NEXT:    vmv1r.v v13, v8
2656 ; CHECK-NEXT:    vmv1r.v v14, v8
2657 ; CHECK-NEXT:    vmv1r.v v15, v8
2658 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
2659 ; CHECK-NEXT:    vssseg8e16.v v8, (a0), a1
2660 ; CHECK-NEXT:    ret
2661 entry:
2662   tail call void @llvm.riscv.vssseg8.nxv2i16(<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val, ptr %base, i64 %offset, i64 %vl)
2663   ret void
2666 define void @test_vssseg8_mask_nxv2i16(<vscale x 2 x i16> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
2667 ; CHECK-LABEL: test_vssseg8_mask_nxv2i16:
2668 ; CHECK:       # %bb.0: # %entry
2669 ; CHECK-NEXT:    vmv1r.v v9, v8
2670 ; CHECK-NEXT:    vmv1r.v v10, v8
2671 ; CHECK-NEXT:    vmv1r.v v11, v8
2672 ; CHECK-NEXT:    vmv1r.v v12, v8
2673 ; CHECK-NEXT:    vmv1r.v v13, v8
2674 ; CHECK-NEXT:    vmv1r.v v14, v8
2675 ; CHECK-NEXT:    vmv1r.v v15, v8
2676 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
2677 ; CHECK-NEXT:    vssseg8e16.v v8, (a0), a1, v0.t
2678 ; CHECK-NEXT:    ret
2679 entry:
2680   tail call void @llvm.riscv.vssseg8.mask.nxv2i16(<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val,<vscale x 2 x i16> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
2681   ret void
2684 declare void @llvm.riscv.vssseg2.nxv2i64(<vscale x 2 x i64>,<vscale x 2 x i64>, ptr, i64, i64)
2685 declare void @llvm.riscv.vssseg2.mask.nxv2i64(<vscale x 2 x i64>,<vscale x 2 x i64>, ptr, i64, <vscale x 2 x i1>, i64)
2687 define void @test_vssseg2_nxv2i64(<vscale x 2 x i64> %val, ptr %base, i64 %offset, i64 %vl) {
2688 ; CHECK-LABEL: test_vssseg2_nxv2i64:
2689 ; CHECK:       # %bb.0: # %entry
2690 ; CHECK-NEXT:    vmv2r.v v10, v8
2691 ; CHECK-NEXT:    vsetvli zero, a2, e64, m2, ta, ma
2692 ; CHECK-NEXT:    vssseg2e64.v v8, (a0), a1
2693 ; CHECK-NEXT:    ret
2694 entry:
2695   tail call void @llvm.riscv.vssseg2.nxv2i64(<vscale x 2 x i64> %val,<vscale x 2 x i64> %val, ptr %base, i64 %offset, i64 %vl)
2696   ret void
2699 define void @test_vssseg2_mask_nxv2i64(<vscale x 2 x i64> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
2700 ; CHECK-LABEL: test_vssseg2_mask_nxv2i64:
2701 ; CHECK:       # %bb.0: # %entry
2702 ; CHECK-NEXT:    vmv2r.v v10, v8
2703 ; CHECK-NEXT:    vsetvli zero, a2, e64, m2, ta, ma
2704 ; CHECK-NEXT:    vssseg2e64.v v8, (a0), a1, v0.t
2705 ; CHECK-NEXT:    ret
2706 entry:
2707   tail call void @llvm.riscv.vssseg2.mask.nxv2i64(<vscale x 2 x i64> %val,<vscale x 2 x i64> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
2708   ret void
2711 declare void @llvm.riscv.vssseg3.nxv2i64(<vscale x 2 x i64>,<vscale x 2 x i64>,<vscale x 2 x i64>, ptr, i64, i64)
2712 declare void @llvm.riscv.vssseg3.mask.nxv2i64(<vscale x 2 x i64>,<vscale x 2 x i64>,<vscale x 2 x i64>, ptr, i64, <vscale x 2 x i1>, i64)
2714 define void @test_vssseg3_nxv2i64(<vscale x 2 x i64> %val, ptr %base, i64 %offset, i64 %vl) {
2715 ; CHECK-LABEL: test_vssseg3_nxv2i64:
2716 ; CHECK:       # %bb.0: # %entry
2717 ; CHECK-NEXT:    vmv2r.v v10, v8
2718 ; CHECK-NEXT:    vmv2r.v v12, v8
2719 ; CHECK-NEXT:    vsetvli zero, a2, e64, m2, ta, ma
2720 ; CHECK-NEXT:    vssseg3e64.v v8, (a0), a1
2721 ; CHECK-NEXT:    ret
2722 entry:
2723   tail call void @llvm.riscv.vssseg3.nxv2i64(<vscale x 2 x i64> %val,<vscale x 2 x i64> %val,<vscale x 2 x i64> %val, ptr %base, i64 %offset, i64 %vl)
2724   ret void
2727 define void @test_vssseg3_mask_nxv2i64(<vscale x 2 x i64> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
2728 ; CHECK-LABEL: test_vssseg3_mask_nxv2i64:
2729 ; CHECK:       # %bb.0: # %entry
2730 ; CHECK-NEXT:    vmv2r.v v10, v8
2731 ; CHECK-NEXT:    vmv2r.v v12, v8
2732 ; CHECK-NEXT:    vsetvli zero, a2, e64, m2, ta, ma
2733 ; CHECK-NEXT:    vssseg3e64.v v8, (a0), a1, v0.t
2734 ; CHECK-NEXT:    ret
2735 entry:
2736   tail call void @llvm.riscv.vssseg3.mask.nxv2i64(<vscale x 2 x i64> %val,<vscale x 2 x i64> %val,<vscale x 2 x i64> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
2737   ret void
2740 declare void @llvm.riscv.vssseg4.nxv2i64(<vscale x 2 x i64>,<vscale x 2 x i64>,<vscale x 2 x i64>,<vscale x 2 x i64>, ptr, i64, i64)
2741 declare void @llvm.riscv.vssseg4.mask.nxv2i64(<vscale x 2 x i64>,<vscale x 2 x i64>,<vscale x 2 x i64>,<vscale x 2 x i64>, ptr, i64, <vscale x 2 x i1>, i64)
2743 define void @test_vssseg4_nxv2i64(<vscale x 2 x i64> %val, ptr %base, i64 %offset, i64 %vl) {
2744 ; CHECK-LABEL: test_vssseg4_nxv2i64:
2745 ; CHECK:       # %bb.0: # %entry
2746 ; CHECK-NEXT:    vmv2r.v v10, v8
2747 ; CHECK-NEXT:    vmv2r.v v12, v8
2748 ; CHECK-NEXT:    vmv2r.v v14, v8
2749 ; CHECK-NEXT:    vsetvli zero, a2, e64, m2, ta, ma
2750 ; CHECK-NEXT:    vssseg4e64.v v8, (a0), a1
2751 ; CHECK-NEXT:    ret
2752 entry:
2753   tail call void @llvm.riscv.vssseg4.nxv2i64(<vscale x 2 x i64> %val,<vscale x 2 x i64> %val,<vscale x 2 x i64> %val,<vscale x 2 x i64> %val, ptr %base, i64 %offset, i64 %vl)
2754   ret void
2757 define void @test_vssseg4_mask_nxv2i64(<vscale x 2 x i64> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
2758 ; CHECK-LABEL: test_vssseg4_mask_nxv2i64:
2759 ; CHECK:       # %bb.0: # %entry
2760 ; CHECK-NEXT:    vmv2r.v v10, v8
2761 ; CHECK-NEXT:    vmv2r.v v12, v8
2762 ; CHECK-NEXT:    vmv2r.v v14, v8
2763 ; CHECK-NEXT:    vsetvli zero, a2, e64, m2, ta, ma
2764 ; CHECK-NEXT:    vssseg4e64.v v8, (a0), a1, v0.t
2765 ; CHECK-NEXT:    ret
2766 entry:
2767   tail call void @llvm.riscv.vssseg4.mask.nxv2i64(<vscale x 2 x i64> %val,<vscale x 2 x i64> %val,<vscale x 2 x i64> %val,<vscale x 2 x i64> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
2768   ret void
2771 declare void @llvm.riscv.vssseg2.nxv16f16(<vscale x 16 x half>,<vscale x 16 x half>, ptr, i64, i64)
2772 declare void @llvm.riscv.vssseg2.mask.nxv16f16(<vscale x 16 x half>,<vscale x 16 x half>, ptr, i64, <vscale x 16 x i1>, i64)
2774 define void @test_vssseg2_nxv16f16(<vscale x 16 x half> %val, ptr %base, i64 %offset, i64 %vl) {
2775 ; CHECK-LABEL: test_vssseg2_nxv16f16:
2776 ; CHECK:       # %bb.0: # %entry
2777 ; CHECK-NEXT:    vmv4r.v v12, v8
2778 ; CHECK-NEXT:    vsetvli zero, a2, e16, m4, ta, ma
2779 ; CHECK-NEXT:    vssseg2e16.v v8, (a0), a1
2780 ; CHECK-NEXT:    ret
2781 entry:
2782   tail call void @llvm.riscv.vssseg2.nxv16f16(<vscale x 16 x half> %val,<vscale x 16 x half> %val, ptr %base, i64 %offset, i64 %vl)
2783   ret void
2786 define void @test_vssseg2_mask_nxv16f16(<vscale x 16 x half> %val, ptr %base, i64 %offset, <vscale x 16 x i1> %mask, i64 %vl) {
2787 ; CHECK-LABEL: test_vssseg2_mask_nxv16f16:
2788 ; CHECK:       # %bb.0: # %entry
2789 ; CHECK-NEXT:    vmv4r.v v12, v8
2790 ; CHECK-NEXT:    vsetvli zero, a2, e16, m4, ta, ma
2791 ; CHECK-NEXT:    vssseg2e16.v v8, (a0), a1, v0.t
2792 ; CHECK-NEXT:    ret
2793 entry:
2794   tail call void @llvm.riscv.vssseg2.mask.nxv16f16(<vscale x 16 x half> %val,<vscale x 16 x half> %val, ptr %base, i64 %offset, <vscale x 16 x i1> %mask, i64 %vl)
2795   ret void
2798 declare void @llvm.riscv.vssseg2.nxv4f64(<vscale x 4 x double>,<vscale x 4 x double>, ptr, i64, i64)
2799 declare void @llvm.riscv.vssseg2.mask.nxv4f64(<vscale x 4 x double>,<vscale x 4 x double>, ptr, i64, <vscale x 4 x i1>, i64)
2801 define void @test_vssseg2_nxv4f64(<vscale x 4 x double> %val, ptr %base, i64 %offset, i64 %vl) {
2802 ; CHECK-LABEL: test_vssseg2_nxv4f64:
2803 ; CHECK:       # %bb.0: # %entry
2804 ; CHECK-NEXT:    vmv4r.v v12, v8
2805 ; CHECK-NEXT:    vsetvli zero, a2, e64, m4, ta, ma
2806 ; CHECK-NEXT:    vssseg2e64.v v8, (a0), a1
2807 ; CHECK-NEXT:    ret
2808 entry:
2809   tail call void @llvm.riscv.vssseg2.nxv4f64(<vscale x 4 x double> %val,<vscale x 4 x double> %val, ptr %base, i64 %offset, i64 %vl)
2810   ret void
2813 define void @test_vssseg2_mask_nxv4f64(<vscale x 4 x double> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
2814 ; CHECK-LABEL: test_vssseg2_mask_nxv4f64:
2815 ; CHECK:       # %bb.0: # %entry
2816 ; CHECK-NEXT:    vmv4r.v v12, v8
2817 ; CHECK-NEXT:    vsetvli zero, a2, e64, m4, ta, ma
2818 ; CHECK-NEXT:    vssseg2e64.v v8, (a0), a1, v0.t
2819 ; CHECK-NEXT:    ret
2820 entry:
2821   tail call void @llvm.riscv.vssseg2.mask.nxv4f64(<vscale x 4 x double> %val,<vscale x 4 x double> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
2822   ret void
2825 declare void @llvm.riscv.vssseg2.nxv1f64(<vscale x 1 x double>,<vscale x 1 x double>, ptr, i64, i64)
2826 declare void @llvm.riscv.vssseg2.mask.nxv1f64(<vscale x 1 x double>,<vscale x 1 x double>, ptr, i64, <vscale x 1 x i1>, i64)
2828 define void @test_vssseg2_nxv1f64(<vscale x 1 x double> %val, ptr %base, i64 %offset, i64 %vl) {
2829 ; CHECK-LABEL: test_vssseg2_nxv1f64:
2830 ; CHECK:       # %bb.0: # %entry
2831 ; CHECK-NEXT:    vmv1r.v v9, v8
2832 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
2833 ; CHECK-NEXT:    vssseg2e64.v v8, (a0), a1
2834 ; CHECK-NEXT:    ret
2835 entry:
2836   tail call void @llvm.riscv.vssseg2.nxv1f64(<vscale x 1 x double> %val,<vscale x 1 x double> %val, ptr %base, i64 %offset, i64 %vl)
2837   ret void
2840 define void @test_vssseg2_mask_nxv1f64(<vscale x 1 x double> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
2841 ; CHECK-LABEL: test_vssseg2_mask_nxv1f64:
2842 ; CHECK:       # %bb.0: # %entry
2843 ; CHECK-NEXT:    vmv1r.v v9, v8
2844 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
2845 ; CHECK-NEXT:    vssseg2e64.v v8, (a0), a1, v0.t
2846 ; CHECK-NEXT:    ret
2847 entry:
2848   tail call void @llvm.riscv.vssseg2.mask.nxv1f64(<vscale x 1 x double> %val,<vscale x 1 x double> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
2849   ret void
2852 declare void @llvm.riscv.vssseg3.nxv1f64(<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>, ptr, i64, i64)
2853 declare void @llvm.riscv.vssseg3.mask.nxv1f64(<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>, ptr, i64, <vscale x 1 x i1>, i64)
2855 define void @test_vssseg3_nxv1f64(<vscale x 1 x double> %val, ptr %base, i64 %offset, i64 %vl) {
2856 ; CHECK-LABEL: test_vssseg3_nxv1f64:
2857 ; CHECK:       # %bb.0: # %entry
2858 ; CHECK-NEXT:    vmv1r.v v9, v8
2859 ; CHECK-NEXT:    vmv1r.v v10, v8
2860 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
2861 ; CHECK-NEXT:    vssseg3e64.v v8, (a0), a1
2862 ; CHECK-NEXT:    ret
2863 entry:
2864   tail call void @llvm.riscv.vssseg3.nxv1f64(<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val, ptr %base, i64 %offset, i64 %vl)
2865   ret void
2868 define void @test_vssseg3_mask_nxv1f64(<vscale x 1 x double> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
2869 ; CHECK-LABEL: test_vssseg3_mask_nxv1f64:
2870 ; CHECK:       # %bb.0: # %entry
2871 ; CHECK-NEXT:    vmv1r.v v9, v8
2872 ; CHECK-NEXT:    vmv1r.v v10, v8
2873 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
2874 ; CHECK-NEXT:    vssseg3e64.v v8, (a0), a1, v0.t
2875 ; CHECK-NEXT:    ret
2876 entry:
2877   tail call void @llvm.riscv.vssseg3.mask.nxv1f64(<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
2878   ret void
2881 declare void @llvm.riscv.vssseg4.nxv1f64(<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>, ptr, i64, i64)
2882 declare void @llvm.riscv.vssseg4.mask.nxv1f64(<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>, ptr, i64, <vscale x 1 x i1>, i64)
2884 define void @test_vssseg4_nxv1f64(<vscale x 1 x double> %val, ptr %base, i64 %offset, i64 %vl) {
2885 ; CHECK-LABEL: test_vssseg4_nxv1f64:
2886 ; CHECK:       # %bb.0: # %entry
2887 ; CHECK-NEXT:    vmv1r.v v9, v8
2888 ; CHECK-NEXT:    vmv1r.v v10, v8
2889 ; CHECK-NEXT:    vmv1r.v v11, v8
2890 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
2891 ; CHECK-NEXT:    vssseg4e64.v v8, (a0), a1
2892 ; CHECK-NEXT:    ret
2893 entry:
2894   tail call void @llvm.riscv.vssseg4.nxv1f64(<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val, ptr %base, i64 %offset, i64 %vl)
2895   ret void
2898 define void @test_vssseg4_mask_nxv1f64(<vscale x 1 x double> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
2899 ; CHECK-LABEL: test_vssseg4_mask_nxv1f64:
2900 ; CHECK:       # %bb.0: # %entry
2901 ; CHECK-NEXT:    vmv1r.v v9, v8
2902 ; CHECK-NEXT:    vmv1r.v v10, v8
2903 ; CHECK-NEXT:    vmv1r.v v11, v8
2904 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
2905 ; CHECK-NEXT:    vssseg4e64.v v8, (a0), a1, v0.t
2906 ; CHECK-NEXT:    ret
2907 entry:
2908   tail call void @llvm.riscv.vssseg4.mask.nxv1f64(<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
2909   ret void
2912 declare void @llvm.riscv.vssseg5.nxv1f64(<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>, ptr, i64, i64)
2913 declare void @llvm.riscv.vssseg5.mask.nxv1f64(<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>, ptr, i64, <vscale x 1 x i1>, i64)
2915 define void @test_vssseg5_nxv1f64(<vscale x 1 x double> %val, ptr %base, i64 %offset, i64 %vl) {
2916 ; CHECK-LABEL: test_vssseg5_nxv1f64:
2917 ; CHECK:       # %bb.0: # %entry
2918 ; CHECK-NEXT:    vmv1r.v v9, v8
2919 ; CHECK-NEXT:    vmv1r.v v10, v8
2920 ; CHECK-NEXT:    vmv1r.v v11, v8
2921 ; CHECK-NEXT:    vmv1r.v v12, v8
2922 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
2923 ; CHECK-NEXT:    vssseg5e64.v v8, (a0), a1
2924 ; CHECK-NEXT:    ret
2925 entry:
2926   tail call void @llvm.riscv.vssseg5.nxv1f64(<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val, ptr %base, i64 %offset, i64 %vl)
2927   ret void
2930 define void @test_vssseg5_mask_nxv1f64(<vscale x 1 x double> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
2931 ; CHECK-LABEL: test_vssseg5_mask_nxv1f64:
2932 ; CHECK:       # %bb.0: # %entry
2933 ; CHECK-NEXT:    vmv1r.v v9, v8
2934 ; CHECK-NEXT:    vmv1r.v v10, v8
2935 ; CHECK-NEXT:    vmv1r.v v11, v8
2936 ; CHECK-NEXT:    vmv1r.v v12, v8
2937 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
2938 ; CHECK-NEXT:    vssseg5e64.v v8, (a0), a1, v0.t
2939 ; CHECK-NEXT:    ret
2940 entry:
2941   tail call void @llvm.riscv.vssseg5.mask.nxv1f64(<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
2942   ret void
2945 declare void @llvm.riscv.vssseg6.nxv1f64(<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>, ptr, i64, i64)
2946 declare void @llvm.riscv.vssseg6.mask.nxv1f64(<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>, ptr, i64, <vscale x 1 x i1>, i64)
2948 define void @test_vssseg6_nxv1f64(<vscale x 1 x double> %val, ptr %base, i64 %offset, i64 %vl) {
2949 ; CHECK-LABEL: test_vssseg6_nxv1f64:
2950 ; CHECK:       # %bb.0: # %entry
2951 ; CHECK-NEXT:    vmv1r.v v9, v8
2952 ; CHECK-NEXT:    vmv1r.v v10, v8
2953 ; CHECK-NEXT:    vmv1r.v v11, v8
2954 ; CHECK-NEXT:    vmv1r.v v12, v8
2955 ; CHECK-NEXT:    vmv1r.v v13, v8
2956 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
2957 ; CHECK-NEXT:    vssseg6e64.v v8, (a0), a1
2958 ; CHECK-NEXT:    ret
2959 entry:
2960   tail call void @llvm.riscv.vssseg6.nxv1f64(<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val, ptr %base, i64 %offset, i64 %vl)
2961   ret void
2964 define void @test_vssseg6_mask_nxv1f64(<vscale x 1 x double> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
2965 ; CHECK-LABEL: test_vssseg6_mask_nxv1f64:
2966 ; CHECK:       # %bb.0: # %entry
2967 ; CHECK-NEXT:    vmv1r.v v9, v8
2968 ; CHECK-NEXT:    vmv1r.v v10, v8
2969 ; CHECK-NEXT:    vmv1r.v v11, v8
2970 ; CHECK-NEXT:    vmv1r.v v12, v8
2971 ; CHECK-NEXT:    vmv1r.v v13, v8
2972 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
2973 ; CHECK-NEXT:    vssseg6e64.v v8, (a0), a1, v0.t
2974 ; CHECK-NEXT:    ret
2975 entry:
2976   tail call void @llvm.riscv.vssseg6.mask.nxv1f64(<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
2977   ret void
2980 declare void @llvm.riscv.vssseg7.nxv1f64(<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>, ptr, i64, i64)
2981 declare void @llvm.riscv.vssseg7.mask.nxv1f64(<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>, ptr, i64, <vscale x 1 x i1>, i64)
2983 define void @test_vssseg7_nxv1f64(<vscale x 1 x double> %val, ptr %base, i64 %offset, i64 %vl) {
2984 ; CHECK-LABEL: test_vssseg7_nxv1f64:
2985 ; CHECK:       # %bb.0: # %entry
2986 ; CHECK-NEXT:    vmv1r.v v9, v8
2987 ; CHECK-NEXT:    vmv1r.v v10, v8
2988 ; CHECK-NEXT:    vmv1r.v v11, v8
2989 ; CHECK-NEXT:    vmv1r.v v12, v8
2990 ; CHECK-NEXT:    vmv1r.v v13, v8
2991 ; CHECK-NEXT:    vmv1r.v v14, v8
2992 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
2993 ; CHECK-NEXT:    vssseg7e64.v v8, (a0), a1
2994 ; CHECK-NEXT:    ret
2995 entry:
2996   tail call void @llvm.riscv.vssseg7.nxv1f64(<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val, ptr %base, i64 %offset, i64 %vl)
2997   ret void
3000 define void @test_vssseg7_mask_nxv1f64(<vscale x 1 x double> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
3001 ; CHECK-LABEL: test_vssseg7_mask_nxv1f64:
3002 ; CHECK:       # %bb.0: # %entry
3003 ; CHECK-NEXT:    vmv1r.v v9, v8
3004 ; CHECK-NEXT:    vmv1r.v v10, v8
3005 ; CHECK-NEXT:    vmv1r.v v11, v8
3006 ; CHECK-NEXT:    vmv1r.v v12, v8
3007 ; CHECK-NEXT:    vmv1r.v v13, v8
3008 ; CHECK-NEXT:    vmv1r.v v14, v8
3009 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
3010 ; CHECK-NEXT:    vssseg7e64.v v8, (a0), a1, v0.t
3011 ; CHECK-NEXT:    ret
3012 entry:
3013   tail call void @llvm.riscv.vssseg7.mask.nxv1f64(<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
3014   ret void
3017 declare void @llvm.riscv.vssseg8.nxv1f64(<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>, ptr, i64, i64)
3018 declare void @llvm.riscv.vssseg8.mask.nxv1f64(<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>,<vscale x 1 x double>, ptr, i64, <vscale x 1 x i1>, i64)
3020 define void @test_vssseg8_nxv1f64(<vscale x 1 x double> %val, ptr %base, i64 %offset, i64 %vl) {
3021 ; CHECK-LABEL: test_vssseg8_nxv1f64:
3022 ; CHECK:       # %bb.0: # %entry
3023 ; CHECK-NEXT:    vmv1r.v v9, v8
3024 ; CHECK-NEXT:    vmv1r.v v10, v8
3025 ; CHECK-NEXT:    vmv1r.v v11, v8
3026 ; CHECK-NEXT:    vmv1r.v v12, v8
3027 ; CHECK-NEXT:    vmv1r.v v13, v8
3028 ; CHECK-NEXT:    vmv1r.v v14, v8
3029 ; CHECK-NEXT:    vmv1r.v v15, v8
3030 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
3031 ; CHECK-NEXT:    vssseg8e64.v v8, (a0), a1
3032 ; CHECK-NEXT:    ret
3033 entry:
3034   tail call void @llvm.riscv.vssseg8.nxv1f64(<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val, ptr %base, i64 %offset, i64 %vl)
3035   ret void
3038 define void @test_vssseg8_mask_nxv1f64(<vscale x 1 x double> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
3039 ; CHECK-LABEL: test_vssseg8_mask_nxv1f64:
3040 ; CHECK:       # %bb.0: # %entry
3041 ; CHECK-NEXT:    vmv1r.v v9, v8
3042 ; CHECK-NEXT:    vmv1r.v v10, v8
3043 ; CHECK-NEXT:    vmv1r.v v11, v8
3044 ; CHECK-NEXT:    vmv1r.v v12, v8
3045 ; CHECK-NEXT:    vmv1r.v v13, v8
3046 ; CHECK-NEXT:    vmv1r.v v14, v8
3047 ; CHECK-NEXT:    vmv1r.v v15, v8
3048 ; CHECK-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
3049 ; CHECK-NEXT:    vssseg8e64.v v8, (a0), a1, v0.t
3050 ; CHECK-NEXT:    ret
3051 entry:
3052   tail call void @llvm.riscv.vssseg8.mask.nxv1f64(<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val,<vscale x 1 x double> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
3053   ret void
3056 declare void @llvm.riscv.vssseg2.nxv2f32(<vscale x 2 x float>,<vscale x 2 x float>, ptr, i64, i64)
3057 declare void @llvm.riscv.vssseg2.mask.nxv2f32(<vscale x 2 x float>,<vscale x 2 x float>, ptr, i64, <vscale x 2 x i1>, i64)
3059 define void @test_vssseg2_nxv2f32(<vscale x 2 x float> %val, ptr %base, i64 %offset, i64 %vl) {
3060 ; CHECK-LABEL: test_vssseg2_nxv2f32:
3061 ; CHECK:       # %bb.0: # %entry
3062 ; CHECK-NEXT:    vmv1r.v v9, v8
3063 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
3064 ; CHECK-NEXT:    vssseg2e32.v v8, (a0), a1
3065 ; CHECK-NEXT:    ret
3066 entry:
3067   tail call void @llvm.riscv.vssseg2.nxv2f32(<vscale x 2 x float> %val,<vscale x 2 x float> %val, ptr %base, i64 %offset, i64 %vl)
3068   ret void
3071 define void @test_vssseg2_mask_nxv2f32(<vscale x 2 x float> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
3072 ; CHECK-LABEL: test_vssseg2_mask_nxv2f32:
3073 ; CHECK:       # %bb.0: # %entry
3074 ; CHECK-NEXT:    vmv1r.v v9, v8
3075 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
3076 ; CHECK-NEXT:    vssseg2e32.v v8, (a0), a1, v0.t
3077 ; CHECK-NEXT:    ret
3078 entry:
3079   tail call void @llvm.riscv.vssseg2.mask.nxv2f32(<vscale x 2 x float> %val,<vscale x 2 x float> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
3080   ret void
3083 declare void @llvm.riscv.vssseg3.nxv2f32(<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>, ptr, i64, i64)
3084 declare void @llvm.riscv.vssseg3.mask.nxv2f32(<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>, ptr, i64, <vscale x 2 x i1>, i64)
3086 define void @test_vssseg3_nxv2f32(<vscale x 2 x float> %val, ptr %base, i64 %offset, i64 %vl) {
3087 ; CHECK-LABEL: test_vssseg3_nxv2f32:
3088 ; CHECK:       # %bb.0: # %entry
3089 ; CHECK-NEXT:    vmv1r.v v9, v8
3090 ; CHECK-NEXT:    vmv1r.v v10, v8
3091 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
3092 ; CHECK-NEXT:    vssseg3e32.v v8, (a0), a1
3093 ; CHECK-NEXT:    ret
3094 entry:
3095   tail call void @llvm.riscv.vssseg3.nxv2f32(<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val, ptr %base, i64 %offset, i64 %vl)
3096   ret void
3099 define void @test_vssseg3_mask_nxv2f32(<vscale x 2 x float> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
3100 ; CHECK-LABEL: test_vssseg3_mask_nxv2f32:
3101 ; CHECK:       # %bb.0: # %entry
3102 ; CHECK-NEXT:    vmv1r.v v9, v8
3103 ; CHECK-NEXT:    vmv1r.v v10, v8
3104 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
3105 ; CHECK-NEXT:    vssseg3e32.v v8, (a0), a1, v0.t
3106 ; CHECK-NEXT:    ret
3107 entry:
3108   tail call void @llvm.riscv.vssseg3.mask.nxv2f32(<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
3109   ret void
3112 declare void @llvm.riscv.vssseg4.nxv2f32(<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>, ptr, i64, i64)
3113 declare void @llvm.riscv.vssseg4.mask.nxv2f32(<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>, ptr, i64, <vscale x 2 x i1>, i64)
3115 define void @test_vssseg4_nxv2f32(<vscale x 2 x float> %val, ptr %base, i64 %offset, i64 %vl) {
3116 ; CHECK-LABEL: test_vssseg4_nxv2f32:
3117 ; CHECK:       # %bb.0: # %entry
3118 ; CHECK-NEXT:    vmv1r.v v9, v8
3119 ; CHECK-NEXT:    vmv1r.v v10, v8
3120 ; CHECK-NEXT:    vmv1r.v v11, v8
3121 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
3122 ; CHECK-NEXT:    vssseg4e32.v v8, (a0), a1
3123 ; CHECK-NEXT:    ret
3124 entry:
3125   tail call void @llvm.riscv.vssseg4.nxv2f32(<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val, ptr %base, i64 %offset, i64 %vl)
3126   ret void
3129 define void @test_vssseg4_mask_nxv2f32(<vscale x 2 x float> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
3130 ; CHECK-LABEL: test_vssseg4_mask_nxv2f32:
3131 ; CHECK:       # %bb.0: # %entry
3132 ; CHECK-NEXT:    vmv1r.v v9, v8
3133 ; CHECK-NEXT:    vmv1r.v v10, v8
3134 ; CHECK-NEXT:    vmv1r.v v11, v8
3135 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
3136 ; CHECK-NEXT:    vssseg4e32.v v8, (a0), a1, v0.t
3137 ; CHECK-NEXT:    ret
3138 entry:
3139   tail call void @llvm.riscv.vssseg4.mask.nxv2f32(<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
3140   ret void
3143 declare void @llvm.riscv.vssseg5.nxv2f32(<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>, ptr, i64, i64)
3144 declare void @llvm.riscv.vssseg5.mask.nxv2f32(<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>, ptr, i64, <vscale x 2 x i1>, i64)
3146 define void @test_vssseg5_nxv2f32(<vscale x 2 x float> %val, ptr %base, i64 %offset, i64 %vl) {
3147 ; CHECK-LABEL: test_vssseg5_nxv2f32:
3148 ; CHECK:       # %bb.0: # %entry
3149 ; CHECK-NEXT:    vmv1r.v v9, v8
3150 ; CHECK-NEXT:    vmv1r.v v10, v8
3151 ; CHECK-NEXT:    vmv1r.v v11, v8
3152 ; CHECK-NEXT:    vmv1r.v v12, v8
3153 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
3154 ; CHECK-NEXT:    vssseg5e32.v v8, (a0), a1
3155 ; CHECK-NEXT:    ret
3156 entry:
3157   tail call void @llvm.riscv.vssseg5.nxv2f32(<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val, ptr %base, i64 %offset, i64 %vl)
3158   ret void
3161 define void @test_vssseg5_mask_nxv2f32(<vscale x 2 x float> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
3162 ; CHECK-LABEL: test_vssseg5_mask_nxv2f32:
3163 ; CHECK:       # %bb.0: # %entry
3164 ; CHECK-NEXT:    vmv1r.v v9, v8
3165 ; CHECK-NEXT:    vmv1r.v v10, v8
3166 ; CHECK-NEXT:    vmv1r.v v11, v8
3167 ; CHECK-NEXT:    vmv1r.v v12, v8
3168 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
3169 ; CHECK-NEXT:    vssseg5e32.v v8, (a0), a1, v0.t
3170 ; CHECK-NEXT:    ret
3171 entry:
3172   tail call void @llvm.riscv.vssseg5.mask.nxv2f32(<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
3173   ret void
3176 declare void @llvm.riscv.vssseg6.nxv2f32(<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>, ptr, i64, i64)
3177 declare void @llvm.riscv.vssseg6.mask.nxv2f32(<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>, ptr, i64, <vscale x 2 x i1>, i64)
3179 define void @test_vssseg6_nxv2f32(<vscale x 2 x float> %val, ptr %base, i64 %offset, i64 %vl) {
3180 ; CHECK-LABEL: test_vssseg6_nxv2f32:
3181 ; CHECK:       # %bb.0: # %entry
3182 ; CHECK-NEXT:    vmv1r.v v9, v8
3183 ; CHECK-NEXT:    vmv1r.v v10, v8
3184 ; CHECK-NEXT:    vmv1r.v v11, v8
3185 ; CHECK-NEXT:    vmv1r.v v12, v8
3186 ; CHECK-NEXT:    vmv1r.v v13, v8
3187 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
3188 ; CHECK-NEXT:    vssseg6e32.v v8, (a0), a1
3189 ; CHECK-NEXT:    ret
3190 entry:
3191   tail call void @llvm.riscv.vssseg6.nxv2f32(<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val, ptr %base, i64 %offset, i64 %vl)
3192   ret void
3195 define void @test_vssseg6_mask_nxv2f32(<vscale x 2 x float> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
3196 ; CHECK-LABEL: test_vssseg6_mask_nxv2f32:
3197 ; CHECK:       # %bb.0: # %entry
3198 ; CHECK-NEXT:    vmv1r.v v9, v8
3199 ; CHECK-NEXT:    vmv1r.v v10, v8
3200 ; CHECK-NEXT:    vmv1r.v v11, v8
3201 ; CHECK-NEXT:    vmv1r.v v12, v8
3202 ; CHECK-NEXT:    vmv1r.v v13, v8
3203 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
3204 ; CHECK-NEXT:    vssseg6e32.v v8, (a0), a1, v0.t
3205 ; CHECK-NEXT:    ret
3206 entry:
3207   tail call void @llvm.riscv.vssseg6.mask.nxv2f32(<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
3208   ret void
3211 declare void @llvm.riscv.vssseg7.nxv2f32(<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>, ptr, i64, i64)
3212 declare void @llvm.riscv.vssseg7.mask.nxv2f32(<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>, ptr, i64, <vscale x 2 x i1>, i64)
3214 define void @test_vssseg7_nxv2f32(<vscale x 2 x float> %val, ptr %base, i64 %offset, i64 %vl) {
3215 ; CHECK-LABEL: test_vssseg7_nxv2f32:
3216 ; CHECK:       # %bb.0: # %entry
3217 ; CHECK-NEXT:    vmv1r.v v9, v8
3218 ; CHECK-NEXT:    vmv1r.v v10, v8
3219 ; CHECK-NEXT:    vmv1r.v v11, v8
3220 ; CHECK-NEXT:    vmv1r.v v12, v8
3221 ; CHECK-NEXT:    vmv1r.v v13, v8
3222 ; CHECK-NEXT:    vmv1r.v v14, v8
3223 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
3224 ; CHECK-NEXT:    vssseg7e32.v v8, (a0), a1
3225 ; CHECK-NEXT:    ret
3226 entry:
3227   tail call void @llvm.riscv.vssseg7.nxv2f32(<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val, ptr %base, i64 %offset, i64 %vl)
3228   ret void
3231 define void @test_vssseg7_mask_nxv2f32(<vscale x 2 x float> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
3232 ; CHECK-LABEL: test_vssseg7_mask_nxv2f32:
3233 ; CHECK:       # %bb.0: # %entry
3234 ; CHECK-NEXT:    vmv1r.v v9, v8
3235 ; CHECK-NEXT:    vmv1r.v v10, v8
3236 ; CHECK-NEXT:    vmv1r.v v11, v8
3237 ; CHECK-NEXT:    vmv1r.v v12, v8
3238 ; CHECK-NEXT:    vmv1r.v v13, v8
3239 ; CHECK-NEXT:    vmv1r.v v14, v8
3240 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
3241 ; CHECK-NEXT:    vssseg7e32.v v8, (a0), a1, v0.t
3242 ; CHECK-NEXT:    ret
3243 entry:
3244   tail call void @llvm.riscv.vssseg7.mask.nxv2f32(<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
3245   ret void
3248 declare void @llvm.riscv.vssseg8.nxv2f32(<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>, ptr, i64, i64)
3249 declare void @llvm.riscv.vssseg8.mask.nxv2f32(<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>,<vscale x 2 x float>, ptr, i64, <vscale x 2 x i1>, i64)
3251 define void @test_vssseg8_nxv2f32(<vscale x 2 x float> %val, ptr %base, i64 %offset, i64 %vl) {
3252 ; CHECK-LABEL: test_vssseg8_nxv2f32:
3253 ; CHECK:       # %bb.0: # %entry
3254 ; CHECK-NEXT:    vmv1r.v v9, v8
3255 ; CHECK-NEXT:    vmv1r.v v10, v8
3256 ; CHECK-NEXT:    vmv1r.v v11, v8
3257 ; CHECK-NEXT:    vmv1r.v v12, v8
3258 ; CHECK-NEXT:    vmv1r.v v13, v8
3259 ; CHECK-NEXT:    vmv1r.v v14, v8
3260 ; CHECK-NEXT:    vmv1r.v v15, v8
3261 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
3262 ; CHECK-NEXT:    vssseg8e32.v v8, (a0), a1
3263 ; CHECK-NEXT:    ret
3264 entry:
3265   tail call void @llvm.riscv.vssseg8.nxv2f32(<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val, ptr %base, i64 %offset, i64 %vl)
3266   ret void
3269 define void @test_vssseg8_mask_nxv2f32(<vscale x 2 x float> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
3270 ; CHECK-LABEL: test_vssseg8_mask_nxv2f32:
3271 ; CHECK:       # %bb.0: # %entry
3272 ; CHECK-NEXT:    vmv1r.v v9, v8
3273 ; CHECK-NEXT:    vmv1r.v v10, v8
3274 ; CHECK-NEXT:    vmv1r.v v11, v8
3275 ; CHECK-NEXT:    vmv1r.v v12, v8
3276 ; CHECK-NEXT:    vmv1r.v v13, v8
3277 ; CHECK-NEXT:    vmv1r.v v14, v8
3278 ; CHECK-NEXT:    vmv1r.v v15, v8
3279 ; CHECK-NEXT:    vsetvli zero, a2, e32, m1, ta, ma
3280 ; CHECK-NEXT:    vssseg8e32.v v8, (a0), a1, v0.t
3281 ; CHECK-NEXT:    ret
3282 entry:
3283   tail call void @llvm.riscv.vssseg8.mask.nxv2f32(<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val,<vscale x 2 x float> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
3284   ret void
3287 declare void @llvm.riscv.vssseg2.nxv1f16(<vscale x 1 x half>,<vscale x 1 x half>, ptr, i64, i64)
3288 declare void @llvm.riscv.vssseg2.mask.nxv1f16(<vscale x 1 x half>,<vscale x 1 x half>, ptr, i64, <vscale x 1 x i1>, i64)
3290 define void @test_vssseg2_nxv1f16(<vscale x 1 x half> %val, ptr %base, i64 %offset, i64 %vl) {
3291 ; CHECK-LABEL: test_vssseg2_nxv1f16:
3292 ; CHECK:       # %bb.0: # %entry
3293 ; CHECK-NEXT:    vmv1r.v v9, v8
3294 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
3295 ; CHECK-NEXT:    vssseg2e16.v v8, (a0), a1
3296 ; CHECK-NEXT:    ret
3297 entry:
3298   tail call void @llvm.riscv.vssseg2.nxv1f16(<vscale x 1 x half> %val,<vscale x 1 x half> %val, ptr %base, i64 %offset, i64 %vl)
3299   ret void
3302 define void @test_vssseg2_mask_nxv1f16(<vscale x 1 x half> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
3303 ; CHECK-LABEL: test_vssseg2_mask_nxv1f16:
3304 ; CHECK:       # %bb.0: # %entry
3305 ; CHECK-NEXT:    vmv1r.v v9, v8
3306 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
3307 ; CHECK-NEXT:    vssseg2e16.v v8, (a0), a1, v0.t
3308 ; CHECK-NEXT:    ret
3309 entry:
3310   tail call void @llvm.riscv.vssseg2.mask.nxv1f16(<vscale x 1 x half> %val,<vscale x 1 x half> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
3311   ret void
3314 declare void @llvm.riscv.vssseg3.nxv1f16(<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>, ptr, i64, i64)
3315 declare void @llvm.riscv.vssseg3.mask.nxv1f16(<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>, ptr, i64, <vscale x 1 x i1>, i64)
3317 define void @test_vssseg3_nxv1f16(<vscale x 1 x half> %val, ptr %base, i64 %offset, i64 %vl) {
3318 ; CHECK-LABEL: test_vssseg3_nxv1f16:
3319 ; CHECK:       # %bb.0: # %entry
3320 ; CHECK-NEXT:    vmv1r.v v9, v8
3321 ; CHECK-NEXT:    vmv1r.v v10, v8
3322 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
3323 ; CHECK-NEXT:    vssseg3e16.v v8, (a0), a1
3324 ; CHECK-NEXT:    ret
3325 entry:
3326   tail call void @llvm.riscv.vssseg3.nxv1f16(<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val, ptr %base, i64 %offset, i64 %vl)
3327   ret void
3330 define void @test_vssseg3_mask_nxv1f16(<vscale x 1 x half> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
3331 ; CHECK-LABEL: test_vssseg3_mask_nxv1f16:
3332 ; CHECK:       # %bb.0: # %entry
3333 ; CHECK-NEXT:    vmv1r.v v9, v8
3334 ; CHECK-NEXT:    vmv1r.v v10, v8
3335 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
3336 ; CHECK-NEXT:    vssseg3e16.v v8, (a0), a1, v0.t
3337 ; CHECK-NEXT:    ret
3338 entry:
3339   tail call void @llvm.riscv.vssseg3.mask.nxv1f16(<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
3340   ret void
3343 declare void @llvm.riscv.vssseg4.nxv1f16(<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>, ptr, i64, i64)
3344 declare void @llvm.riscv.vssseg4.mask.nxv1f16(<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>, ptr, i64, <vscale x 1 x i1>, i64)
3346 define void @test_vssseg4_nxv1f16(<vscale x 1 x half> %val, ptr %base, i64 %offset, i64 %vl) {
3347 ; CHECK-LABEL: test_vssseg4_nxv1f16:
3348 ; CHECK:       # %bb.0: # %entry
3349 ; CHECK-NEXT:    vmv1r.v v9, v8
3350 ; CHECK-NEXT:    vmv1r.v v10, v8
3351 ; CHECK-NEXT:    vmv1r.v v11, v8
3352 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
3353 ; CHECK-NEXT:    vssseg4e16.v v8, (a0), a1
3354 ; CHECK-NEXT:    ret
3355 entry:
3356   tail call void @llvm.riscv.vssseg4.nxv1f16(<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val, ptr %base, i64 %offset, i64 %vl)
3357   ret void
3360 define void @test_vssseg4_mask_nxv1f16(<vscale x 1 x half> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
3361 ; CHECK-LABEL: test_vssseg4_mask_nxv1f16:
3362 ; CHECK:       # %bb.0: # %entry
3363 ; CHECK-NEXT:    vmv1r.v v9, v8
3364 ; CHECK-NEXT:    vmv1r.v v10, v8
3365 ; CHECK-NEXT:    vmv1r.v v11, v8
3366 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
3367 ; CHECK-NEXT:    vssseg4e16.v v8, (a0), a1, v0.t
3368 ; CHECK-NEXT:    ret
3369 entry:
3370   tail call void @llvm.riscv.vssseg4.mask.nxv1f16(<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
3371   ret void
3374 declare void @llvm.riscv.vssseg5.nxv1f16(<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>, ptr, i64, i64)
3375 declare void @llvm.riscv.vssseg5.mask.nxv1f16(<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>, ptr, i64, <vscale x 1 x i1>, i64)
3377 define void @test_vssseg5_nxv1f16(<vscale x 1 x half> %val, ptr %base, i64 %offset, i64 %vl) {
3378 ; CHECK-LABEL: test_vssseg5_nxv1f16:
3379 ; CHECK:       # %bb.0: # %entry
3380 ; CHECK-NEXT:    vmv1r.v v9, v8
3381 ; CHECK-NEXT:    vmv1r.v v10, v8
3382 ; CHECK-NEXT:    vmv1r.v v11, v8
3383 ; CHECK-NEXT:    vmv1r.v v12, v8
3384 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
3385 ; CHECK-NEXT:    vssseg5e16.v v8, (a0), a1
3386 ; CHECK-NEXT:    ret
3387 entry:
3388   tail call void @llvm.riscv.vssseg5.nxv1f16(<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val, ptr %base, i64 %offset, i64 %vl)
3389   ret void
3392 define void @test_vssseg5_mask_nxv1f16(<vscale x 1 x half> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
3393 ; CHECK-LABEL: test_vssseg5_mask_nxv1f16:
3394 ; CHECK:       # %bb.0: # %entry
3395 ; CHECK-NEXT:    vmv1r.v v9, v8
3396 ; CHECK-NEXT:    vmv1r.v v10, v8
3397 ; CHECK-NEXT:    vmv1r.v v11, v8
3398 ; CHECK-NEXT:    vmv1r.v v12, v8
3399 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
3400 ; CHECK-NEXT:    vssseg5e16.v v8, (a0), a1, v0.t
3401 ; CHECK-NEXT:    ret
3402 entry:
3403   tail call void @llvm.riscv.vssseg5.mask.nxv1f16(<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
3404   ret void
3407 declare void @llvm.riscv.vssseg6.nxv1f16(<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>, ptr, i64, i64)
3408 declare void @llvm.riscv.vssseg6.mask.nxv1f16(<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>, ptr, i64, <vscale x 1 x i1>, i64)
3410 define void @test_vssseg6_nxv1f16(<vscale x 1 x half> %val, ptr %base, i64 %offset, i64 %vl) {
3411 ; CHECK-LABEL: test_vssseg6_nxv1f16:
3412 ; CHECK:       # %bb.0: # %entry
3413 ; CHECK-NEXT:    vmv1r.v v9, v8
3414 ; CHECK-NEXT:    vmv1r.v v10, v8
3415 ; CHECK-NEXT:    vmv1r.v v11, v8
3416 ; CHECK-NEXT:    vmv1r.v v12, v8
3417 ; CHECK-NEXT:    vmv1r.v v13, v8
3418 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
3419 ; CHECK-NEXT:    vssseg6e16.v v8, (a0), a1
3420 ; CHECK-NEXT:    ret
3421 entry:
3422   tail call void @llvm.riscv.vssseg6.nxv1f16(<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val, ptr %base, i64 %offset, i64 %vl)
3423   ret void
3426 define void @test_vssseg6_mask_nxv1f16(<vscale x 1 x half> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
3427 ; CHECK-LABEL: test_vssseg6_mask_nxv1f16:
3428 ; CHECK:       # %bb.0: # %entry
3429 ; CHECK-NEXT:    vmv1r.v v9, v8
3430 ; CHECK-NEXT:    vmv1r.v v10, v8
3431 ; CHECK-NEXT:    vmv1r.v v11, v8
3432 ; CHECK-NEXT:    vmv1r.v v12, v8
3433 ; CHECK-NEXT:    vmv1r.v v13, v8
3434 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
3435 ; CHECK-NEXT:    vssseg6e16.v v8, (a0), a1, v0.t
3436 ; CHECK-NEXT:    ret
3437 entry:
3438   tail call void @llvm.riscv.vssseg6.mask.nxv1f16(<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
3439   ret void
3442 declare void @llvm.riscv.vssseg7.nxv1f16(<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>, ptr, i64, i64)
3443 declare void @llvm.riscv.vssseg7.mask.nxv1f16(<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>, ptr, i64, <vscale x 1 x i1>, i64)
3445 define void @test_vssseg7_nxv1f16(<vscale x 1 x half> %val, ptr %base, i64 %offset, i64 %vl) {
3446 ; CHECK-LABEL: test_vssseg7_nxv1f16:
3447 ; CHECK:       # %bb.0: # %entry
3448 ; CHECK-NEXT:    vmv1r.v v9, v8
3449 ; CHECK-NEXT:    vmv1r.v v10, v8
3450 ; CHECK-NEXT:    vmv1r.v v11, v8
3451 ; CHECK-NEXT:    vmv1r.v v12, v8
3452 ; CHECK-NEXT:    vmv1r.v v13, v8
3453 ; CHECK-NEXT:    vmv1r.v v14, v8
3454 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
3455 ; CHECK-NEXT:    vssseg7e16.v v8, (a0), a1
3456 ; CHECK-NEXT:    ret
3457 entry:
3458   tail call void @llvm.riscv.vssseg7.nxv1f16(<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val, ptr %base, i64 %offset, i64 %vl)
3459   ret void
3462 define void @test_vssseg7_mask_nxv1f16(<vscale x 1 x half> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
3463 ; CHECK-LABEL: test_vssseg7_mask_nxv1f16:
3464 ; CHECK:       # %bb.0: # %entry
3465 ; CHECK-NEXT:    vmv1r.v v9, v8
3466 ; CHECK-NEXT:    vmv1r.v v10, v8
3467 ; CHECK-NEXT:    vmv1r.v v11, v8
3468 ; CHECK-NEXT:    vmv1r.v v12, v8
3469 ; CHECK-NEXT:    vmv1r.v v13, v8
3470 ; CHECK-NEXT:    vmv1r.v v14, v8
3471 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
3472 ; CHECK-NEXT:    vssseg7e16.v v8, (a0), a1, v0.t
3473 ; CHECK-NEXT:    ret
3474 entry:
3475   tail call void @llvm.riscv.vssseg7.mask.nxv1f16(<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
3476   ret void
3479 declare void @llvm.riscv.vssseg8.nxv1f16(<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>, ptr, i64, i64)
3480 declare void @llvm.riscv.vssseg8.mask.nxv1f16(<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>,<vscale x 1 x half>, ptr, i64, <vscale x 1 x i1>, i64)
3482 define void @test_vssseg8_nxv1f16(<vscale x 1 x half> %val, ptr %base, i64 %offset, i64 %vl) {
3483 ; CHECK-LABEL: test_vssseg8_nxv1f16:
3484 ; CHECK:       # %bb.0: # %entry
3485 ; CHECK-NEXT:    vmv1r.v v9, v8
3486 ; CHECK-NEXT:    vmv1r.v v10, v8
3487 ; CHECK-NEXT:    vmv1r.v v11, v8
3488 ; CHECK-NEXT:    vmv1r.v v12, v8
3489 ; CHECK-NEXT:    vmv1r.v v13, v8
3490 ; CHECK-NEXT:    vmv1r.v v14, v8
3491 ; CHECK-NEXT:    vmv1r.v v15, v8
3492 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
3493 ; CHECK-NEXT:    vssseg8e16.v v8, (a0), a1
3494 ; CHECK-NEXT:    ret
3495 entry:
3496   tail call void @llvm.riscv.vssseg8.nxv1f16(<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val, ptr %base, i64 %offset, i64 %vl)
3497   ret void
3500 define void @test_vssseg8_mask_nxv1f16(<vscale x 1 x half> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
3501 ; CHECK-LABEL: test_vssseg8_mask_nxv1f16:
3502 ; CHECK:       # %bb.0: # %entry
3503 ; CHECK-NEXT:    vmv1r.v v9, v8
3504 ; CHECK-NEXT:    vmv1r.v v10, v8
3505 ; CHECK-NEXT:    vmv1r.v v11, v8
3506 ; CHECK-NEXT:    vmv1r.v v12, v8
3507 ; CHECK-NEXT:    vmv1r.v v13, v8
3508 ; CHECK-NEXT:    vmv1r.v v14, v8
3509 ; CHECK-NEXT:    vmv1r.v v15, v8
3510 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf4, ta, ma
3511 ; CHECK-NEXT:    vssseg8e16.v v8, (a0), a1, v0.t
3512 ; CHECK-NEXT:    ret
3513 entry:
3514   tail call void @llvm.riscv.vssseg8.mask.nxv1f16(<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val,<vscale x 1 x half> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
3515   ret void
3518 declare void @llvm.riscv.vssseg2.nxv1f32(<vscale x 1 x float>,<vscale x 1 x float>, ptr, i64, i64)
3519 declare void @llvm.riscv.vssseg2.mask.nxv1f32(<vscale x 1 x float>,<vscale x 1 x float>, ptr, i64, <vscale x 1 x i1>, i64)
3521 define void @test_vssseg2_nxv1f32(<vscale x 1 x float> %val, ptr %base, i64 %offset, i64 %vl) {
3522 ; CHECK-LABEL: test_vssseg2_nxv1f32:
3523 ; CHECK:       # %bb.0: # %entry
3524 ; CHECK-NEXT:    vmv1r.v v9, v8
3525 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
3526 ; CHECK-NEXT:    vssseg2e32.v v8, (a0), a1
3527 ; CHECK-NEXT:    ret
3528 entry:
3529   tail call void @llvm.riscv.vssseg2.nxv1f32(<vscale x 1 x float> %val,<vscale x 1 x float> %val, ptr %base, i64 %offset, i64 %vl)
3530   ret void
3533 define void @test_vssseg2_mask_nxv1f32(<vscale x 1 x float> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
3534 ; CHECK-LABEL: test_vssseg2_mask_nxv1f32:
3535 ; CHECK:       # %bb.0: # %entry
3536 ; CHECK-NEXT:    vmv1r.v v9, v8
3537 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
3538 ; CHECK-NEXT:    vssseg2e32.v v8, (a0), a1, v0.t
3539 ; CHECK-NEXT:    ret
3540 entry:
3541   tail call void @llvm.riscv.vssseg2.mask.nxv1f32(<vscale x 1 x float> %val,<vscale x 1 x float> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
3542   ret void
3545 declare void @llvm.riscv.vssseg3.nxv1f32(<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>, ptr, i64, i64)
3546 declare void @llvm.riscv.vssseg3.mask.nxv1f32(<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>, ptr, i64, <vscale x 1 x i1>, i64)
3548 define void @test_vssseg3_nxv1f32(<vscale x 1 x float> %val, ptr %base, i64 %offset, i64 %vl) {
3549 ; CHECK-LABEL: test_vssseg3_nxv1f32:
3550 ; CHECK:       # %bb.0: # %entry
3551 ; CHECK-NEXT:    vmv1r.v v9, v8
3552 ; CHECK-NEXT:    vmv1r.v v10, v8
3553 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
3554 ; CHECK-NEXT:    vssseg3e32.v v8, (a0), a1
3555 ; CHECK-NEXT:    ret
3556 entry:
3557   tail call void @llvm.riscv.vssseg3.nxv1f32(<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val, ptr %base, i64 %offset, i64 %vl)
3558   ret void
3561 define void @test_vssseg3_mask_nxv1f32(<vscale x 1 x float> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
3562 ; CHECK-LABEL: test_vssseg3_mask_nxv1f32:
3563 ; CHECK:       # %bb.0: # %entry
3564 ; CHECK-NEXT:    vmv1r.v v9, v8
3565 ; CHECK-NEXT:    vmv1r.v v10, v8
3566 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
3567 ; CHECK-NEXT:    vssseg3e32.v v8, (a0), a1, v0.t
3568 ; CHECK-NEXT:    ret
3569 entry:
3570   tail call void @llvm.riscv.vssseg3.mask.nxv1f32(<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
3571   ret void
3574 declare void @llvm.riscv.vssseg4.nxv1f32(<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>, ptr, i64, i64)
3575 declare void @llvm.riscv.vssseg4.mask.nxv1f32(<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>, ptr, i64, <vscale x 1 x i1>, i64)
3577 define void @test_vssseg4_nxv1f32(<vscale x 1 x float> %val, ptr %base, i64 %offset, i64 %vl) {
3578 ; CHECK-LABEL: test_vssseg4_nxv1f32:
3579 ; CHECK:       # %bb.0: # %entry
3580 ; CHECK-NEXT:    vmv1r.v v9, v8
3581 ; CHECK-NEXT:    vmv1r.v v10, v8
3582 ; CHECK-NEXT:    vmv1r.v v11, v8
3583 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
3584 ; CHECK-NEXT:    vssseg4e32.v v8, (a0), a1
3585 ; CHECK-NEXT:    ret
3586 entry:
3587   tail call void @llvm.riscv.vssseg4.nxv1f32(<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val, ptr %base, i64 %offset, i64 %vl)
3588   ret void
3591 define void @test_vssseg4_mask_nxv1f32(<vscale x 1 x float> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
3592 ; CHECK-LABEL: test_vssseg4_mask_nxv1f32:
3593 ; CHECK:       # %bb.0: # %entry
3594 ; CHECK-NEXT:    vmv1r.v v9, v8
3595 ; CHECK-NEXT:    vmv1r.v v10, v8
3596 ; CHECK-NEXT:    vmv1r.v v11, v8
3597 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
3598 ; CHECK-NEXT:    vssseg4e32.v v8, (a0), a1, v0.t
3599 ; CHECK-NEXT:    ret
3600 entry:
3601   tail call void @llvm.riscv.vssseg4.mask.nxv1f32(<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
3602   ret void
3605 declare void @llvm.riscv.vssseg5.nxv1f32(<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>, ptr, i64, i64)
3606 declare void @llvm.riscv.vssseg5.mask.nxv1f32(<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>, ptr, i64, <vscale x 1 x i1>, i64)
3608 define void @test_vssseg5_nxv1f32(<vscale x 1 x float> %val, ptr %base, i64 %offset, i64 %vl) {
3609 ; CHECK-LABEL: test_vssseg5_nxv1f32:
3610 ; CHECK:       # %bb.0: # %entry
3611 ; CHECK-NEXT:    vmv1r.v v9, v8
3612 ; CHECK-NEXT:    vmv1r.v v10, v8
3613 ; CHECK-NEXT:    vmv1r.v v11, v8
3614 ; CHECK-NEXT:    vmv1r.v v12, v8
3615 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
3616 ; CHECK-NEXT:    vssseg5e32.v v8, (a0), a1
3617 ; CHECK-NEXT:    ret
3618 entry:
3619   tail call void @llvm.riscv.vssseg5.nxv1f32(<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val, ptr %base, i64 %offset, i64 %vl)
3620   ret void
3623 define void @test_vssseg5_mask_nxv1f32(<vscale x 1 x float> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
3624 ; CHECK-LABEL: test_vssseg5_mask_nxv1f32:
3625 ; CHECK:       # %bb.0: # %entry
3626 ; CHECK-NEXT:    vmv1r.v v9, v8
3627 ; CHECK-NEXT:    vmv1r.v v10, v8
3628 ; CHECK-NEXT:    vmv1r.v v11, v8
3629 ; CHECK-NEXT:    vmv1r.v v12, v8
3630 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
3631 ; CHECK-NEXT:    vssseg5e32.v v8, (a0), a1, v0.t
3632 ; CHECK-NEXT:    ret
3633 entry:
3634   tail call void @llvm.riscv.vssseg5.mask.nxv1f32(<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
3635   ret void
3638 declare void @llvm.riscv.vssseg6.nxv1f32(<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>, ptr, i64, i64)
3639 declare void @llvm.riscv.vssseg6.mask.nxv1f32(<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>, ptr, i64, <vscale x 1 x i1>, i64)
3641 define void @test_vssseg6_nxv1f32(<vscale x 1 x float> %val, ptr %base, i64 %offset, i64 %vl) {
3642 ; CHECK-LABEL: test_vssseg6_nxv1f32:
3643 ; CHECK:       # %bb.0: # %entry
3644 ; CHECK-NEXT:    vmv1r.v v9, v8
3645 ; CHECK-NEXT:    vmv1r.v v10, v8
3646 ; CHECK-NEXT:    vmv1r.v v11, v8
3647 ; CHECK-NEXT:    vmv1r.v v12, v8
3648 ; CHECK-NEXT:    vmv1r.v v13, v8
3649 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
3650 ; CHECK-NEXT:    vssseg6e32.v v8, (a0), a1
3651 ; CHECK-NEXT:    ret
3652 entry:
3653   tail call void @llvm.riscv.vssseg6.nxv1f32(<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val, ptr %base, i64 %offset, i64 %vl)
3654   ret void
3657 define void @test_vssseg6_mask_nxv1f32(<vscale x 1 x float> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
3658 ; CHECK-LABEL: test_vssseg6_mask_nxv1f32:
3659 ; CHECK:       # %bb.0: # %entry
3660 ; CHECK-NEXT:    vmv1r.v v9, v8
3661 ; CHECK-NEXT:    vmv1r.v v10, v8
3662 ; CHECK-NEXT:    vmv1r.v v11, v8
3663 ; CHECK-NEXT:    vmv1r.v v12, v8
3664 ; CHECK-NEXT:    vmv1r.v v13, v8
3665 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
3666 ; CHECK-NEXT:    vssseg6e32.v v8, (a0), a1, v0.t
3667 ; CHECK-NEXT:    ret
3668 entry:
3669   tail call void @llvm.riscv.vssseg6.mask.nxv1f32(<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
3670   ret void
3673 declare void @llvm.riscv.vssseg7.nxv1f32(<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>, ptr, i64, i64)
3674 declare void @llvm.riscv.vssseg7.mask.nxv1f32(<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>, ptr, i64, <vscale x 1 x i1>, i64)
3676 define void @test_vssseg7_nxv1f32(<vscale x 1 x float> %val, ptr %base, i64 %offset, i64 %vl) {
3677 ; CHECK-LABEL: test_vssseg7_nxv1f32:
3678 ; CHECK:       # %bb.0: # %entry
3679 ; CHECK-NEXT:    vmv1r.v v9, v8
3680 ; CHECK-NEXT:    vmv1r.v v10, v8
3681 ; CHECK-NEXT:    vmv1r.v v11, v8
3682 ; CHECK-NEXT:    vmv1r.v v12, v8
3683 ; CHECK-NEXT:    vmv1r.v v13, v8
3684 ; CHECK-NEXT:    vmv1r.v v14, v8
3685 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
3686 ; CHECK-NEXT:    vssseg7e32.v v8, (a0), a1
3687 ; CHECK-NEXT:    ret
3688 entry:
3689   tail call void @llvm.riscv.vssseg7.nxv1f32(<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val, ptr %base, i64 %offset, i64 %vl)
3690   ret void
3693 define void @test_vssseg7_mask_nxv1f32(<vscale x 1 x float> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
3694 ; CHECK-LABEL: test_vssseg7_mask_nxv1f32:
3695 ; CHECK:       # %bb.0: # %entry
3696 ; CHECK-NEXT:    vmv1r.v v9, v8
3697 ; CHECK-NEXT:    vmv1r.v v10, v8
3698 ; CHECK-NEXT:    vmv1r.v v11, v8
3699 ; CHECK-NEXT:    vmv1r.v v12, v8
3700 ; CHECK-NEXT:    vmv1r.v v13, v8
3701 ; CHECK-NEXT:    vmv1r.v v14, v8
3702 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
3703 ; CHECK-NEXT:    vssseg7e32.v v8, (a0), a1, v0.t
3704 ; CHECK-NEXT:    ret
3705 entry:
3706   tail call void @llvm.riscv.vssseg7.mask.nxv1f32(<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
3707   ret void
3710 declare void @llvm.riscv.vssseg8.nxv1f32(<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>, ptr, i64, i64)
3711 declare void @llvm.riscv.vssseg8.mask.nxv1f32(<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>,<vscale x 1 x float>, ptr, i64, <vscale x 1 x i1>, i64)
3713 define void @test_vssseg8_nxv1f32(<vscale x 1 x float> %val, ptr %base, i64 %offset, i64 %vl) {
3714 ; CHECK-LABEL: test_vssseg8_nxv1f32:
3715 ; CHECK:       # %bb.0: # %entry
3716 ; CHECK-NEXT:    vmv1r.v v9, v8
3717 ; CHECK-NEXT:    vmv1r.v v10, v8
3718 ; CHECK-NEXT:    vmv1r.v v11, v8
3719 ; CHECK-NEXT:    vmv1r.v v12, v8
3720 ; CHECK-NEXT:    vmv1r.v v13, v8
3721 ; CHECK-NEXT:    vmv1r.v v14, v8
3722 ; CHECK-NEXT:    vmv1r.v v15, v8
3723 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
3724 ; CHECK-NEXT:    vssseg8e32.v v8, (a0), a1
3725 ; CHECK-NEXT:    ret
3726 entry:
3727   tail call void @llvm.riscv.vssseg8.nxv1f32(<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val, ptr %base, i64 %offset, i64 %vl)
3728   ret void
3731 define void @test_vssseg8_mask_nxv1f32(<vscale x 1 x float> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl) {
3732 ; CHECK-LABEL: test_vssseg8_mask_nxv1f32:
3733 ; CHECK:       # %bb.0: # %entry
3734 ; CHECK-NEXT:    vmv1r.v v9, v8
3735 ; CHECK-NEXT:    vmv1r.v v10, v8
3736 ; CHECK-NEXT:    vmv1r.v v11, v8
3737 ; CHECK-NEXT:    vmv1r.v v12, v8
3738 ; CHECK-NEXT:    vmv1r.v v13, v8
3739 ; CHECK-NEXT:    vmv1r.v v14, v8
3740 ; CHECK-NEXT:    vmv1r.v v15, v8
3741 ; CHECK-NEXT:    vsetvli zero, a2, e32, mf2, ta, ma
3742 ; CHECK-NEXT:    vssseg8e32.v v8, (a0), a1, v0.t
3743 ; CHECK-NEXT:    ret
3744 entry:
3745   tail call void @llvm.riscv.vssseg8.mask.nxv1f32(<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val,<vscale x 1 x float> %val, ptr %base, i64 %offset, <vscale x 1 x i1> %mask, i64 %vl)
3746   ret void
3749 declare void @llvm.riscv.vssseg2.nxv8f16(<vscale x 8 x half>,<vscale x 8 x half>, ptr, i64, i64)
3750 declare void @llvm.riscv.vssseg2.mask.nxv8f16(<vscale x 8 x half>,<vscale x 8 x half>, ptr, i64, <vscale x 8 x i1>, i64)
3752 define void @test_vssseg2_nxv8f16(<vscale x 8 x half> %val, ptr %base, i64 %offset, i64 %vl) {
3753 ; CHECK-LABEL: test_vssseg2_nxv8f16:
3754 ; CHECK:       # %bb.0: # %entry
3755 ; CHECK-NEXT:    vmv2r.v v10, v8
3756 ; CHECK-NEXT:    vsetvli zero, a2, e16, m2, ta, ma
3757 ; CHECK-NEXT:    vssseg2e16.v v8, (a0), a1
3758 ; CHECK-NEXT:    ret
3759 entry:
3760   tail call void @llvm.riscv.vssseg2.nxv8f16(<vscale x 8 x half> %val,<vscale x 8 x half> %val, ptr %base, i64 %offset, i64 %vl)
3761   ret void
3764 define void @test_vssseg2_mask_nxv8f16(<vscale x 8 x half> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl) {
3765 ; CHECK-LABEL: test_vssseg2_mask_nxv8f16:
3766 ; CHECK:       # %bb.0: # %entry
3767 ; CHECK-NEXT:    vmv2r.v v10, v8
3768 ; CHECK-NEXT:    vsetvli zero, a2, e16, m2, ta, ma
3769 ; CHECK-NEXT:    vssseg2e16.v v8, (a0), a1, v0.t
3770 ; CHECK-NEXT:    ret
3771 entry:
3772   tail call void @llvm.riscv.vssseg2.mask.nxv8f16(<vscale x 8 x half> %val,<vscale x 8 x half> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl)
3773   ret void
3776 declare void @llvm.riscv.vssseg3.nxv8f16(<vscale x 8 x half>,<vscale x 8 x half>,<vscale x 8 x half>, ptr, i64, i64)
3777 declare void @llvm.riscv.vssseg3.mask.nxv8f16(<vscale x 8 x half>,<vscale x 8 x half>,<vscale x 8 x half>, ptr, i64, <vscale x 8 x i1>, i64)
3779 define void @test_vssseg3_nxv8f16(<vscale x 8 x half> %val, ptr %base, i64 %offset, i64 %vl) {
3780 ; CHECK-LABEL: test_vssseg3_nxv8f16:
3781 ; CHECK:       # %bb.0: # %entry
3782 ; CHECK-NEXT:    vmv2r.v v10, v8
3783 ; CHECK-NEXT:    vmv2r.v v12, v8
3784 ; CHECK-NEXT:    vsetvli zero, a2, e16, m2, ta, ma
3785 ; CHECK-NEXT:    vssseg3e16.v v8, (a0), a1
3786 ; CHECK-NEXT:    ret
3787 entry:
3788   tail call void @llvm.riscv.vssseg3.nxv8f16(<vscale x 8 x half> %val,<vscale x 8 x half> %val,<vscale x 8 x half> %val, ptr %base, i64 %offset, i64 %vl)
3789   ret void
3792 define void @test_vssseg3_mask_nxv8f16(<vscale x 8 x half> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl) {
3793 ; CHECK-LABEL: test_vssseg3_mask_nxv8f16:
3794 ; CHECK:       # %bb.0: # %entry
3795 ; CHECK-NEXT:    vmv2r.v v10, v8
3796 ; CHECK-NEXT:    vmv2r.v v12, v8
3797 ; CHECK-NEXT:    vsetvli zero, a2, e16, m2, ta, ma
3798 ; CHECK-NEXT:    vssseg3e16.v v8, (a0), a1, v0.t
3799 ; CHECK-NEXT:    ret
3800 entry:
3801   tail call void @llvm.riscv.vssseg3.mask.nxv8f16(<vscale x 8 x half> %val,<vscale x 8 x half> %val,<vscale x 8 x half> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl)
3802   ret void
3805 declare void @llvm.riscv.vssseg4.nxv8f16(<vscale x 8 x half>,<vscale x 8 x half>,<vscale x 8 x half>,<vscale x 8 x half>, ptr, i64, i64)
3806 declare void @llvm.riscv.vssseg4.mask.nxv8f16(<vscale x 8 x half>,<vscale x 8 x half>,<vscale x 8 x half>,<vscale x 8 x half>, ptr, i64, <vscale x 8 x i1>, i64)
3808 define void @test_vssseg4_nxv8f16(<vscale x 8 x half> %val, ptr %base, i64 %offset, i64 %vl) {
3809 ; CHECK-LABEL: test_vssseg4_nxv8f16:
3810 ; CHECK:       # %bb.0: # %entry
3811 ; CHECK-NEXT:    vmv2r.v v10, v8
3812 ; CHECK-NEXT:    vmv2r.v v12, v8
3813 ; CHECK-NEXT:    vmv2r.v v14, v8
3814 ; CHECK-NEXT:    vsetvli zero, a2, e16, m2, ta, ma
3815 ; CHECK-NEXT:    vssseg4e16.v v8, (a0), a1
3816 ; CHECK-NEXT:    ret
3817 entry:
3818   tail call void @llvm.riscv.vssseg4.nxv8f16(<vscale x 8 x half> %val,<vscale x 8 x half> %val,<vscale x 8 x half> %val,<vscale x 8 x half> %val, ptr %base, i64 %offset, i64 %vl)
3819   ret void
3822 define void @test_vssseg4_mask_nxv8f16(<vscale x 8 x half> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl) {
3823 ; CHECK-LABEL: test_vssseg4_mask_nxv8f16:
3824 ; CHECK:       # %bb.0: # %entry
3825 ; CHECK-NEXT:    vmv2r.v v10, v8
3826 ; CHECK-NEXT:    vmv2r.v v12, v8
3827 ; CHECK-NEXT:    vmv2r.v v14, v8
3828 ; CHECK-NEXT:    vsetvli zero, a2, e16, m2, ta, ma
3829 ; CHECK-NEXT:    vssseg4e16.v v8, (a0), a1, v0.t
3830 ; CHECK-NEXT:    ret
3831 entry:
3832   tail call void @llvm.riscv.vssseg4.mask.nxv8f16(<vscale x 8 x half> %val,<vscale x 8 x half> %val,<vscale x 8 x half> %val,<vscale x 8 x half> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl)
3833   ret void
3836 declare void @llvm.riscv.vssseg2.nxv8f32(<vscale x 8 x float>,<vscale x 8 x float>, ptr, i64, i64)
3837 declare void @llvm.riscv.vssseg2.mask.nxv8f32(<vscale x 8 x float>,<vscale x 8 x float>, ptr, i64, <vscale x 8 x i1>, i64)
3839 define void @test_vssseg2_nxv8f32(<vscale x 8 x float> %val, ptr %base, i64 %offset, i64 %vl) {
3840 ; CHECK-LABEL: test_vssseg2_nxv8f32:
3841 ; CHECK:       # %bb.0: # %entry
3842 ; CHECK-NEXT:    vmv4r.v v12, v8
3843 ; CHECK-NEXT:    vsetvli zero, a2, e32, m4, ta, ma
3844 ; CHECK-NEXT:    vssseg2e32.v v8, (a0), a1
3845 ; CHECK-NEXT:    ret
3846 entry:
3847   tail call void @llvm.riscv.vssseg2.nxv8f32(<vscale x 8 x float> %val,<vscale x 8 x float> %val, ptr %base, i64 %offset, i64 %vl)
3848   ret void
3851 define void @test_vssseg2_mask_nxv8f32(<vscale x 8 x float> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl) {
3852 ; CHECK-LABEL: test_vssseg2_mask_nxv8f32:
3853 ; CHECK:       # %bb.0: # %entry
3854 ; CHECK-NEXT:    vmv4r.v v12, v8
3855 ; CHECK-NEXT:    vsetvli zero, a2, e32, m4, ta, ma
3856 ; CHECK-NEXT:    vssseg2e32.v v8, (a0), a1, v0.t
3857 ; CHECK-NEXT:    ret
3858 entry:
3859   tail call void @llvm.riscv.vssseg2.mask.nxv8f32(<vscale x 8 x float> %val,<vscale x 8 x float> %val, ptr %base, i64 %offset, <vscale x 8 x i1> %mask, i64 %vl)
3860   ret void
3863 declare void @llvm.riscv.vssseg2.nxv2f64(<vscale x 2 x double>,<vscale x 2 x double>, ptr, i64, i64)
3864 declare void @llvm.riscv.vssseg2.mask.nxv2f64(<vscale x 2 x double>,<vscale x 2 x double>, ptr, i64, <vscale x 2 x i1>, i64)
3866 define void @test_vssseg2_nxv2f64(<vscale x 2 x double> %val, ptr %base, i64 %offset, i64 %vl) {
3867 ; CHECK-LABEL: test_vssseg2_nxv2f64:
3868 ; CHECK:       # %bb.0: # %entry
3869 ; CHECK-NEXT:    vmv2r.v v10, v8
3870 ; CHECK-NEXT:    vsetvli zero, a2, e64, m2, ta, ma
3871 ; CHECK-NEXT:    vssseg2e64.v v8, (a0), a1
3872 ; CHECK-NEXT:    ret
3873 entry:
3874   tail call void @llvm.riscv.vssseg2.nxv2f64(<vscale x 2 x double> %val,<vscale x 2 x double> %val, ptr %base, i64 %offset, i64 %vl)
3875   ret void
3878 define void @test_vssseg2_mask_nxv2f64(<vscale x 2 x double> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
3879 ; CHECK-LABEL: test_vssseg2_mask_nxv2f64:
3880 ; CHECK:       # %bb.0: # %entry
3881 ; CHECK-NEXT:    vmv2r.v v10, v8
3882 ; CHECK-NEXT:    vsetvli zero, a2, e64, m2, ta, ma
3883 ; CHECK-NEXT:    vssseg2e64.v v8, (a0), a1, v0.t
3884 ; CHECK-NEXT:    ret
3885 entry:
3886   tail call void @llvm.riscv.vssseg2.mask.nxv2f64(<vscale x 2 x double> %val,<vscale x 2 x double> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
3887   ret void
3890 declare void @llvm.riscv.vssseg3.nxv2f64(<vscale x 2 x double>,<vscale x 2 x double>,<vscale x 2 x double>, ptr, i64, i64)
3891 declare void @llvm.riscv.vssseg3.mask.nxv2f64(<vscale x 2 x double>,<vscale x 2 x double>,<vscale x 2 x double>, ptr, i64, <vscale x 2 x i1>, i64)
3893 define void @test_vssseg3_nxv2f64(<vscale x 2 x double> %val, ptr %base, i64 %offset, i64 %vl) {
3894 ; CHECK-LABEL: test_vssseg3_nxv2f64:
3895 ; CHECK:       # %bb.0: # %entry
3896 ; CHECK-NEXT:    vmv2r.v v10, v8
3897 ; CHECK-NEXT:    vmv2r.v v12, v8
3898 ; CHECK-NEXT:    vsetvli zero, a2, e64, m2, ta, ma
3899 ; CHECK-NEXT:    vssseg3e64.v v8, (a0), a1
3900 ; CHECK-NEXT:    ret
3901 entry:
3902   tail call void @llvm.riscv.vssseg3.nxv2f64(<vscale x 2 x double> %val,<vscale x 2 x double> %val,<vscale x 2 x double> %val, ptr %base, i64 %offset, i64 %vl)
3903   ret void
3906 define void @test_vssseg3_mask_nxv2f64(<vscale x 2 x double> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
3907 ; CHECK-LABEL: test_vssseg3_mask_nxv2f64:
3908 ; CHECK:       # %bb.0: # %entry
3909 ; CHECK-NEXT:    vmv2r.v v10, v8
3910 ; CHECK-NEXT:    vmv2r.v v12, v8
3911 ; CHECK-NEXT:    vsetvli zero, a2, e64, m2, ta, ma
3912 ; CHECK-NEXT:    vssseg3e64.v v8, (a0), a1, v0.t
3913 ; CHECK-NEXT:    ret
3914 entry:
3915   tail call void @llvm.riscv.vssseg3.mask.nxv2f64(<vscale x 2 x double> %val,<vscale x 2 x double> %val,<vscale x 2 x double> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
3916   ret void
3919 declare void @llvm.riscv.vssseg4.nxv2f64(<vscale x 2 x double>,<vscale x 2 x double>,<vscale x 2 x double>,<vscale x 2 x double>, ptr, i64, i64)
3920 declare void @llvm.riscv.vssseg4.mask.nxv2f64(<vscale x 2 x double>,<vscale x 2 x double>,<vscale x 2 x double>,<vscale x 2 x double>, ptr, i64, <vscale x 2 x i1>, i64)
3922 define void @test_vssseg4_nxv2f64(<vscale x 2 x double> %val, ptr %base, i64 %offset, i64 %vl) {
3923 ; CHECK-LABEL: test_vssseg4_nxv2f64:
3924 ; CHECK:       # %bb.0: # %entry
3925 ; CHECK-NEXT:    vmv2r.v v10, v8
3926 ; CHECK-NEXT:    vmv2r.v v12, v8
3927 ; CHECK-NEXT:    vmv2r.v v14, v8
3928 ; CHECK-NEXT:    vsetvli zero, a2, e64, m2, ta, ma
3929 ; CHECK-NEXT:    vssseg4e64.v v8, (a0), a1
3930 ; CHECK-NEXT:    ret
3931 entry:
3932   tail call void @llvm.riscv.vssseg4.nxv2f64(<vscale x 2 x double> %val,<vscale x 2 x double> %val,<vscale x 2 x double> %val,<vscale x 2 x double> %val, ptr %base, i64 %offset, i64 %vl)
3933   ret void
3936 define void @test_vssseg4_mask_nxv2f64(<vscale x 2 x double> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
3937 ; CHECK-LABEL: test_vssseg4_mask_nxv2f64:
3938 ; CHECK:       # %bb.0: # %entry
3939 ; CHECK-NEXT:    vmv2r.v v10, v8
3940 ; CHECK-NEXT:    vmv2r.v v12, v8
3941 ; CHECK-NEXT:    vmv2r.v v14, v8
3942 ; CHECK-NEXT:    vsetvli zero, a2, e64, m2, ta, ma
3943 ; CHECK-NEXT:    vssseg4e64.v v8, (a0), a1, v0.t
3944 ; CHECK-NEXT:    ret
3945 entry:
3946   tail call void @llvm.riscv.vssseg4.mask.nxv2f64(<vscale x 2 x double> %val,<vscale x 2 x double> %val,<vscale x 2 x double> %val,<vscale x 2 x double> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
3947   ret void
3950 declare void @llvm.riscv.vssseg2.nxv4f16(<vscale x 4 x half>,<vscale x 4 x half>, ptr, i64, i64)
3951 declare void @llvm.riscv.vssseg2.mask.nxv4f16(<vscale x 4 x half>,<vscale x 4 x half>, ptr, i64, <vscale x 4 x i1>, i64)
3953 define void @test_vssseg2_nxv4f16(<vscale x 4 x half> %val, ptr %base, i64 %offset, i64 %vl) {
3954 ; CHECK-LABEL: test_vssseg2_nxv4f16:
3955 ; CHECK:       # %bb.0: # %entry
3956 ; CHECK-NEXT:    vmv1r.v v9, v8
3957 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
3958 ; CHECK-NEXT:    vssseg2e16.v v8, (a0), a1
3959 ; CHECK-NEXT:    ret
3960 entry:
3961   tail call void @llvm.riscv.vssseg2.nxv4f16(<vscale x 4 x half> %val,<vscale x 4 x half> %val, ptr %base, i64 %offset, i64 %vl)
3962   ret void
3965 define void @test_vssseg2_mask_nxv4f16(<vscale x 4 x half> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
3966 ; CHECK-LABEL: test_vssseg2_mask_nxv4f16:
3967 ; CHECK:       # %bb.0: # %entry
3968 ; CHECK-NEXT:    vmv1r.v v9, v8
3969 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
3970 ; CHECK-NEXT:    vssseg2e16.v v8, (a0), a1, v0.t
3971 ; CHECK-NEXT:    ret
3972 entry:
3973   tail call void @llvm.riscv.vssseg2.mask.nxv4f16(<vscale x 4 x half> %val,<vscale x 4 x half> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
3974   ret void
3977 declare void @llvm.riscv.vssseg3.nxv4f16(<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>, ptr, i64, i64)
3978 declare void @llvm.riscv.vssseg3.mask.nxv4f16(<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>, ptr, i64, <vscale x 4 x i1>, i64)
3980 define void @test_vssseg3_nxv4f16(<vscale x 4 x half> %val, ptr %base, i64 %offset, i64 %vl) {
3981 ; CHECK-LABEL: test_vssseg3_nxv4f16:
3982 ; CHECK:       # %bb.0: # %entry
3983 ; CHECK-NEXT:    vmv1r.v v9, v8
3984 ; CHECK-NEXT:    vmv1r.v v10, v8
3985 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
3986 ; CHECK-NEXT:    vssseg3e16.v v8, (a0), a1
3987 ; CHECK-NEXT:    ret
3988 entry:
3989   tail call void @llvm.riscv.vssseg3.nxv4f16(<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val, ptr %base, i64 %offset, i64 %vl)
3990   ret void
3993 define void @test_vssseg3_mask_nxv4f16(<vscale x 4 x half> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
3994 ; CHECK-LABEL: test_vssseg3_mask_nxv4f16:
3995 ; CHECK:       # %bb.0: # %entry
3996 ; CHECK-NEXT:    vmv1r.v v9, v8
3997 ; CHECK-NEXT:    vmv1r.v v10, v8
3998 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
3999 ; CHECK-NEXT:    vssseg3e16.v v8, (a0), a1, v0.t
4000 ; CHECK-NEXT:    ret
4001 entry:
4002   tail call void @llvm.riscv.vssseg3.mask.nxv4f16(<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
4003   ret void
4006 declare void @llvm.riscv.vssseg4.nxv4f16(<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>, ptr, i64, i64)
4007 declare void @llvm.riscv.vssseg4.mask.nxv4f16(<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>, ptr, i64, <vscale x 4 x i1>, i64)
4009 define void @test_vssseg4_nxv4f16(<vscale x 4 x half> %val, ptr %base, i64 %offset, i64 %vl) {
4010 ; CHECK-LABEL: test_vssseg4_nxv4f16:
4011 ; CHECK:       # %bb.0: # %entry
4012 ; CHECK-NEXT:    vmv1r.v v9, v8
4013 ; CHECK-NEXT:    vmv1r.v v10, v8
4014 ; CHECK-NEXT:    vmv1r.v v11, v8
4015 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
4016 ; CHECK-NEXT:    vssseg4e16.v v8, (a0), a1
4017 ; CHECK-NEXT:    ret
4018 entry:
4019   tail call void @llvm.riscv.vssseg4.nxv4f16(<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val, ptr %base, i64 %offset, i64 %vl)
4020   ret void
4023 define void @test_vssseg4_mask_nxv4f16(<vscale x 4 x half> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
4024 ; CHECK-LABEL: test_vssseg4_mask_nxv4f16:
4025 ; CHECK:       # %bb.0: # %entry
4026 ; CHECK-NEXT:    vmv1r.v v9, v8
4027 ; CHECK-NEXT:    vmv1r.v v10, v8
4028 ; CHECK-NEXT:    vmv1r.v v11, v8
4029 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
4030 ; CHECK-NEXT:    vssseg4e16.v v8, (a0), a1, v0.t
4031 ; CHECK-NEXT:    ret
4032 entry:
4033   tail call void @llvm.riscv.vssseg4.mask.nxv4f16(<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
4034   ret void
4037 declare void @llvm.riscv.vssseg5.nxv4f16(<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>, ptr, i64, i64)
4038 declare void @llvm.riscv.vssseg5.mask.nxv4f16(<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>, ptr, i64, <vscale x 4 x i1>, i64)
4040 define void @test_vssseg5_nxv4f16(<vscale x 4 x half> %val, ptr %base, i64 %offset, i64 %vl) {
4041 ; CHECK-LABEL: test_vssseg5_nxv4f16:
4042 ; CHECK:       # %bb.0: # %entry
4043 ; CHECK-NEXT:    vmv1r.v v9, v8
4044 ; CHECK-NEXT:    vmv1r.v v10, v8
4045 ; CHECK-NEXT:    vmv1r.v v11, v8
4046 ; CHECK-NEXT:    vmv1r.v v12, v8
4047 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
4048 ; CHECK-NEXT:    vssseg5e16.v v8, (a0), a1
4049 ; CHECK-NEXT:    ret
4050 entry:
4051   tail call void @llvm.riscv.vssseg5.nxv4f16(<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val, ptr %base, i64 %offset, i64 %vl)
4052   ret void
4055 define void @test_vssseg5_mask_nxv4f16(<vscale x 4 x half> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
4056 ; CHECK-LABEL: test_vssseg5_mask_nxv4f16:
4057 ; CHECK:       # %bb.0: # %entry
4058 ; CHECK-NEXT:    vmv1r.v v9, v8
4059 ; CHECK-NEXT:    vmv1r.v v10, v8
4060 ; CHECK-NEXT:    vmv1r.v v11, v8
4061 ; CHECK-NEXT:    vmv1r.v v12, v8
4062 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
4063 ; CHECK-NEXT:    vssseg5e16.v v8, (a0), a1, v0.t
4064 ; CHECK-NEXT:    ret
4065 entry:
4066   tail call void @llvm.riscv.vssseg5.mask.nxv4f16(<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
4067   ret void
4070 declare void @llvm.riscv.vssseg6.nxv4f16(<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>, ptr, i64, i64)
4071 declare void @llvm.riscv.vssseg6.mask.nxv4f16(<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>, ptr, i64, <vscale x 4 x i1>, i64)
4073 define void @test_vssseg6_nxv4f16(<vscale x 4 x half> %val, ptr %base, i64 %offset, i64 %vl) {
4074 ; CHECK-LABEL: test_vssseg6_nxv4f16:
4075 ; CHECK:       # %bb.0: # %entry
4076 ; CHECK-NEXT:    vmv1r.v v9, v8
4077 ; CHECK-NEXT:    vmv1r.v v10, v8
4078 ; CHECK-NEXT:    vmv1r.v v11, v8
4079 ; CHECK-NEXT:    vmv1r.v v12, v8
4080 ; CHECK-NEXT:    vmv1r.v v13, v8
4081 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
4082 ; CHECK-NEXT:    vssseg6e16.v v8, (a0), a1
4083 ; CHECK-NEXT:    ret
4084 entry:
4085   tail call void @llvm.riscv.vssseg6.nxv4f16(<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val, ptr %base, i64 %offset, i64 %vl)
4086   ret void
4089 define void @test_vssseg6_mask_nxv4f16(<vscale x 4 x half> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
4090 ; CHECK-LABEL: test_vssseg6_mask_nxv4f16:
4091 ; CHECK:       # %bb.0: # %entry
4092 ; CHECK-NEXT:    vmv1r.v v9, v8
4093 ; CHECK-NEXT:    vmv1r.v v10, v8
4094 ; CHECK-NEXT:    vmv1r.v v11, v8
4095 ; CHECK-NEXT:    vmv1r.v v12, v8
4096 ; CHECK-NEXT:    vmv1r.v v13, v8
4097 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
4098 ; CHECK-NEXT:    vssseg6e16.v v8, (a0), a1, v0.t
4099 ; CHECK-NEXT:    ret
4100 entry:
4101   tail call void @llvm.riscv.vssseg6.mask.nxv4f16(<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
4102   ret void
4105 declare void @llvm.riscv.vssseg7.nxv4f16(<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>, ptr, i64, i64)
4106 declare void @llvm.riscv.vssseg7.mask.nxv4f16(<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>, ptr, i64, <vscale x 4 x i1>, i64)
4108 define void @test_vssseg7_nxv4f16(<vscale x 4 x half> %val, ptr %base, i64 %offset, i64 %vl) {
4109 ; CHECK-LABEL: test_vssseg7_nxv4f16:
4110 ; CHECK:       # %bb.0: # %entry
4111 ; CHECK-NEXT:    vmv1r.v v9, v8
4112 ; CHECK-NEXT:    vmv1r.v v10, v8
4113 ; CHECK-NEXT:    vmv1r.v v11, v8
4114 ; CHECK-NEXT:    vmv1r.v v12, v8
4115 ; CHECK-NEXT:    vmv1r.v v13, v8
4116 ; CHECK-NEXT:    vmv1r.v v14, v8
4117 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
4118 ; CHECK-NEXT:    vssseg7e16.v v8, (a0), a1
4119 ; CHECK-NEXT:    ret
4120 entry:
4121   tail call void @llvm.riscv.vssseg7.nxv4f16(<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val, ptr %base, i64 %offset, i64 %vl)
4122   ret void
4125 define void @test_vssseg7_mask_nxv4f16(<vscale x 4 x half> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
4126 ; CHECK-LABEL: test_vssseg7_mask_nxv4f16:
4127 ; CHECK:       # %bb.0: # %entry
4128 ; CHECK-NEXT:    vmv1r.v v9, v8
4129 ; CHECK-NEXT:    vmv1r.v v10, v8
4130 ; CHECK-NEXT:    vmv1r.v v11, v8
4131 ; CHECK-NEXT:    vmv1r.v v12, v8
4132 ; CHECK-NEXT:    vmv1r.v v13, v8
4133 ; CHECK-NEXT:    vmv1r.v v14, v8
4134 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
4135 ; CHECK-NEXT:    vssseg7e16.v v8, (a0), a1, v0.t
4136 ; CHECK-NEXT:    ret
4137 entry:
4138   tail call void @llvm.riscv.vssseg7.mask.nxv4f16(<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
4139   ret void
4142 declare void @llvm.riscv.vssseg8.nxv4f16(<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>, ptr, i64, i64)
4143 declare void @llvm.riscv.vssseg8.mask.nxv4f16(<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>,<vscale x 4 x half>, ptr, i64, <vscale x 4 x i1>, i64)
4145 define void @test_vssseg8_nxv4f16(<vscale x 4 x half> %val, ptr %base, i64 %offset, i64 %vl) {
4146 ; CHECK-LABEL: test_vssseg8_nxv4f16:
4147 ; CHECK:       # %bb.0: # %entry
4148 ; CHECK-NEXT:    vmv1r.v v9, v8
4149 ; CHECK-NEXT:    vmv1r.v v10, v8
4150 ; CHECK-NEXT:    vmv1r.v v11, v8
4151 ; CHECK-NEXT:    vmv1r.v v12, v8
4152 ; CHECK-NEXT:    vmv1r.v v13, v8
4153 ; CHECK-NEXT:    vmv1r.v v14, v8
4154 ; CHECK-NEXT:    vmv1r.v v15, v8
4155 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
4156 ; CHECK-NEXT:    vssseg8e16.v v8, (a0), a1
4157 ; CHECK-NEXT:    ret
4158 entry:
4159   tail call void @llvm.riscv.vssseg8.nxv4f16(<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val, ptr %base, i64 %offset, i64 %vl)
4160   ret void
4163 define void @test_vssseg8_mask_nxv4f16(<vscale x 4 x half> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
4164 ; CHECK-LABEL: test_vssseg8_mask_nxv4f16:
4165 ; CHECK:       # %bb.0: # %entry
4166 ; CHECK-NEXT:    vmv1r.v v9, v8
4167 ; CHECK-NEXT:    vmv1r.v v10, v8
4168 ; CHECK-NEXT:    vmv1r.v v11, v8
4169 ; CHECK-NEXT:    vmv1r.v v12, v8
4170 ; CHECK-NEXT:    vmv1r.v v13, v8
4171 ; CHECK-NEXT:    vmv1r.v v14, v8
4172 ; CHECK-NEXT:    vmv1r.v v15, v8
4173 ; CHECK-NEXT:    vsetvli zero, a2, e16, m1, ta, ma
4174 ; CHECK-NEXT:    vssseg8e16.v v8, (a0), a1, v0.t
4175 ; CHECK-NEXT:    ret
4176 entry:
4177   tail call void @llvm.riscv.vssseg8.mask.nxv4f16(<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val,<vscale x 4 x half> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
4178   ret void
4181 declare void @llvm.riscv.vssseg2.nxv2f16(<vscale x 2 x half>,<vscale x 2 x half>, ptr, i64, i64)
4182 declare void @llvm.riscv.vssseg2.mask.nxv2f16(<vscale x 2 x half>,<vscale x 2 x half>, ptr, i64, <vscale x 2 x i1>, i64)
4184 define void @test_vssseg2_nxv2f16(<vscale x 2 x half> %val, ptr %base, i64 %offset, i64 %vl) {
4185 ; CHECK-LABEL: test_vssseg2_nxv2f16:
4186 ; CHECK:       # %bb.0: # %entry
4187 ; CHECK-NEXT:    vmv1r.v v9, v8
4188 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
4189 ; CHECK-NEXT:    vssseg2e16.v v8, (a0), a1
4190 ; CHECK-NEXT:    ret
4191 entry:
4192   tail call void @llvm.riscv.vssseg2.nxv2f16(<vscale x 2 x half> %val,<vscale x 2 x half> %val, ptr %base, i64 %offset, i64 %vl)
4193   ret void
4196 define void @test_vssseg2_mask_nxv2f16(<vscale x 2 x half> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
4197 ; CHECK-LABEL: test_vssseg2_mask_nxv2f16:
4198 ; CHECK:       # %bb.0: # %entry
4199 ; CHECK-NEXT:    vmv1r.v v9, v8
4200 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
4201 ; CHECK-NEXT:    vssseg2e16.v v8, (a0), a1, v0.t
4202 ; CHECK-NEXT:    ret
4203 entry:
4204   tail call void @llvm.riscv.vssseg2.mask.nxv2f16(<vscale x 2 x half> %val,<vscale x 2 x half> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
4205   ret void
4208 declare void @llvm.riscv.vssseg3.nxv2f16(<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>, ptr, i64, i64)
4209 declare void @llvm.riscv.vssseg3.mask.nxv2f16(<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>, ptr, i64, <vscale x 2 x i1>, i64)
4211 define void @test_vssseg3_nxv2f16(<vscale x 2 x half> %val, ptr %base, i64 %offset, i64 %vl) {
4212 ; CHECK-LABEL: test_vssseg3_nxv2f16:
4213 ; CHECK:       # %bb.0: # %entry
4214 ; CHECK-NEXT:    vmv1r.v v9, v8
4215 ; CHECK-NEXT:    vmv1r.v v10, v8
4216 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
4217 ; CHECK-NEXT:    vssseg3e16.v v8, (a0), a1
4218 ; CHECK-NEXT:    ret
4219 entry:
4220   tail call void @llvm.riscv.vssseg3.nxv2f16(<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val, ptr %base, i64 %offset, i64 %vl)
4221   ret void
4224 define void @test_vssseg3_mask_nxv2f16(<vscale x 2 x half> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
4225 ; CHECK-LABEL: test_vssseg3_mask_nxv2f16:
4226 ; CHECK:       # %bb.0: # %entry
4227 ; CHECK-NEXT:    vmv1r.v v9, v8
4228 ; CHECK-NEXT:    vmv1r.v v10, v8
4229 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
4230 ; CHECK-NEXT:    vssseg3e16.v v8, (a0), a1, v0.t
4231 ; CHECK-NEXT:    ret
4232 entry:
4233   tail call void @llvm.riscv.vssseg3.mask.nxv2f16(<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
4234   ret void
4237 declare void @llvm.riscv.vssseg4.nxv2f16(<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>, ptr, i64, i64)
4238 declare void @llvm.riscv.vssseg4.mask.nxv2f16(<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>, ptr, i64, <vscale x 2 x i1>, i64)
4240 define void @test_vssseg4_nxv2f16(<vscale x 2 x half> %val, ptr %base, i64 %offset, i64 %vl) {
4241 ; CHECK-LABEL: test_vssseg4_nxv2f16:
4242 ; CHECK:       # %bb.0: # %entry
4243 ; CHECK-NEXT:    vmv1r.v v9, v8
4244 ; CHECK-NEXT:    vmv1r.v v10, v8
4245 ; CHECK-NEXT:    vmv1r.v v11, v8
4246 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
4247 ; CHECK-NEXT:    vssseg4e16.v v8, (a0), a1
4248 ; CHECK-NEXT:    ret
4249 entry:
4250   tail call void @llvm.riscv.vssseg4.nxv2f16(<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val, ptr %base, i64 %offset, i64 %vl)
4251   ret void
4254 define void @test_vssseg4_mask_nxv2f16(<vscale x 2 x half> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
4255 ; CHECK-LABEL: test_vssseg4_mask_nxv2f16:
4256 ; CHECK:       # %bb.0: # %entry
4257 ; CHECK-NEXT:    vmv1r.v v9, v8
4258 ; CHECK-NEXT:    vmv1r.v v10, v8
4259 ; CHECK-NEXT:    vmv1r.v v11, v8
4260 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
4261 ; CHECK-NEXT:    vssseg4e16.v v8, (a0), a1, v0.t
4262 ; CHECK-NEXT:    ret
4263 entry:
4264   tail call void @llvm.riscv.vssseg4.mask.nxv2f16(<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
4265   ret void
4268 declare void @llvm.riscv.vssseg5.nxv2f16(<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>, ptr, i64, i64)
4269 declare void @llvm.riscv.vssseg5.mask.nxv2f16(<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>, ptr, i64, <vscale x 2 x i1>, i64)
4271 define void @test_vssseg5_nxv2f16(<vscale x 2 x half> %val, ptr %base, i64 %offset, i64 %vl) {
4272 ; CHECK-LABEL: test_vssseg5_nxv2f16:
4273 ; CHECK:       # %bb.0: # %entry
4274 ; CHECK-NEXT:    vmv1r.v v9, v8
4275 ; CHECK-NEXT:    vmv1r.v v10, v8
4276 ; CHECK-NEXT:    vmv1r.v v11, v8
4277 ; CHECK-NEXT:    vmv1r.v v12, v8
4278 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
4279 ; CHECK-NEXT:    vssseg5e16.v v8, (a0), a1
4280 ; CHECK-NEXT:    ret
4281 entry:
4282   tail call void @llvm.riscv.vssseg5.nxv2f16(<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val, ptr %base, i64 %offset, i64 %vl)
4283   ret void
4286 define void @test_vssseg5_mask_nxv2f16(<vscale x 2 x half> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
4287 ; CHECK-LABEL: test_vssseg5_mask_nxv2f16:
4288 ; CHECK:       # %bb.0: # %entry
4289 ; CHECK-NEXT:    vmv1r.v v9, v8
4290 ; CHECK-NEXT:    vmv1r.v v10, v8
4291 ; CHECK-NEXT:    vmv1r.v v11, v8
4292 ; CHECK-NEXT:    vmv1r.v v12, v8
4293 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
4294 ; CHECK-NEXT:    vssseg5e16.v v8, (a0), a1, v0.t
4295 ; CHECK-NEXT:    ret
4296 entry:
4297   tail call void @llvm.riscv.vssseg5.mask.nxv2f16(<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
4298   ret void
4301 declare void @llvm.riscv.vssseg6.nxv2f16(<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>, ptr, i64, i64)
4302 declare void @llvm.riscv.vssseg6.mask.nxv2f16(<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>, ptr, i64, <vscale x 2 x i1>, i64)
4304 define void @test_vssseg6_nxv2f16(<vscale x 2 x half> %val, ptr %base, i64 %offset, i64 %vl) {
4305 ; CHECK-LABEL: test_vssseg6_nxv2f16:
4306 ; CHECK:       # %bb.0: # %entry
4307 ; CHECK-NEXT:    vmv1r.v v9, v8
4308 ; CHECK-NEXT:    vmv1r.v v10, v8
4309 ; CHECK-NEXT:    vmv1r.v v11, v8
4310 ; CHECK-NEXT:    vmv1r.v v12, v8
4311 ; CHECK-NEXT:    vmv1r.v v13, v8
4312 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
4313 ; CHECK-NEXT:    vssseg6e16.v v8, (a0), a1
4314 ; CHECK-NEXT:    ret
4315 entry:
4316   tail call void @llvm.riscv.vssseg6.nxv2f16(<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val, ptr %base, i64 %offset, i64 %vl)
4317   ret void
4320 define void @test_vssseg6_mask_nxv2f16(<vscale x 2 x half> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
4321 ; CHECK-LABEL: test_vssseg6_mask_nxv2f16:
4322 ; CHECK:       # %bb.0: # %entry
4323 ; CHECK-NEXT:    vmv1r.v v9, v8
4324 ; CHECK-NEXT:    vmv1r.v v10, v8
4325 ; CHECK-NEXT:    vmv1r.v v11, v8
4326 ; CHECK-NEXT:    vmv1r.v v12, v8
4327 ; CHECK-NEXT:    vmv1r.v v13, v8
4328 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
4329 ; CHECK-NEXT:    vssseg6e16.v v8, (a0), a1, v0.t
4330 ; CHECK-NEXT:    ret
4331 entry:
4332   tail call void @llvm.riscv.vssseg6.mask.nxv2f16(<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
4333   ret void
4336 declare void @llvm.riscv.vssseg7.nxv2f16(<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>, ptr, i64, i64)
4337 declare void @llvm.riscv.vssseg7.mask.nxv2f16(<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>, ptr, i64, <vscale x 2 x i1>, i64)
4339 define void @test_vssseg7_nxv2f16(<vscale x 2 x half> %val, ptr %base, i64 %offset, i64 %vl) {
4340 ; CHECK-LABEL: test_vssseg7_nxv2f16:
4341 ; CHECK:       # %bb.0: # %entry
4342 ; CHECK-NEXT:    vmv1r.v v9, v8
4343 ; CHECK-NEXT:    vmv1r.v v10, v8
4344 ; CHECK-NEXT:    vmv1r.v v11, v8
4345 ; CHECK-NEXT:    vmv1r.v v12, v8
4346 ; CHECK-NEXT:    vmv1r.v v13, v8
4347 ; CHECK-NEXT:    vmv1r.v v14, v8
4348 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
4349 ; CHECK-NEXT:    vssseg7e16.v v8, (a0), a1
4350 ; CHECK-NEXT:    ret
4351 entry:
4352   tail call void @llvm.riscv.vssseg7.nxv2f16(<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val, ptr %base, i64 %offset, i64 %vl)
4353   ret void
4356 define void @test_vssseg7_mask_nxv2f16(<vscale x 2 x half> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
4357 ; CHECK-LABEL: test_vssseg7_mask_nxv2f16:
4358 ; CHECK:       # %bb.0: # %entry
4359 ; CHECK-NEXT:    vmv1r.v v9, v8
4360 ; CHECK-NEXT:    vmv1r.v v10, v8
4361 ; CHECK-NEXT:    vmv1r.v v11, v8
4362 ; CHECK-NEXT:    vmv1r.v v12, v8
4363 ; CHECK-NEXT:    vmv1r.v v13, v8
4364 ; CHECK-NEXT:    vmv1r.v v14, v8
4365 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
4366 ; CHECK-NEXT:    vssseg7e16.v v8, (a0), a1, v0.t
4367 ; CHECK-NEXT:    ret
4368 entry:
4369   tail call void @llvm.riscv.vssseg7.mask.nxv2f16(<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
4370   ret void
4373 declare void @llvm.riscv.vssseg8.nxv2f16(<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>, ptr, i64, i64)
4374 declare void @llvm.riscv.vssseg8.mask.nxv2f16(<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>,<vscale x 2 x half>, ptr, i64, <vscale x 2 x i1>, i64)
4376 define void @test_vssseg8_nxv2f16(<vscale x 2 x half> %val, ptr %base, i64 %offset, i64 %vl) {
4377 ; CHECK-LABEL: test_vssseg8_nxv2f16:
4378 ; CHECK:       # %bb.0: # %entry
4379 ; CHECK-NEXT:    vmv1r.v v9, v8
4380 ; CHECK-NEXT:    vmv1r.v v10, v8
4381 ; CHECK-NEXT:    vmv1r.v v11, v8
4382 ; CHECK-NEXT:    vmv1r.v v12, v8
4383 ; CHECK-NEXT:    vmv1r.v v13, v8
4384 ; CHECK-NEXT:    vmv1r.v v14, v8
4385 ; CHECK-NEXT:    vmv1r.v v15, v8
4386 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
4387 ; CHECK-NEXT:    vssseg8e16.v v8, (a0), a1
4388 ; CHECK-NEXT:    ret
4389 entry:
4390   tail call void @llvm.riscv.vssseg8.nxv2f16(<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val, ptr %base, i64 %offset, i64 %vl)
4391   ret void
4394 define void @test_vssseg8_mask_nxv2f16(<vscale x 2 x half> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl) {
4395 ; CHECK-LABEL: test_vssseg8_mask_nxv2f16:
4396 ; CHECK:       # %bb.0: # %entry
4397 ; CHECK-NEXT:    vmv1r.v v9, v8
4398 ; CHECK-NEXT:    vmv1r.v v10, v8
4399 ; CHECK-NEXT:    vmv1r.v v11, v8
4400 ; CHECK-NEXT:    vmv1r.v v12, v8
4401 ; CHECK-NEXT:    vmv1r.v v13, v8
4402 ; CHECK-NEXT:    vmv1r.v v14, v8
4403 ; CHECK-NEXT:    vmv1r.v v15, v8
4404 ; CHECK-NEXT:    vsetvli zero, a2, e16, mf2, ta, ma
4405 ; CHECK-NEXT:    vssseg8e16.v v8, (a0), a1, v0.t
4406 ; CHECK-NEXT:    ret
4407 entry:
4408   tail call void @llvm.riscv.vssseg8.mask.nxv2f16(<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val,<vscale x 2 x half> %val, ptr %base, i64 %offset, <vscale x 2 x i1> %mask, i64 %vl)
4409   ret void
4412 declare void @llvm.riscv.vssseg2.nxv4f32(<vscale x 4 x float>,<vscale x 4 x float>, ptr, i64, i64)
4413 declare void @llvm.riscv.vssseg2.mask.nxv4f32(<vscale x 4 x float>,<vscale x 4 x float>, ptr, i64, <vscale x 4 x i1>, i64)
4415 define void @test_vssseg2_nxv4f32(<vscale x 4 x float> %val, ptr %base, i64 %offset, i64 %vl) {
4416 ; CHECK-LABEL: test_vssseg2_nxv4f32:
4417 ; CHECK:       # %bb.0: # %entry
4418 ; CHECK-NEXT:    vmv2r.v v10, v8
4419 ; CHECK-NEXT:    vsetvli zero, a2, e32, m2, ta, ma
4420 ; CHECK-NEXT:    vssseg2e32.v v8, (a0), a1
4421 ; CHECK-NEXT:    ret
4422 entry:
4423   tail call void @llvm.riscv.vssseg2.nxv4f32(<vscale x 4 x float> %val,<vscale x 4 x float> %val, ptr %base, i64 %offset, i64 %vl)
4424   ret void
4427 define void @test_vssseg2_mask_nxv4f32(<vscale x 4 x float> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
4428 ; CHECK-LABEL: test_vssseg2_mask_nxv4f32:
4429 ; CHECK:       # %bb.0: # %entry
4430 ; CHECK-NEXT:    vmv2r.v v10, v8
4431 ; CHECK-NEXT:    vsetvli zero, a2, e32, m2, ta, ma
4432 ; CHECK-NEXT:    vssseg2e32.v v8, (a0), a1, v0.t
4433 ; CHECK-NEXT:    ret
4434 entry:
4435   tail call void @llvm.riscv.vssseg2.mask.nxv4f32(<vscale x 4 x float> %val,<vscale x 4 x float> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
4436   ret void
4439 declare void @llvm.riscv.vssseg3.nxv4f32(<vscale x 4 x float>,<vscale x 4 x float>,<vscale x 4 x float>, ptr, i64, i64)
4440 declare void @llvm.riscv.vssseg3.mask.nxv4f32(<vscale x 4 x float>,<vscale x 4 x float>,<vscale x 4 x float>, ptr, i64, <vscale x 4 x i1>, i64)
4442 define void @test_vssseg3_nxv4f32(<vscale x 4 x float> %val, ptr %base, i64 %offset, i64 %vl) {
4443 ; CHECK-LABEL: test_vssseg3_nxv4f32:
4444 ; CHECK:       # %bb.0: # %entry
4445 ; CHECK-NEXT:    vmv2r.v v10, v8
4446 ; CHECK-NEXT:    vmv2r.v v12, v8
4447 ; CHECK-NEXT:    vsetvli zero, a2, e32, m2, ta, ma
4448 ; CHECK-NEXT:    vssseg3e32.v v8, (a0), a1
4449 ; CHECK-NEXT:    ret
4450 entry:
4451   tail call void @llvm.riscv.vssseg3.nxv4f32(<vscale x 4 x float> %val,<vscale x 4 x float> %val,<vscale x 4 x float> %val, ptr %base, i64 %offset, i64 %vl)
4452   ret void
4455 define void @test_vssseg3_mask_nxv4f32(<vscale x 4 x float> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
4456 ; CHECK-LABEL: test_vssseg3_mask_nxv4f32:
4457 ; CHECK:       # %bb.0: # %entry
4458 ; CHECK-NEXT:    vmv2r.v v10, v8
4459 ; CHECK-NEXT:    vmv2r.v v12, v8
4460 ; CHECK-NEXT:    vsetvli zero, a2, e32, m2, ta, ma
4461 ; CHECK-NEXT:    vssseg3e32.v v8, (a0), a1, v0.t
4462 ; CHECK-NEXT:    ret
4463 entry:
4464   tail call void @llvm.riscv.vssseg3.mask.nxv4f32(<vscale x 4 x float> %val,<vscale x 4 x float> %val,<vscale x 4 x float> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
4465   ret void
4468 declare void @llvm.riscv.vssseg4.nxv4f32(<vscale x 4 x float>,<vscale x 4 x float>,<vscale x 4 x float>,<vscale x 4 x float>, ptr, i64, i64)
4469 declare void @llvm.riscv.vssseg4.mask.nxv4f32(<vscale x 4 x float>,<vscale x 4 x float>,<vscale x 4 x float>,<vscale x 4 x float>, ptr, i64, <vscale x 4 x i1>, i64)
4471 define void @test_vssseg4_nxv4f32(<vscale x 4 x float> %val, ptr %base, i64 %offset, i64 %vl) {
4472 ; CHECK-LABEL: test_vssseg4_nxv4f32:
4473 ; CHECK:       # %bb.0: # %entry
4474 ; CHECK-NEXT:    vmv2r.v v10, v8
4475 ; CHECK-NEXT:    vmv2r.v v12, v8
4476 ; CHECK-NEXT:    vmv2r.v v14, v8
4477 ; CHECK-NEXT:    vsetvli zero, a2, e32, m2, ta, ma
4478 ; CHECK-NEXT:    vssseg4e32.v v8, (a0), a1
4479 ; CHECK-NEXT:    ret
4480 entry:
4481   tail call void @llvm.riscv.vssseg4.nxv4f32(<vscale x 4 x float> %val,<vscale x 4 x float> %val,<vscale x 4 x float> %val,<vscale x 4 x float> %val, ptr %base, i64 %offset, i64 %vl)
4482   ret void
4485 define void @test_vssseg4_mask_nxv4f32(<vscale x 4 x float> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl) {
4486 ; CHECK-LABEL: test_vssseg4_mask_nxv4f32:
4487 ; CHECK:       # %bb.0: # %entry
4488 ; CHECK-NEXT:    vmv2r.v v10, v8
4489 ; CHECK-NEXT:    vmv2r.v v12, v8
4490 ; CHECK-NEXT:    vmv2r.v v14, v8
4491 ; CHECK-NEXT:    vsetvli zero, a2, e32, m2, ta, ma
4492 ; CHECK-NEXT:    vssseg4e32.v v8, (a0), a1, v0.t
4493 ; CHECK-NEXT:    ret
4494 entry:
4495   tail call void @llvm.riscv.vssseg4.mask.nxv4f32(<vscale x 4 x float> %val,<vscale x 4 x float> %val,<vscale x 4 x float> %val,<vscale x 4 x float> %val, ptr %base, i64 %offset, <vscale x 4 x i1> %mask, i64 %vl)
4496   ret void