[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / CodeGen / RISCV / rvv / fixed-vectors-vrem-vp.ll
blob06635519898376c1ec74fa0a528eae8b2439b7d7
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -mtriple=riscv32 -mattr=+v -verify-machineinstrs < %s \
3 ; RUN:   | FileCheck %s --check-prefixes=CHECK,RV32
4 ; RUN: llc -mtriple=riscv64 -mattr=+v -verify-machineinstrs < %s \
5 ; RUN:   | FileCheck %s --check-prefixes=CHECK,RV64
7 declare <8 x i7> @llvm.vp.srem.v8i7(<8 x i7>, <8 x i7>, <8 x i1>, i32)
9 define <8 x i7> @vrem_vv_v8i7(<8 x i7> %va, <8 x i7> %b, <8 x i1> %m, i32 zeroext %evl) {
10 ; CHECK-LABEL: vrem_vv_v8i7:
11 ; CHECK:       # %bb.0:
12 ; CHECK-NEXT:    vsetivli zero, 8, e8, mf2, ta, ma
13 ; CHECK-NEXT:    vadd.vv v9, v9, v9
14 ; CHECK-NEXT:    vsra.vi v9, v9, 1
15 ; CHECK-NEXT:    vadd.vv v8, v8, v8
16 ; CHECK-NEXT:    vsra.vi v8, v8, 1
17 ; CHECK-NEXT:    vsetvli zero, a0, e8, mf2, ta, ma
18 ; CHECK-NEXT:    vrem.vv v8, v8, v9, v0.t
19 ; CHECK-NEXT:    ret
20   %v = call <8 x i7> @llvm.vp.srem.v8i7(<8 x i7> %va, <8 x i7> %b, <8 x i1> %m, i32 %evl)
21   ret <8 x i7> %v
24 declare <2 x i8> @llvm.vp.srem.v2i8(<2 x i8>, <2 x i8>, <2 x i1>, i32)
26 define <2 x i8> @vrem_vv_v2i8(<2 x i8> %va, <2 x i8> %b, <2 x i1> %m, i32 zeroext %evl) {
27 ; CHECK-LABEL: vrem_vv_v2i8:
28 ; CHECK:       # %bb.0:
29 ; CHECK-NEXT:    vsetvli zero, a0, e8, mf8, ta, ma
30 ; CHECK-NEXT:    vrem.vv v8, v8, v9, v0.t
31 ; CHECK-NEXT:    ret
32   %v = call <2 x i8> @llvm.vp.srem.v2i8(<2 x i8> %va, <2 x i8> %b, <2 x i1> %m, i32 %evl)
33   ret <2 x i8> %v
36 define <2 x i8> @vrem_vv_v2i8_unmasked(<2 x i8> %va, <2 x i8> %b, i32 zeroext %evl) {
37 ; CHECK-LABEL: vrem_vv_v2i8_unmasked:
38 ; CHECK:       # %bb.0:
39 ; CHECK-NEXT:    vsetvli zero, a0, e8, mf8, ta, ma
40 ; CHECK-NEXT:    vrem.vv v8, v8, v9
41 ; CHECK-NEXT:    ret
42   %head = insertelement <2 x i1> poison, i1 true, i32 0
43   %m = shufflevector <2 x i1> %head, <2 x i1> poison, <2 x i32> zeroinitializer
44   %v = call <2 x i8> @llvm.vp.srem.v2i8(<2 x i8> %va, <2 x i8> %b, <2 x i1> %m, i32 %evl)
45   ret <2 x i8> %v
48 define <2 x i8> @vrem_vx_v2i8(<2 x i8> %va, i8 %b, <2 x i1> %m, i32 zeroext %evl) {
49 ; CHECK-LABEL: vrem_vx_v2i8:
50 ; CHECK:       # %bb.0:
51 ; CHECK-NEXT:    vsetvli zero, a1, e8, mf8, ta, ma
52 ; CHECK-NEXT:    vrem.vx v8, v8, a0, v0.t
53 ; CHECK-NEXT:    ret
54   %elt.head = insertelement <2 x i8> poison, i8 %b, i32 0
55   %vb = shufflevector <2 x i8> %elt.head, <2 x i8> poison, <2 x i32> zeroinitializer
56   %v = call <2 x i8> @llvm.vp.srem.v2i8(<2 x i8> %va, <2 x i8> %vb, <2 x i1> %m, i32 %evl)
57   ret <2 x i8> %v
60 define <2 x i8> @vrem_vx_v2i8_unmasked(<2 x i8> %va, i8 %b, i32 zeroext %evl) {
61 ; CHECK-LABEL: vrem_vx_v2i8_unmasked:
62 ; CHECK:       # %bb.0:
63 ; CHECK-NEXT:    vsetvli zero, a1, e8, mf8, ta, ma
64 ; CHECK-NEXT:    vrem.vx v8, v8, a0
65 ; CHECK-NEXT:    ret
66   %elt.head = insertelement <2 x i8> poison, i8 %b, i32 0
67   %vb = shufflevector <2 x i8> %elt.head, <2 x i8> poison, <2 x i32> zeroinitializer
68   %head = insertelement <2 x i1> poison, i1 true, i32 0
69   %m = shufflevector <2 x i1> %head, <2 x i1> poison, <2 x i32> zeroinitializer
70   %v = call <2 x i8> @llvm.vp.srem.v2i8(<2 x i8> %va, <2 x i8> %vb, <2 x i1> %m, i32 %evl)
71   ret <2 x i8> %v
74 declare <4 x i8> @llvm.vp.srem.v4i8(<4 x i8>, <4 x i8>, <4 x i1>, i32)
76 define <4 x i8> @vrem_vv_v4i8(<4 x i8> %va, <4 x i8> %b, <4 x i1> %m, i32 zeroext %evl) {
77 ; CHECK-LABEL: vrem_vv_v4i8:
78 ; CHECK:       # %bb.0:
79 ; CHECK-NEXT:    vsetvli zero, a0, e8, mf4, ta, ma
80 ; CHECK-NEXT:    vrem.vv v8, v8, v9, v0.t
81 ; CHECK-NEXT:    ret
82   %v = call <4 x i8> @llvm.vp.srem.v4i8(<4 x i8> %va, <4 x i8> %b, <4 x i1> %m, i32 %evl)
83   ret <4 x i8> %v
86 define <4 x i8> @vrem_vv_v4i8_unmasked(<4 x i8> %va, <4 x i8> %b, i32 zeroext %evl) {
87 ; CHECK-LABEL: vrem_vv_v4i8_unmasked:
88 ; CHECK:       # %bb.0:
89 ; CHECK-NEXT:    vsetvli zero, a0, e8, mf4, ta, ma
90 ; CHECK-NEXT:    vrem.vv v8, v8, v9
91 ; CHECK-NEXT:    ret
92   %head = insertelement <4 x i1> poison, i1 true, i32 0
93   %m = shufflevector <4 x i1> %head, <4 x i1> poison, <4 x i32> zeroinitializer
94   %v = call <4 x i8> @llvm.vp.srem.v4i8(<4 x i8> %va, <4 x i8> %b, <4 x i1> %m, i32 %evl)
95   ret <4 x i8> %v
98 define <4 x i8> @vrem_vx_v4i8(<4 x i8> %va, i8 %b, <4 x i1> %m, i32 zeroext %evl) {
99 ; CHECK-LABEL: vrem_vx_v4i8:
100 ; CHECK:       # %bb.0:
101 ; CHECK-NEXT:    vsetvli zero, a1, e8, mf4, ta, ma
102 ; CHECK-NEXT:    vrem.vx v8, v8, a0, v0.t
103 ; CHECK-NEXT:    ret
104   %elt.head = insertelement <4 x i8> poison, i8 %b, i32 0
105   %vb = shufflevector <4 x i8> %elt.head, <4 x i8> poison, <4 x i32> zeroinitializer
106   %v = call <4 x i8> @llvm.vp.srem.v4i8(<4 x i8> %va, <4 x i8> %vb, <4 x i1> %m, i32 %evl)
107   ret <4 x i8> %v
110 define <4 x i8> @vrem_vx_v4i8_unmasked(<4 x i8> %va, i8 %b, i32 zeroext %evl) {
111 ; CHECK-LABEL: vrem_vx_v4i8_unmasked:
112 ; CHECK:       # %bb.0:
113 ; CHECK-NEXT:    vsetvli zero, a1, e8, mf4, ta, ma
114 ; CHECK-NEXT:    vrem.vx v8, v8, a0
115 ; CHECK-NEXT:    ret
116   %elt.head = insertelement <4 x i8> poison, i8 %b, i32 0
117   %vb = shufflevector <4 x i8> %elt.head, <4 x i8> poison, <4 x i32> zeroinitializer
118   %head = insertelement <4 x i1> poison, i1 true, i32 0
119   %m = shufflevector <4 x i1> %head, <4 x i1> poison, <4 x i32> zeroinitializer
120   %v = call <4 x i8> @llvm.vp.srem.v4i8(<4 x i8> %va, <4 x i8> %vb, <4 x i1> %m, i32 %evl)
121   ret <4 x i8> %v
124 declare <6 x i8> @llvm.vp.srem.v6i8(<6 x i8>, <6 x i8>, <6 x i1>, i32)
126 define <6 x i8> @vrem_vv_v6i8(<6 x i8> %va, <6 x i8> %b, <6 x i1> %m, i32 zeroext %evl) {
127 ; CHECK-LABEL: vrem_vv_v6i8:
128 ; CHECK:       # %bb.0:
129 ; CHECK-NEXT:    vsetvli zero, a0, e8, mf2, ta, ma
130 ; CHECK-NEXT:    vrem.vv v8, v8, v9, v0.t
131 ; CHECK-NEXT:    ret
132   %v = call <6 x i8> @llvm.vp.srem.v6i8(<6 x i8> %va, <6 x i8> %b, <6 x i1> %m, i32 %evl)
133   ret <6 x i8> %v
136 declare <8 x i8> @llvm.vp.srem.v8i8(<8 x i8>, <8 x i8>, <8 x i1>, i32)
138 define <8 x i8> @vrem_vv_v8i8(<8 x i8> %va, <8 x i8> %b, <8 x i1> %m, i32 zeroext %evl) {
139 ; CHECK-LABEL: vrem_vv_v8i8:
140 ; CHECK:       # %bb.0:
141 ; CHECK-NEXT:    vsetvli zero, a0, e8, mf2, ta, ma
142 ; CHECK-NEXT:    vrem.vv v8, v8, v9, v0.t
143 ; CHECK-NEXT:    ret
144   %v = call <8 x i8> @llvm.vp.srem.v8i8(<8 x i8> %va, <8 x i8> %b, <8 x i1> %m, i32 %evl)
145   ret <8 x i8> %v
148 define <8 x i8> @vrem_vv_v8i8_unmasked(<8 x i8> %va, <8 x i8> %b, i32 zeroext %evl) {
149 ; CHECK-LABEL: vrem_vv_v8i8_unmasked:
150 ; CHECK:       # %bb.0:
151 ; CHECK-NEXT:    vsetvli zero, a0, e8, mf2, ta, ma
152 ; CHECK-NEXT:    vrem.vv v8, v8, v9
153 ; CHECK-NEXT:    ret
154   %head = insertelement <8 x i1> poison, i1 true, i32 0
155   %m = shufflevector <8 x i1> %head, <8 x i1> poison, <8 x i32> zeroinitializer
156   %v = call <8 x i8> @llvm.vp.srem.v8i8(<8 x i8> %va, <8 x i8> %b, <8 x i1> %m, i32 %evl)
157   ret <8 x i8> %v
160 define <8 x i8> @vrem_vx_v8i8(<8 x i8> %va, i8 %b, <8 x i1> %m, i32 zeroext %evl) {
161 ; CHECK-LABEL: vrem_vx_v8i8:
162 ; CHECK:       # %bb.0:
163 ; CHECK-NEXT:    vsetvli zero, a1, e8, mf2, ta, ma
164 ; CHECK-NEXT:    vrem.vx v8, v8, a0, v0.t
165 ; CHECK-NEXT:    ret
166   %elt.head = insertelement <8 x i8> poison, i8 %b, i32 0
167   %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer
168   %v = call <8 x i8> @llvm.vp.srem.v8i8(<8 x i8> %va, <8 x i8> %vb, <8 x i1> %m, i32 %evl)
169   ret <8 x i8> %v
172 define <8 x i8> @vrem_vx_v8i8_unmasked(<8 x i8> %va, i8 %b, i32 zeroext %evl) {
173 ; CHECK-LABEL: vrem_vx_v8i8_unmasked:
174 ; CHECK:       # %bb.0:
175 ; CHECK-NEXT:    vsetvli zero, a1, e8, mf2, ta, ma
176 ; CHECK-NEXT:    vrem.vx v8, v8, a0
177 ; CHECK-NEXT:    ret
178   %elt.head = insertelement <8 x i8> poison, i8 %b, i32 0
179   %vb = shufflevector <8 x i8> %elt.head, <8 x i8> poison, <8 x i32> zeroinitializer
180   %head = insertelement <8 x i1> poison, i1 true, i32 0
181   %m = shufflevector <8 x i1> %head, <8 x i1> poison, <8 x i32> zeroinitializer
182   %v = call <8 x i8> @llvm.vp.srem.v8i8(<8 x i8> %va, <8 x i8> %vb, <8 x i1> %m, i32 %evl)
183   ret <8 x i8> %v
186 declare <16 x i8> @llvm.vp.srem.v16i8(<16 x i8>, <16 x i8>, <16 x i1>, i32)
188 define <16 x i8> @vrem_vv_v16i8(<16 x i8> %va, <16 x i8> %b, <16 x i1> %m, i32 zeroext %evl) {
189 ; CHECK-LABEL: vrem_vv_v16i8:
190 ; CHECK:       # %bb.0:
191 ; CHECK-NEXT:    vsetvli zero, a0, e8, m1, ta, ma
192 ; CHECK-NEXT:    vrem.vv v8, v8, v9, v0.t
193 ; CHECK-NEXT:    ret
194   %v = call <16 x i8> @llvm.vp.srem.v16i8(<16 x i8> %va, <16 x i8> %b, <16 x i1> %m, i32 %evl)
195   ret <16 x i8> %v
198 define <16 x i8> @vrem_vv_v16i8_unmasked(<16 x i8> %va, <16 x i8> %b, i32 zeroext %evl) {
199 ; CHECK-LABEL: vrem_vv_v16i8_unmasked:
200 ; CHECK:       # %bb.0:
201 ; CHECK-NEXT:    vsetvli zero, a0, e8, m1, ta, ma
202 ; CHECK-NEXT:    vrem.vv v8, v8, v9
203 ; CHECK-NEXT:    ret
204   %head = insertelement <16 x i1> poison, i1 true, i32 0
205   %m = shufflevector <16 x i1> %head, <16 x i1> poison, <16 x i32> zeroinitializer
206   %v = call <16 x i8> @llvm.vp.srem.v16i8(<16 x i8> %va, <16 x i8> %b, <16 x i1> %m, i32 %evl)
207   ret <16 x i8> %v
210 define <16 x i8> @vrem_vx_v16i8(<16 x i8> %va, i8 %b, <16 x i1> %m, i32 zeroext %evl) {
211 ; CHECK-LABEL: vrem_vx_v16i8:
212 ; CHECK:       # %bb.0:
213 ; CHECK-NEXT:    vsetvli zero, a1, e8, m1, ta, ma
214 ; CHECK-NEXT:    vrem.vx v8, v8, a0, v0.t
215 ; CHECK-NEXT:    ret
216   %elt.head = insertelement <16 x i8> poison, i8 %b, i32 0
217   %vb = shufflevector <16 x i8> %elt.head, <16 x i8> poison, <16 x i32> zeroinitializer
218   %v = call <16 x i8> @llvm.vp.srem.v16i8(<16 x i8> %va, <16 x i8> %vb, <16 x i1> %m, i32 %evl)
219   ret <16 x i8> %v
222 define <16 x i8> @vrem_vx_v16i8_unmasked(<16 x i8> %va, i8 %b, i32 zeroext %evl) {
223 ; CHECK-LABEL: vrem_vx_v16i8_unmasked:
224 ; CHECK:       # %bb.0:
225 ; CHECK-NEXT:    vsetvli zero, a1, e8, m1, ta, ma
226 ; CHECK-NEXT:    vrem.vx v8, v8, a0
227 ; CHECK-NEXT:    ret
228   %elt.head = insertelement <16 x i8> poison, i8 %b, i32 0
229   %vb = shufflevector <16 x i8> %elt.head, <16 x i8> poison, <16 x i32> zeroinitializer
230   %head = insertelement <16 x i1> poison, i1 true, i32 0
231   %m = shufflevector <16 x i1> %head, <16 x i1> poison, <16 x i32> zeroinitializer
232   %v = call <16 x i8> @llvm.vp.srem.v16i8(<16 x i8> %va, <16 x i8> %vb, <16 x i1> %m, i32 %evl)
233   ret <16 x i8> %v
236 declare <2 x i16> @llvm.vp.srem.v2i16(<2 x i16>, <2 x i16>, <2 x i1>, i32)
238 define <2 x i16> @vrem_vv_v2i16(<2 x i16> %va, <2 x i16> %b, <2 x i1> %m, i32 zeroext %evl) {
239 ; CHECK-LABEL: vrem_vv_v2i16:
240 ; CHECK:       # %bb.0:
241 ; CHECK-NEXT:    vsetvli zero, a0, e16, mf4, ta, ma
242 ; CHECK-NEXT:    vrem.vv v8, v8, v9, v0.t
243 ; CHECK-NEXT:    ret
244   %v = call <2 x i16> @llvm.vp.srem.v2i16(<2 x i16> %va, <2 x i16> %b, <2 x i1> %m, i32 %evl)
245   ret <2 x i16> %v
248 define <2 x i16> @vrem_vv_v2i16_unmasked(<2 x i16> %va, <2 x i16> %b, i32 zeroext %evl) {
249 ; CHECK-LABEL: vrem_vv_v2i16_unmasked:
250 ; CHECK:       # %bb.0:
251 ; CHECK-NEXT:    vsetvli zero, a0, e16, mf4, ta, ma
252 ; CHECK-NEXT:    vrem.vv v8, v8, v9
253 ; CHECK-NEXT:    ret
254   %head = insertelement <2 x i1> poison, i1 true, i32 0
255   %m = shufflevector <2 x i1> %head, <2 x i1> poison, <2 x i32> zeroinitializer
256   %v = call <2 x i16> @llvm.vp.srem.v2i16(<2 x i16> %va, <2 x i16> %b, <2 x i1> %m, i32 %evl)
257   ret <2 x i16> %v
260 define <2 x i16> @vrem_vx_v2i16(<2 x i16> %va, i16 %b, <2 x i1> %m, i32 zeroext %evl) {
261 ; CHECK-LABEL: vrem_vx_v2i16:
262 ; CHECK:       # %bb.0:
263 ; CHECK-NEXT:    vsetvli zero, a1, e16, mf4, ta, ma
264 ; CHECK-NEXT:    vrem.vx v8, v8, a0, v0.t
265 ; CHECK-NEXT:    ret
266   %elt.head = insertelement <2 x i16> poison, i16 %b, i32 0
267   %vb = shufflevector <2 x i16> %elt.head, <2 x i16> poison, <2 x i32> zeroinitializer
268   %v = call <2 x i16> @llvm.vp.srem.v2i16(<2 x i16> %va, <2 x i16> %vb, <2 x i1> %m, i32 %evl)
269   ret <2 x i16> %v
272 define <2 x i16> @vrem_vx_v2i16_unmasked(<2 x i16> %va, i16 %b, i32 zeroext %evl) {
273 ; CHECK-LABEL: vrem_vx_v2i16_unmasked:
274 ; CHECK:       # %bb.0:
275 ; CHECK-NEXT:    vsetvli zero, a1, e16, mf4, ta, ma
276 ; CHECK-NEXT:    vrem.vx v8, v8, a0
277 ; CHECK-NEXT:    ret
278   %elt.head = insertelement <2 x i16> poison, i16 %b, i32 0
279   %vb = shufflevector <2 x i16> %elt.head, <2 x i16> poison, <2 x i32> zeroinitializer
280   %head = insertelement <2 x i1> poison, i1 true, i32 0
281   %m = shufflevector <2 x i1> %head, <2 x i1> poison, <2 x i32> zeroinitializer
282   %v = call <2 x i16> @llvm.vp.srem.v2i16(<2 x i16> %va, <2 x i16> %vb, <2 x i1> %m, i32 %evl)
283   ret <2 x i16> %v
286 declare <4 x i16> @llvm.vp.srem.v4i16(<4 x i16>, <4 x i16>, <4 x i1>, i32)
288 define <4 x i16> @vrem_vv_v4i16(<4 x i16> %va, <4 x i16> %b, <4 x i1> %m, i32 zeroext %evl) {
289 ; CHECK-LABEL: vrem_vv_v4i16:
290 ; CHECK:       # %bb.0:
291 ; CHECK-NEXT:    vsetvli zero, a0, e16, mf2, ta, ma
292 ; CHECK-NEXT:    vrem.vv v8, v8, v9, v0.t
293 ; CHECK-NEXT:    ret
294   %v = call <4 x i16> @llvm.vp.srem.v4i16(<4 x i16> %va, <4 x i16> %b, <4 x i1> %m, i32 %evl)
295   ret <4 x i16> %v
298 define <4 x i16> @vrem_vv_v4i16_unmasked(<4 x i16> %va, <4 x i16> %b, i32 zeroext %evl) {
299 ; CHECK-LABEL: vrem_vv_v4i16_unmasked:
300 ; CHECK:       # %bb.0:
301 ; CHECK-NEXT:    vsetvli zero, a0, e16, mf2, ta, ma
302 ; CHECK-NEXT:    vrem.vv v8, v8, v9
303 ; CHECK-NEXT:    ret
304   %head = insertelement <4 x i1> poison, i1 true, i32 0
305   %m = shufflevector <4 x i1> %head, <4 x i1> poison, <4 x i32> zeroinitializer
306   %v = call <4 x i16> @llvm.vp.srem.v4i16(<4 x i16> %va, <4 x i16> %b, <4 x i1> %m, i32 %evl)
307   ret <4 x i16> %v
310 define <4 x i16> @vrem_vx_v4i16(<4 x i16> %va, i16 %b, <4 x i1> %m, i32 zeroext %evl) {
311 ; CHECK-LABEL: vrem_vx_v4i16:
312 ; CHECK:       # %bb.0:
313 ; CHECK-NEXT:    vsetvli zero, a1, e16, mf2, ta, ma
314 ; CHECK-NEXT:    vrem.vx v8, v8, a0, v0.t
315 ; CHECK-NEXT:    ret
316   %elt.head = insertelement <4 x i16> poison, i16 %b, i32 0
317   %vb = shufflevector <4 x i16> %elt.head, <4 x i16> poison, <4 x i32> zeroinitializer
318   %v = call <4 x i16> @llvm.vp.srem.v4i16(<4 x i16> %va, <4 x i16> %vb, <4 x i1> %m, i32 %evl)
319   ret <4 x i16> %v
322 define <4 x i16> @vrem_vx_v4i16_unmasked(<4 x i16> %va, i16 %b, i32 zeroext %evl) {
323 ; CHECK-LABEL: vrem_vx_v4i16_unmasked:
324 ; CHECK:       # %bb.0:
325 ; CHECK-NEXT:    vsetvli zero, a1, e16, mf2, ta, ma
326 ; CHECK-NEXT:    vrem.vx v8, v8, a0
327 ; CHECK-NEXT:    ret
328   %elt.head = insertelement <4 x i16> poison, i16 %b, i32 0
329   %vb = shufflevector <4 x i16> %elt.head, <4 x i16> poison, <4 x i32> zeroinitializer
330   %head = insertelement <4 x i1> poison, i1 true, i32 0
331   %m = shufflevector <4 x i1> %head, <4 x i1> poison, <4 x i32> zeroinitializer
332   %v = call <4 x i16> @llvm.vp.srem.v4i16(<4 x i16> %va, <4 x i16> %vb, <4 x i1> %m, i32 %evl)
333   ret <4 x i16> %v
336 declare <8 x i16> @llvm.vp.srem.v8i16(<8 x i16>, <8 x i16>, <8 x i1>, i32)
338 define <8 x i16> @vrem_vv_v8i16(<8 x i16> %va, <8 x i16> %b, <8 x i1> %m, i32 zeroext %evl) {
339 ; CHECK-LABEL: vrem_vv_v8i16:
340 ; CHECK:       # %bb.0:
341 ; CHECK-NEXT:    vsetvli zero, a0, e16, m1, ta, ma
342 ; CHECK-NEXT:    vrem.vv v8, v8, v9, v0.t
343 ; CHECK-NEXT:    ret
344   %v = call <8 x i16> @llvm.vp.srem.v8i16(<8 x i16> %va, <8 x i16> %b, <8 x i1> %m, i32 %evl)
345   ret <8 x i16> %v
348 define <8 x i16> @vrem_vv_v8i16_unmasked(<8 x i16> %va, <8 x i16> %b, i32 zeroext %evl) {
349 ; CHECK-LABEL: vrem_vv_v8i16_unmasked:
350 ; CHECK:       # %bb.0:
351 ; CHECK-NEXT:    vsetvli zero, a0, e16, m1, ta, ma
352 ; CHECK-NEXT:    vrem.vv v8, v8, v9
353 ; CHECK-NEXT:    ret
354   %head = insertelement <8 x i1> poison, i1 true, i32 0
355   %m = shufflevector <8 x i1> %head, <8 x i1> poison, <8 x i32> zeroinitializer
356   %v = call <8 x i16> @llvm.vp.srem.v8i16(<8 x i16> %va, <8 x i16> %b, <8 x i1> %m, i32 %evl)
357   ret <8 x i16> %v
360 define <8 x i16> @vrem_vx_v8i16(<8 x i16> %va, i16 %b, <8 x i1> %m, i32 zeroext %evl) {
361 ; CHECK-LABEL: vrem_vx_v8i16:
362 ; CHECK:       # %bb.0:
363 ; CHECK-NEXT:    vsetvli zero, a1, e16, m1, ta, ma
364 ; CHECK-NEXT:    vrem.vx v8, v8, a0, v0.t
365 ; CHECK-NEXT:    ret
366   %elt.head = insertelement <8 x i16> poison, i16 %b, i32 0
367   %vb = shufflevector <8 x i16> %elt.head, <8 x i16> poison, <8 x i32> zeroinitializer
368   %v = call <8 x i16> @llvm.vp.srem.v8i16(<8 x i16> %va, <8 x i16> %vb, <8 x i1> %m, i32 %evl)
369   ret <8 x i16> %v
372 define <8 x i16> @vrem_vx_v8i16_unmasked(<8 x i16> %va, i16 %b, i32 zeroext %evl) {
373 ; CHECK-LABEL: vrem_vx_v8i16_unmasked:
374 ; CHECK:       # %bb.0:
375 ; CHECK-NEXT:    vsetvli zero, a1, e16, m1, ta, ma
376 ; CHECK-NEXT:    vrem.vx v8, v8, a0
377 ; CHECK-NEXT:    ret
378   %elt.head = insertelement <8 x i16> poison, i16 %b, i32 0
379   %vb = shufflevector <8 x i16> %elt.head, <8 x i16> poison, <8 x i32> zeroinitializer
380   %head = insertelement <8 x i1> poison, i1 true, i32 0
381   %m = shufflevector <8 x i1> %head, <8 x i1> poison, <8 x i32> zeroinitializer
382   %v = call <8 x i16> @llvm.vp.srem.v8i16(<8 x i16> %va, <8 x i16> %vb, <8 x i1> %m, i32 %evl)
383   ret <8 x i16> %v
386 declare <16 x i16> @llvm.vp.srem.v16i16(<16 x i16>, <16 x i16>, <16 x i1>, i32)
388 define <16 x i16> @vrem_vv_v16i16(<16 x i16> %va, <16 x i16> %b, <16 x i1> %m, i32 zeroext %evl) {
389 ; CHECK-LABEL: vrem_vv_v16i16:
390 ; CHECK:       # %bb.0:
391 ; CHECK-NEXT:    vsetvli zero, a0, e16, m2, ta, ma
392 ; CHECK-NEXT:    vrem.vv v8, v8, v10, v0.t
393 ; CHECK-NEXT:    ret
394   %v = call <16 x i16> @llvm.vp.srem.v16i16(<16 x i16> %va, <16 x i16> %b, <16 x i1> %m, i32 %evl)
395   ret <16 x i16> %v
398 define <16 x i16> @vrem_vv_v16i16_unmasked(<16 x i16> %va, <16 x i16> %b, i32 zeroext %evl) {
399 ; CHECK-LABEL: vrem_vv_v16i16_unmasked:
400 ; CHECK:       # %bb.0:
401 ; CHECK-NEXT:    vsetvli zero, a0, e16, m2, ta, ma
402 ; CHECK-NEXT:    vrem.vv v8, v8, v10
403 ; CHECK-NEXT:    ret
404   %head = insertelement <16 x i1> poison, i1 true, i32 0
405   %m = shufflevector <16 x i1> %head, <16 x i1> poison, <16 x i32> zeroinitializer
406   %v = call <16 x i16> @llvm.vp.srem.v16i16(<16 x i16> %va, <16 x i16> %b, <16 x i1> %m, i32 %evl)
407   ret <16 x i16> %v
410 define <16 x i16> @vrem_vx_v16i16(<16 x i16> %va, i16 %b, <16 x i1> %m, i32 zeroext %evl) {
411 ; CHECK-LABEL: vrem_vx_v16i16:
412 ; CHECK:       # %bb.0:
413 ; CHECK-NEXT:    vsetvli zero, a1, e16, m2, ta, ma
414 ; CHECK-NEXT:    vrem.vx v8, v8, a0, v0.t
415 ; CHECK-NEXT:    ret
416   %elt.head = insertelement <16 x i16> poison, i16 %b, i32 0
417   %vb = shufflevector <16 x i16> %elt.head, <16 x i16> poison, <16 x i32> zeroinitializer
418   %v = call <16 x i16> @llvm.vp.srem.v16i16(<16 x i16> %va, <16 x i16> %vb, <16 x i1> %m, i32 %evl)
419   ret <16 x i16> %v
422 define <16 x i16> @vrem_vx_v16i16_unmasked(<16 x i16> %va, i16 %b, i32 zeroext %evl) {
423 ; CHECK-LABEL: vrem_vx_v16i16_unmasked:
424 ; CHECK:       # %bb.0:
425 ; CHECK-NEXT:    vsetvli zero, a1, e16, m2, ta, ma
426 ; CHECK-NEXT:    vrem.vx v8, v8, a0
427 ; CHECK-NEXT:    ret
428   %elt.head = insertelement <16 x i16> poison, i16 %b, i32 0
429   %vb = shufflevector <16 x i16> %elt.head, <16 x i16> poison, <16 x i32> zeroinitializer
430   %head = insertelement <16 x i1> poison, i1 true, i32 0
431   %m = shufflevector <16 x i1> %head, <16 x i1> poison, <16 x i32> zeroinitializer
432   %v = call <16 x i16> @llvm.vp.srem.v16i16(<16 x i16> %va, <16 x i16> %vb, <16 x i1> %m, i32 %evl)
433   ret <16 x i16> %v
436 declare <2 x i32> @llvm.vp.srem.v2i32(<2 x i32>, <2 x i32>, <2 x i1>, i32)
438 define <2 x i32> @vrem_vv_v2i32(<2 x i32> %va, <2 x i32> %b, <2 x i1> %m, i32 zeroext %evl) {
439 ; CHECK-LABEL: vrem_vv_v2i32:
440 ; CHECK:       # %bb.0:
441 ; CHECK-NEXT:    vsetvli zero, a0, e32, mf2, ta, ma
442 ; CHECK-NEXT:    vrem.vv v8, v8, v9, v0.t
443 ; CHECK-NEXT:    ret
444   %v = call <2 x i32> @llvm.vp.srem.v2i32(<2 x i32> %va, <2 x i32> %b, <2 x i1> %m, i32 %evl)
445   ret <2 x i32> %v
448 define <2 x i32> @vrem_vv_v2i32_unmasked(<2 x i32> %va, <2 x i32> %b, i32 zeroext %evl) {
449 ; CHECK-LABEL: vrem_vv_v2i32_unmasked:
450 ; CHECK:       # %bb.0:
451 ; CHECK-NEXT:    vsetvli zero, a0, e32, mf2, ta, ma
452 ; CHECK-NEXT:    vrem.vv v8, v8, v9
453 ; CHECK-NEXT:    ret
454   %head = insertelement <2 x i1> poison, i1 true, i32 0
455   %m = shufflevector <2 x i1> %head, <2 x i1> poison, <2 x i32> zeroinitializer
456   %v = call <2 x i32> @llvm.vp.srem.v2i32(<2 x i32> %va, <2 x i32> %b, <2 x i1> %m, i32 %evl)
457   ret <2 x i32> %v
460 define <2 x i32> @vrem_vx_v2i32(<2 x i32> %va, i32 %b, <2 x i1> %m, i32 zeroext %evl) {
461 ; CHECK-LABEL: vrem_vx_v2i32:
462 ; CHECK:       # %bb.0:
463 ; CHECK-NEXT:    vsetvli zero, a1, e32, mf2, ta, ma
464 ; CHECK-NEXT:    vrem.vx v8, v8, a0, v0.t
465 ; CHECK-NEXT:    ret
466   %elt.head = insertelement <2 x i32> poison, i32 %b, i32 0
467   %vb = shufflevector <2 x i32> %elt.head, <2 x i32> poison, <2 x i32> zeroinitializer
468   %v = call <2 x i32> @llvm.vp.srem.v2i32(<2 x i32> %va, <2 x i32> %vb, <2 x i1> %m, i32 %evl)
469   ret <2 x i32> %v
472 define <2 x i32> @vrem_vx_v2i32_unmasked(<2 x i32> %va, i32 %b, i32 zeroext %evl) {
473 ; CHECK-LABEL: vrem_vx_v2i32_unmasked:
474 ; CHECK:       # %bb.0:
475 ; CHECK-NEXT:    vsetvli zero, a1, e32, mf2, ta, ma
476 ; CHECK-NEXT:    vrem.vx v8, v8, a0
477 ; CHECK-NEXT:    ret
478   %elt.head = insertelement <2 x i32> poison, i32 %b, i32 0
479   %vb = shufflevector <2 x i32> %elt.head, <2 x i32> poison, <2 x i32> zeroinitializer
480   %head = insertelement <2 x i1> poison, i1 true, i32 0
481   %m = shufflevector <2 x i1> %head, <2 x i1> poison, <2 x i32> zeroinitializer
482   %v = call <2 x i32> @llvm.vp.srem.v2i32(<2 x i32> %va, <2 x i32> %vb, <2 x i1> %m, i32 %evl)
483   ret <2 x i32> %v
486 declare <4 x i32> @llvm.vp.srem.v4i32(<4 x i32>, <4 x i32>, <4 x i1>, i32)
488 define <4 x i32> @vrem_vv_v4i32(<4 x i32> %va, <4 x i32> %b, <4 x i1> %m, i32 zeroext %evl) {
489 ; CHECK-LABEL: vrem_vv_v4i32:
490 ; CHECK:       # %bb.0:
491 ; CHECK-NEXT:    vsetvli zero, a0, e32, m1, ta, ma
492 ; CHECK-NEXT:    vrem.vv v8, v8, v9, v0.t
493 ; CHECK-NEXT:    ret
494   %v = call <4 x i32> @llvm.vp.srem.v4i32(<4 x i32> %va, <4 x i32> %b, <4 x i1> %m, i32 %evl)
495   ret <4 x i32> %v
498 define <4 x i32> @vrem_vv_v4i32_unmasked(<4 x i32> %va, <4 x i32> %b, i32 zeroext %evl) {
499 ; CHECK-LABEL: vrem_vv_v4i32_unmasked:
500 ; CHECK:       # %bb.0:
501 ; CHECK-NEXT:    vsetvli zero, a0, e32, m1, ta, ma
502 ; CHECK-NEXT:    vrem.vv v8, v8, v9
503 ; CHECK-NEXT:    ret
504   %head = insertelement <4 x i1> poison, i1 true, i32 0
505   %m = shufflevector <4 x i1> %head, <4 x i1> poison, <4 x i32> zeroinitializer
506   %v = call <4 x i32> @llvm.vp.srem.v4i32(<4 x i32> %va, <4 x i32> %b, <4 x i1> %m, i32 %evl)
507   ret <4 x i32> %v
510 define <4 x i32> @vrem_vx_v4i32(<4 x i32> %va, i32 %b, <4 x i1> %m, i32 zeroext %evl) {
511 ; CHECK-LABEL: vrem_vx_v4i32:
512 ; CHECK:       # %bb.0:
513 ; CHECK-NEXT:    vsetvli zero, a1, e32, m1, ta, ma
514 ; CHECK-NEXT:    vrem.vx v8, v8, a0, v0.t
515 ; CHECK-NEXT:    ret
516   %elt.head = insertelement <4 x i32> poison, i32 %b, i32 0
517   %vb = shufflevector <4 x i32> %elt.head, <4 x i32> poison, <4 x i32> zeroinitializer
518   %v = call <4 x i32> @llvm.vp.srem.v4i32(<4 x i32> %va, <4 x i32> %vb, <4 x i1> %m, i32 %evl)
519   ret <4 x i32> %v
522 define <4 x i32> @vrem_vx_v4i32_unmasked(<4 x i32> %va, i32 %b, i32 zeroext %evl) {
523 ; CHECK-LABEL: vrem_vx_v4i32_unmasked:
524 ; CHECK:       # %bb.0:
525 ; CHECK-NEXT:    vsetvli zero, a1, e32, m1, ta, ma
526 ; CHECK-NEXT:    vrem.vx v8, v8, a0
527 ; CHECK-NEXT:    ret
528   %elt.head = insertelement <4 x i32> poison, i32 %b, i32 0
529   %vb = shufflevector <4 x i32> %elt.head, <4 x i32> poison, <4 x i32> zeroinitializer
530   %head = insertelement <4 x i1> poison, i1 true, i32 0
531   %m = shufflevector <4 x i1> %head, <4 x i1> poison, <4 x i32> zeroinitializer
532   %v = call <4 x i32> @llvm.vp.srem.v4i32(<4 x i32> %va, <4 x i32> %vb, <4 x i1> %m, i32 %evl)
533   ret <4 x i32> %v
536 declare <8 x i32> @llvm.vp.srem.v8i32(<8 x i32>, <8 x i32>, <8 x i1>, i32)
538 define <8 x i32> @vrem_vv_v8i32(<8 x i32> %va, <8 x i32> %b, <8 x i1> %m, i32 zeroext %evl) {
539 ; CHECK-LABEL: vrem_vv_v8i32:
540 ; CHECK:       # %bb.0:
541 ; CHECK-NEXT:    vsetvli zero, a0, e32, m2, ta, ma
542 ; CHECK-NEXT:    vrem.vv v8, v8, v10, v0.t
543 ; CHECK-NEXT:    ret
544   %v = call <8 x i32> @llvm.vp.srem.v8i32(<8 x i32> %va, <8 x i32> %b, <8 x i1> %m, i32 %evl)
545   ret <8 x i32> %v
548 define <8 x i32> @vrem_vv_v8i32_unmasked(<8 x i32> %va, <8 x i32> %b, i32 zeroext %evl) {
549 ; CHECK-LABEL: vrem_vv_v8i32_unmasked:
550 ; CHECK:       # %bb.0:
551 ; CHECK-NEXT:    vsetvli zero, a0, e32, m2, ta, ma
552 ; CHECK-NEXT:    vrem.vv v8, v8, v10
553 ; CHECK-NEXT:    ret
554   %head = insertelement <8 x i1> poison, i1 true, i32 0
555   %m = shufflevector <8 x i1> %head, <8 x i1> poison, <8 x i32> zeroinitializer
556   %v = call <8 x i32> @llvm.vp.srem.v8i32(<8 x i32> %va, <8 x i32> %b, <8 x i1> %m, i32 %evl)
557   ret <8 x i32> %v
560 define <8 x i32> @vrem_vx_v8i32(<8 x i32> %va, i32 %b, <8 x i1> %m, i32 zeroext %evl) {
561 ; CHECK-LABEL: vrem_vx_v8i32:
562 ; CHECK:       # %bb.0:
563 ; CHECK-NEXT:    vsetvli zero, a1, e32, m2, ta, ma
564 ; CHECK-NEXT:    vrem.vx v8, v8, a0, v0.t
565 ; CHECK-NEXT:    ret
566   %elt.head = insertelement <8 x i32> poison, i32 %b, i32 0
567   %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer
568   %v = call <8 x i32> @llvm.vp.srem.v8i32(<8 x i32> %va, <8 x i32> %vb, <8 x i1> %m, i32 %evl)
569   ret <8 x i32> %v
572 define <8 x i32> @vrem_vx_v8i32_unmasked(<8 x i32> %va, i32 %b, i32 zeroext %evl) {
573 ; CHECK-LABEL: vrem_vx_v8i32_unmasked:
574 ; CHECK:       # %bb.0:
575 ; CHECK-NEXT:    vsetvli zero, a1, e32, m2, ta, ma
576 ; CHECK-NEXT:    vrem.vx v8, v8, a0
577 ; CHECK-NEXT:    ret
578   %elt.head = insertelement <8 x i32> poison, i32 %b, i32 0
579   %vb = shufflevector <8 x i32> %elt.head, <8 x i32> poison, <8 x i32> zeroinitializer
580   %head = insertelement <8 x i1> poison, i1 true, i32 0
581   %m = shufflevector <8 x i1> %head, <8 x i1> poison, <8 x i32> zeroinitializer
582   %v = call <8 x i32> @llvm.vp.srem.v8i32(<8 x i32> %va, <8 x i32> %vb, <8 x i1> %m, i32 %evl)
583   ret <8 x i32> %v
586 declare <16 x i32> @llvm.vp.srem.v16i32(<16 x i32>, <16 x i32>, <16 x i1>, i32)
588 define <16 x i32> @vrem_vv_v16i32(<16 x i32> %va, <16 x i32> %b, <16 x i1> %m, i32 zeroext %evl) {
589 ; CHECK-LABEL: vrem_vv_v16i32:
590 ; CHECK:       # %bb.0:
591 ; CHECK-NEXT:    vsetvli zero, a0, e32, m4, ta, ma
592 ; CHECK-NEXT:    vrem.vv v8, v8, v12, v0.t
593 ; CHECK-NEXT:    ret
594   %v = call <16 x i32> @llvm.vp.srem.v16i32(<16 x i32> %va, <16 x i32> %b, <16 x i1> %m, i32 %evl)
595   ret <16 x i32> %v
598 define <16 x i32> @vrem_vv_v16i32_unmasked(<16 x i32> %va, <16 x i32> %b, i32 zeroext %evl) {
599 ; CHECK-LABEL: vrem_vv_v16i32_unmasked:
600 ; CHECK:       # %bb.0:
601 ; CHECK-NEXT:    vsetvli zero, a0, e32, m4, ta, ma
602 ; CHECK-NEXT:    vrem.vv v8, v8, v12
603 ; CHECK-NEXT:    ret
604   %head = insertelement <16 x i1> poison, i1 true, i32 0
605   %m = shufflevector <16 x i1> %head, <16 x i1> poison, <16 x i32> zeroinitializer
606   %v = call <16 x i32> @llvm.vp.srem.v16i32(<16 x i32> %va, <16 x i32> %b, <16 x i1> %m, i32 %evl)
607   ret <16 x i32> %v
610 define <16 x i32> @vrem_vx_v16i32(<16 x i32> %va, i32 %b, <16 x i1> %m, i32 zeroext %evl) {
611 ; CHECK-LABEL: vrem_vx_v16i32:
612 ; CHECK:       # %bb.0:
613 ; CHECK-NEXT:    vsetvli zero, a1, e32, m4, ta, ma
614 ; CHECK-NEXT:    vrem.vx v8, v8, a0, v0.t
615 ; CHECK-NEXT:    ret
616   %elt.head = insertelement <16 x i32> poison, i32 %b, i32 0
617   %vb = shufflevector <16 x i32> %elt.head, <16 x i32> poison, <16 x i32> zeroinitializer
618   %v = call <16 x i32> @llvm.vp.srem.v16i32(<16 x i32> %va, <16 x i32> %vb, <16 x i1> %m, i32 %evl)
619   ret <16 x i32> %v
622 define <16 x i32> @vrem_vx_v16i32_unmasked(<16 x i32> %va, i32 %b, i32 zeroext %evl) {
623 ; CHECK-LABEL: vrem_vx_v16i32_unmasked:
624 ; CHECK:       # %bb.0:
625 ; CHECK-NEXT:    vsetvli zero, a1, e32, m4, ta, ma
626 ; CHECK-NEXT:    vrem.vx v8, v8, a0
627 ; CHECK-NEXT:    ret
628   %elt.head = insertelement <16 x i32> poison, i32 %b, i32 0
629   %vb = shufflevector <16 x i32> %elt.head, <16 x i32> poison, <16 x i32> zeroinitializer
630   %head = insertelement <16 x i1> poison, i1 true, i32 0
631   %m = shufflevector <16 x i1> %head, <16 x i1> poison, <16 x i32> zeroinitializer
632   %v = call <16 x i32> @llvm.vp.srem.v16i32(<16 x i32> %va, <16 x i32> %vb, <16 x i1> %m, i32 %evl)
633   ret <16 x i32> %v
636 declare <2 x i64> @llvm.vp.srem.v2i64(<2 x i64>, <2 x i64>, <2 x i1>, i32)
638 define <2 x i64> @vrem_vv_v2i64(<2 x i64> %va, <2 x i64> %b, <2 x i1> %m, i32 zeroext %evl) {
639 ; CHECK-LABEL: vrem_vv_v2i64:
640 ; CHECK:       # %bb.0:
641 ; CHECK-NEXT:    vsetvli zero, a0, e64, m1, ta, ma
642 ; CHECK-NEXT:    vrem.vv v8, v8, v9, v0.t
643 ; CHECK-NEXT:    ret
644   %v = call <2 x i64> @llvm.vp.srem.v2i64(<2 x i64> %va, <2 x i64> %b, <2 x i1> %m, i32 %evl)
645   ret <2 x i64> %v
648 define <2 x i64> @vrem_vv_v2i64_unmasked(<2 x i64> %va, <2 x i64> %b, i32 zeroext %evl) {
649 ; CHECK-LABEL: vrem_vv_v2i64_unmasked:
650 ; CHECK:       # %bb.0:
651 ; CHECK-NEXT:    vsetvli zero, a0, e64, m1, ta, ma
652 ; CHECK-NEXT:    vrem.vv v8, v8, v9
653 ; CHECK-NEXT:    ret
654   %head = insertelement <2 x i1> poison, i1 true, i32 0
655   %m = shufflevector <2 x i1> %head, <2 x i1> poison, <2 x i32> zeroinitializer
656   %v = call <2 x i64> @llvm.vp.srem.v2i64(<2 x i64> %va, <2 x i64> %b, <2 x i1> %m, i32 %evl)
657   ret <2 x i64> %v
660 define <2 x i64> @vrem_vx_v2i64(<2 x i64> %va, i64 %b, <2 x i1> %m, i32 zeroext %evl) {
661 ; RV32-LABEL: vrem_vx_v2i64:
662 ; RV32:       # %bb.0:
663 ; RV32-NEXT:    addi sp, sp, -16
664 ; RV32-NEXT:    .cfi_def_cfa_offset 16
665 ; RV32-NEXT:    sw a1, 12(sp)
666 ; RV32-NEXT:    sw a0, 8(sp)
667 ; RV32-NEXT:    addi a0, sp, 8
668 ; RV32-NEXT:    vsetivli zero, 2, e64, m1, ta, ma
669 ; RV32-NEXT:    vlse64.v v9, (a0), zero
670 ; RV32-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
671 ; RV32-NEXT:    vrem.vv v8, v8, v9, v0.t
672 ; RV32-NEXT:    addi sp, sp, 16
673 ; RV32-NEXT:    ret
675 ; RV64-LABEL: vrem_vx_v2i64:
676 ; RV64:       # %bb.0:
677 ; RV64-NEXT:    vsetvli zero, a1, e64, m1, ta, ma
678 ; RV64-NEXT:    vrem.vx v8, v8, a0, v0.t
679 ; RV64-NEXT:    ret
680   %elt.head = insertelement <2 x i64> poison, i64 %b, i32 0
681   %vb = shufflevector <2 x i64> %elt.head, <2 x i64> poison, <2 x i32> zeroinitializer
682   %v = call <2 x i64> @llvm.vp.srem.v2i64(<2 x i64> %va, <2 x i64> %vb, <2 x i1> %m, i32 %evl)
683   ret <2 x i64> %v
686 define <2 x i64> @vrem_vx_v2i64_unmasked(<2 x i64> %va, i64 %b, i32 zeroext %evl) {
687 ; RV32-LABEL: vrem_vx_v2i64_unmasked:
688 ; RV32:       # %bb.0:
689 ; RV32-NEXT:    addi sp, sp, -16
690 ; RV32-NEXT:    .cfi_def_cfa_offset 16
691 ; RV32-NEXT:    sw a1, 12(sp)
692 ; RV32-NEXT:    sw a0, 8(sp)
693 ; RV32-NEXT:    addi a0, sp, 8
694 ; RV32-NEXT:    vsetivli zero, 2, e64, m1, ta, ma
695 ; RV32-NEXT:    vlse64.v v9, (a0), zero
696 ; RV32-NEXT:    vsetvli zero, a2, e64, m1, ta, ma
697 ; RV32-NEXT:    vrem.vv v8, v8, v9
698 ; RV32-NEXT:    addi sp, sp, 16
699 ; RV32-NEXT:    ret
701 ; RV64-LABEL: vrem_vx_v2i64_unmasked:
702 ; RV64:       # %bb.0:
703 ; RV64-NEXT:    vsetvli zero, a1, e64, m1, ta, ma
704 ; RV64-NEXT:    vrem.vx v8, v8, a0
705 ; RV64-NEXT:    ret
706   %elt.head = insertelement <2 x i64> poison, i64 %b, i32 0
707   %vb = shufflevector <2 x i64> %elt.head, <2 x i64> poison, <2 x i32> zeroinitializer
708   %head = insertelement <2 x i1> poison, i1 true, i32 0
709   %m = shufflevector <2 x i1> %head, <2 x i1> poison, <2 x i32> zeroinitializer
710   %v = call <2 x i64> @llvm.vp.srem.v2i64(<2 x i64> %va, <2 x i64> %vb, <2 x i1> %m, i32 %evl)
711   ret <2 x i64> %v
714 declare <4 x i64> @llvm.vp.srem.v4i64(<4 x i64>, <4 x i64>, <4 x i1>, i32)
716 define <4 x i64> @vrem_vv_v4i64(<4 x i64> %va, <4 x i64> %b, <4 x i1> %m, i32 zeroext %evl) {
717 ; CHECK-LABEL: vrem_vv_v4i64:
718 ; CHECK:       # %bb.0:
719 ; CHECK-NEXT:    vsetvli zero, a0, e64, m2, ta, ma
720 ; CHECK-NEXT:    vrem.vv v8, v8, v10, v0.t
721 ; CHECK-NEXT:    ret
722   %v = call <4 x i64> @llvm.vp.srem.v4i64(<4 x i64> %va, <4 x i64> %b, <4 x i1> %m, i32 %evl)
723   ret <4 x i64> %v
726 define <4 x i64> @vrem_vv_v4i64_unmasked(<4 x i64> %va, <4 x i64> %b, i32 zeroext %evl) {
727 ; CHECK-LABEL: vrem_vv_v4i64_unmasked:
728 ; CHECK:       # %bb.0:
729 ; CHECK-NEXT:    vsetvli zero, a0, e64, m2, ta, ma
730 ; CHECK-NEXT:    vrem.vv v8, v8, v10
731 ; CHECK-NEXT:    ret
732   %head = insertelement <4 x i1> poison, i1 true, i32 0
733   %m = shufflevector <4 x i1> %head, <4 x i1> poison, <4 x i32> zeroinitializer
734   %v = call <4 x i64> @llvm.vp.srem.v4i64(<4 x i64> %va, <4 x i64> %b, <4 x i1> %m, i32 %evl)
735   ret <4 x i64> %v
738 define <4 x i64> @vrem_vx_v4i64(<4 x i64> %va, i64 %b, <4 x i1> %m, i32 zeroext %evl) {
739 ; RV32-LABEL: vrem_vx_v4i64:
740 ; RV32:       # %bb.0:
741 ; RV32-NEXT:    addi sp, sp, -16
742 ; RV32-NEXT:    .cfi_def_cfa_offset 16
743 ; RV32-NEXT:    sw a1, 12(sp)
744 ; RV32-NEXT:    sw a0, 8(sp)
745 ; RV32-NEXT:    addi a0, sp, 8
746 ; RV32-NEXT:    vsetivli zero, 4, e64, m2, ta, ma
747 ; RV32-NEXT:    vlse64.v v10, (a0), zero
748 ; RV32-NEXT:    vsetvli zero, a2, e64, m2, ta, ma
749 ; RV32-NEXT:    vrem.vv v8, v8, v10, v0.t
750 ; RV32-NEXT:    addi sp, sp, 16
751 ; RV32-NEXT:    ret
753 ; RV64-LABEL: vrem_vx_v4i64:
754 ; RV64:       # %bb.0:
755 ; RV64-NEXT:    vsetvli zero, a1, e64, m2, ta, ma
756 ; RV64-NEXT:    vrem.vx v8, v8, a0, v0.t
757 ; RV64-NEXT:    ret
758   %elt.head = insertelement <4 x i64> poison, i64 %b, i32 0
759   %vb = shufflevector <4 x i64> %elt.head, <4 x i64> poison, <4 x i32> zeroinitializer
760   %v = call <4 x i64> @llvm.vp.srem.v4i64(<4 x i64> %va, <4 x i64> %vb, <4 x i1> %m, i32 %evl)
761   ret <4 x i64> %v
764 define <4 x i64> @vrem_vx_v4i64_unmasked(<4 x i64> %va, i64 %b, i32 zeroext %evl) {
765 ; RV32-LABEL: vrem_vx_v4i64_unmasked:
766 ; RV32:       # %bb.0:
767 ; RV32-NEXT:    addi sp, sp, -16
768 ; RV32-NEXT:    .cfi_def_cfa_offset 16
769 ; RV32-NEXT:    sw a1, 12(sp)
770 ; RV32-NEXT:    sw a0, 8(sp)
771 ; RV32-NEXT:    addi a0, sp, 8
772 ; RV32-NEXT:    vsetivli zero, 4, e64, m2, ta, ma
773 ; RV32-NEXT:    vlse64.v v10, (a0), zero
774 ; RV32-NEXT:    vsetvli zero, a2, e64, m2, ta, ma
775 ; RV32-NEXT:    vrem.vv v8, v8, v10
776 ; RV32-NEXT:    addi sp, sp, 16
777 ; RV32-NEXT:    ret
779 ; RV64-LABEL: vrem_vx_v4i64_unmasked:
780 ; RV64:       # %bb.0:
781 ; RV64-NEXT:    vsetvli zero, a1, e64, m2, ta, ma
782 ; RV64-NEXT:    vrem.vx v8, v8, a0
783 ; RV64-NEXT:    ret
784   %elt.head = insertelement <4 x i64> poison, i64 %b, i32 0
785   %vb = shufflevector <4 x i64> %elt.head, <4 x i64> poison, <4 x i32> zeroinitializer
786   %head = insertelement <4 x i1> poison, i1 true, i32 0
787   %m = shufflevector <4 x i1> %head, <4 x i1> poison, <4 x i32> zeroinitializer
788   %v = call <4 x i64> @llvm.vp.srem.v4i64(<4 x i64> %va, <4 x i64> %vb, <4 x i1> %m, i32 %evl)
789   ret <4 x i64> %v
792 declare <8 x i64> @llvm.vp.srem.v8i64(<8 x i64>, <8 x i64>, <8 x i1>, i32)
794 define <8 x i64> @vrem_vv_v8i64(<8 x i64> %va, <8 x i64> %b, <8 x i1> %m, i32 zeroext %evl) {
795 ; CHECK-LABEL: vrem_vv_v8i64:
796 ; CHECK:       # %bb.0:
797 ; CHECK-NEXT:    vsetvli zero, a0, e64, m4, ta, ma
798 ; CHECK-NEXT:    vrem.vv v8, v8, v12, v0.t
799 ; CHECK-NEXT:    ret
800   %v = call <8 x i64> @llvm.vp.srem.v8i64(<8 x i64> %va, <8 x i64> %b, <8 x i1> %m, i32 %evl)
801   ret <8 x i64> %v
804 define <8 x i64> @vrem_vv_v8i64_unmasked(<8 x i64> %va, <8 x i64> %b, i32 zeroext %evl) {
805 ; CHECK-LABEL: vrem_vv_v8i64_unmasked:
806 ; CHECK:       # %bb.0:
807 ; CHECK-NEXT:    vsetvli zero, a0, e64, m4, ta, ma
808 ; CHECK-NEXT:    vrem.vv v8, v8, v12
809 ; CHECK-NEXT:    ret
810   %head = insertelement <8 x i1> poison, i1 true, i32 0
811   %m = shufflevector <8 x i1> %head, <8 x i1> poison, <8 x i32> zeroinitializer
812   %v = call <8 x i64> @llvm.vp.srem.v8i64(<8 x i64> %va, <8 x i64> %b, <8 x i1> %m, i32 %evl)
813   ret <8 x i64> %v
816 define <8 x i64> @vrem_vx_v8i64(<8 x i64> %va, i64 %b, <8 x i1> %m, i32 zeroext %evl) {
817 ; RV32-LABEL: vrem_vx_v8i64:
818 ; RV32:       # %bb.0:
819 ; RV32-NEXT:    addi sp, sp, -16
820 ; RV32-NEXT:    .cfi_def_cfa_offset 16
821 ; RV32-NEXT:    sw a1, 12(sp)
822 ; RV32-NEXT:    sw a0, 8(sp)
823 ; RV32-NEXT:    addi a0, sp, 8
824 ; RV32-NEXT:    vsetivli zero, 8, e64, m4, ta, ma
825 ; RV32-NEXT:    vlse64.v v12, (a0), zero
826 ; RV32-NEXT:    vsetvli zero, a2, e64, m4, ta, ma
827 ; RV32-NEXT:    vrem.vv v8, v8, v12, v0.t
828 ; RV32-NEXT:    addi sp, sp, 16
829 ; RV32-NEXT:    ret
831 ; RV64-LABEL: vrem_vx_v8i64:
832 ; RV64:       # %bb.0:
833 ; RV64-NEXT:    vsetvli zero, a1, e64, m4, ta, ma
834 ; RV64-NEXT:    vrem.vx v8, v8, a0, v0.t
835 ; RV64-NEXT:    ret
836   %elt.head = insertelement <8 x i64> poison, i64 %b, i32 0
837   %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer
838   %v = call <8 x i64> @llvm.vp.srem.v8i64(<8 x i64> %va, <8 x i64> %vb, <8 x i1> %m, i32 %evl)
839   ret <8 x i64> %v
842 define <8 x i64> @vrem_vx_v8i64_unmasked(<8 x i64> %va, i64 %b, i32 zeroext %evl) {
843 ; RV32-LABEL: vrem_vx_v8i64_unmasked:
844 ; RV32:       # %bb.0:
845 ; RV32-NEXT:    addi sp, sp, -16
846 ; RV32-NEXT:    .cfi_def_cfa_offset 16
847 ; RV32-NEXT:    sw a1, 12(sp)
848 ; RV32-NEXT:    sw a0, 8(sp)
849 ; RV32-NEXT:    addi a0, sp, 8
850 ; RV32-NEXT:    vsetivli zero, 8, e64, m4, ta, ma
851 ; RV32-NEXT:    vlse64.v v12, (a0), zero
852 ; RV32-NEXT:    vsetvli zero, a2, e64, m4, ta, ma
853 ; RV32-NEXT:    vrem.vv v8, v8, v12
854 ; RV32-NEXT:    addi sp, sp, 16
855 ; RV32-NEXT:    ret
857 ; RV64-LABEL: vrem_vx_v8i64_unmasked:
858 ; RV64:       # %bb.0:
859 ; RV64-NEXT:    vsetvli zero, a1, e64, m4, ta, ma
860 ; RV64-NEXT:    vrem.vx v8, v8, a0
861 ; RV64-NEXT:    ret
862   %elt.head = insertelement <8 x i64> poison, i64 %b, i32 0
863   %vb = shufflevector <8 x i64> %elt.head, <8 x i64> poison, <8 x i32> zeroinitializer
864   %head = insertelement <8 x i1> poison, i1 true, i32 0
865   %m = shufflevector <8 x i1> %head, <8 x i1> poison, <8 x i32> zeroinitializer
866   %v = call <8 x i64> @llvm.vp.srem.v8i64(<8 x i64> %va, <8 x i64> %vb, <8 x i1> %m, i32 %evl)
867   ret <8 x i64> %v
870 declare <16 x i64> @llvm.vp.srem.v16i64(<16 x i64>, <16 x i64>, <16 x i1>, i32)
872 define <16 x i64> @vrem_vv_v16i64(<16 x i64> %va, <16 x i64> %b, <16 x i1> %m, i32 zeroext %evl) {
873 ; CHECK-LABEL: vrem_vv_v16i64:
874 ; CHECK:       # %bb.0:
875 ; CHECK-NEXT:    vsetvli zero, a0, e64, m8, ta, ma
876 ; CHECK-NEXT:    vrem.vv v8, v8, v16, v0.t
877 ; CHECK-NEXT:    ret
878   %v = call <16 x i64> @llvm.vp.srem.v16i64(<16 x i64> %va, <16 x i64> %b, <16 x i1> %m, i32 %evl)
879   ret <16 x i64> %v
882 define <16 x i64> @vrem_vv_v16i64_unmasked(<16 x i64> %va, <16 x i64> %b, i32 zeroext %evl) {
883 ; CHECK-LABEL: vrem_vv_v16i64_unmasked:
884 ; CHECK:       # %bb.0:
885 ; CHECK-NEXT:    vsetvli zero, a0, e64, m8, ta, ma
886 ; CHECK-NEXT:    vrem.vv v8, v8, v16
887 ; CHECK-NEXT:    ret
888   %head = insertelement <16 x i1> poison, i1 true, i32 0
889   %m = shufflevector <16 x i1> %head, <16 x i1> poison, <16 x i32> zeroinitializer
890   %v = call <16 x i64> @llvm.vp.srem.v16i64(<16 x i64> %va, <16 x i64> %b, <16 x i1> %m, i32 %evl)
891   ret <16 x i64> %v
894 define <16 x i64> @vrem_vx_v16i64(<16 x i64> %va, i64 %b, <16 x i1> %m, i32 zeroext %evl) {
895 ; RV32-LABEL: vrem_vx_v16i64:
896 ; RV32:       # %bb.0:
897 ; RV32-NEXT:    addi sp, sp, -16
898 ; RV32-NEXT:    .cfi_def_cfa_offset 16
899 ; RV32-NEXT:    sw a1, 12(sp)
900 ; RV32-NEXT:    sw a0, 8(sp)
901 ; RV32-NEXT:    addi a0, sp, 8
902 ; RV32-NEXT:    vsetivli zero, 16, e64, m8, ta, ma
903 ; RV32-NEXT:    vlse64.v v16, (a0), zero
904 ; RV32-NEXT:    vsetvli zero, a2, e64, m8, ta, ma
905 ; RV32-NEXT:    vrem.vv v8, v8, v16, v0.t
906 ; RV32-NEXT:    addi sp, sp, 16
907 ; RV32-NEXT:    ret
909 ; RV64-LABEL: vrem_vx_v16i64:
910 ; RV64:       # %bb.0:
911 ; RV64-NEXT:    vsetvli zero, a1, e64, m8, ta, ma
912 ; RV64-NEXT:    vrem.vx v8, v8, a0, v0.t
913 ; RV64-NEXT:    ret
914   %elt.head = insertelement <16 x i64> poison, i64 %b, i32 0
915   %vb = shufflevector <16 x i64> %elt.head, <16 x i64> poison, <16 x i32> zeroinitializer
916   %v = call <16 x i64> @llvm.vp.srem.v16i64(<16 x i64> %va, <16 x i64> %vb, <16 x i1> %m, i32 %evl)
917   ret <16 x i64> %v
920 define <16 x i64> @vrem_vx_v16i64_unmasked(<16 x i64> %va, i64 %b, i32 zeroext %evl) {
921 ; RV32-LABEL: vrem_vx_v16i64_unmasked:
922 ; RV32:       # %bb.0:
923 ; RV32-NEXT:    addi sp, sp, -16
924 ; RV32-NEXT:    .cfi_def_cfa_offset 16
925 ; RV32-NEXT:    sw a1, 12(sp)
926 ; RV32-NEXT:    sw a0, 8(sp)
927 ; RV32-NEXT:    addi a0, sp, 8
928 ; RV32-NEXT:    vsetivli zero, 16, e64, m8, ta, ma
929 ; RV32-NEXT:    vlse64.v v16, (a0), zero
930 ; RV32-NEXT:    vsetvli zero, a2, e64, m8, ta, ma
931 ; RV32-NEXT:    vrem.vv v8, v8, v16
932 ; RV32-NEXT:    addi sp, sp, 16
933 ; RV32-NEXT:    ret
935 ; RV64-LABEL: vrem_vx_v16i64_unmasked:
936 ; RV64:       # %bb.0:
937 ; RV64-NEXT:    vsetvli zero, a1, e64, m8, ta, ma
938 ; RV64-NEXT:    vrem.vx v8, v8, a0
939 ; RV64-NEXT:    ret
940   %elt.head = insertelement <16 x i64> poison, i64 %b, i32 0
941   %vb = shufflevector <16 x i64> %elt.head, <16 x i64> poison, <16 x i32> zeroinitializer
942   %head = insertelement <16 x i1> poison, i1 true, i32 0
943   %m = shufflevector <16 x i1> %head, <16 x i1> poison, <16 x i32> zeroinitializer
944   %v = call <16 x i64> @llvm.vp.srem.v16i64(<16 x i64> %va, <16 x i64> %vb, <16 x i1> %m, i32 %evl)
945   ret <16 x i64> %v