Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / clang / test / CodeGen / RISCV / rvv-intrinsics-autogenerated / non-policy / non-overloaded / vror.c
blobbf7a252950e1dcd95227cb87603b877e98c71a19
1 // NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py UTC_ARGS: --version 2
2 // REQUIRES: riscv-registered-target
3 // RUN: %clang_cc1 -triple riscv64 -target-feature +v -target-feature +zvl512b \
4 // RUN: -target-feature +experimental-zvbb \
5 // RUN: -target-feature +experimental-zvbc \
6 // RUN: -target-feature +experimental-zvkb \
7 // RUN: -target-feature +experimental-zvkg \
8 // RUN: -target-feature +experimental-zvkned \
9 // RUN: -target-feature +experimental-zvknhb \
10 // RUN: -target-feature +experimental-zvksed \
11 // RUN: -target-feature +experimental-zvksh -disable-O0-optnone \
12 // RUN: -emit-llvm %s -o - | opt -S -passes=mem2reg | \
13 // RUN: FileCheck --check-prefix=CHECK-RV64 %s
15 #include <riscv_vector.h>
17 // CHECK-RV64-LABEL: define dso_local <vscale x 1 x i8> @test_vror_vv_u8mf8
18 // CHECK-RV64-SAME: (<vscale x 1 x i8> [[VS2:%.*]], <vscale x 1 x i8> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0:[0-9]+]] {
19 // CHECK-RV64-NEXT: entry:
20 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 1 x i8> @llvm.riscv.vror.nxv1i8.nxv1i8.i64(<vscale x 1 x i8> poison, <vscale x 1 x i8> [[VS2]], <vscale x 1 x i8> [[VS1]], i64 [[VL]])
21 // CHECK-RV64-NEXT: ret <vscale x 1 x i8> [[TMP0]]
23 vuint8mf8_t test_vror_vv_u8mf8(vuint8mf8_t vs2, vuint8mf8_t vs1, size_t vl) {
24 return __riscv_vror_vv_u8mf8(vs2, vs1, vl);
27 // CHECK-RV64-LABEL: define dso_local <vscale x 1 x i8> @test_vror_vx_u8mf8
28 // CHECK-RV64-SAME: (<vscale x 1 x i8> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
29 // CHECK-RV64-NEXT: entry:
30 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 1 x i8> @llvm.riscv.vror.nxv1i8.i64.i64(<vscale x 1 x i8> poison, <vscale x 1 x i8> [[VS2]], i64 [[RS1]], i64 [[VL]])
31 // CHECK-RV64-NEXT: ret <vscale x 1 x i8> [[TMP0]]
33 vuint8mf8_t test_vror_vx_u8mf8(vuint8mf8_t vs2, size_t rs1, size_t vl) {
34 return __riscv_vror_vx_u8mf8(vs2, rs1, vl);
37 // CHECK-RV64-LABEL: define dso_local <vscale x 2 x i8> @test_vror_vv_u8mf4
38 // CHECK-RV64-SAME: (<vscale x 2 x i8> [[VS2:%.*]], <vscale x 2 x i8> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
39 // CHECK-RV64-NEXT: entry:
40 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 2 x i8> @llvm.riscv.vror.nxv2i8.nxv2i8.i64(<vscale x 2 x i8> poison, <vscale x 2 x i8> [[VS2]], <vscale x 2 x i8> [[VS1]], i64 [[VL]])
41 // CHECK-RV64-NEXT: ret <vscale x 2 x i8> [[TMP0]]
43 vuint8mf4_t test_vror_vv_u8mf4(vuint8mf4_t vs2, vuint8mf4_t vs1, size_t vl) {
44 return __riscv_vror_vv_u8mf4(vs2, vs1, vl);
47 // CHECK-RV64-LABEL: define dso_local <vscale x 2 x i8> @test_vror_vx_u8mf4
48 // CHECK-RV64-SAME: (<vscale x 2 x i8> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
49 // CHECK-RV64-NEXT: entry:
50 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 2 x i8> @llvm.riscv.vror.nxv2i8.i64.i64(<vscale x 2 x i8> poison, <vscale x 2 x i8> [[VS2]], i64 [[RS1]], i64 [[VL]])
51 // CHECK-RV64-NEXT: ret <vscale x 2 x i8> [[TMP0]]
53 vuint8mf4_t test_vror_vx_u8mf4(vuint8mf4_t vs2, size_t rs1, size_t vl) {
54 return __riscv_vror_vx_u8mf4(vs2, rs1, vl);
57 // CHECK-RV64-LABEL: define dso_local <vscale x 4 x i8> @test_vror_vv_u8mf2
58 // CHECK-RV64-SAME: (<vscale x 4 x i8> [[VS2:%.*]], <vscale x 4 x i8> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
59 // CHECK-RV64-NEXT: entry:
60 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 4 x i8> @llvm.riscv.vror.nxv4i8.nxv4i8.i64(<vscale x 4 x i8> poison, <vscale x 4 x i8> [[VS2]], <vscale x 4 x i8> [[VS1]], i64 [[VL]])
61 // CHECK-RV64-NEXT: ret <vscale x 4 x i8> [[TMP0]]
63 vuint8mf2_t test_vror_vv_u8mf2(vuint8mf2_t vs2, vuint8mf2_t vs1, size_t vl) {
64 return __riscv_vror_vv_u8mf2(vs2, vs1, vl);
67 // CHECK-RV64-LABEL: define dso_local <vscale x 4 x i8> @test_vror_vx_u8mf2
68 // CHECK-RV64-SAME: (<vscale x 4 x i8> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
69 // CHECK-RV64-NEXT: entry:
70 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 4 x i8> @llvm.riscv.vror.nxv4i8.i64.i64(<vscale x 4 x i8> poison, <vscale x 4 x i8> [[VS2]], i64 [[RS1]], i64 [[VL]])
71 // CHECK-RV64-NEXT: ret <vscale x 4 x i8> [[TMP0]]
73 vuint8mf2_t test_vror_vx_u8mf2(vuint8mf2_t vs2, size_t rs1, size_t vl) {
74 return __riscv_vror_vx_u8mf2(vs2, rs1, vl);
77 // CHECK-RV64-LABEL: define dso_local <vscale x 8 x i8> @test_vror_vv_u8m1
78 // CHECK-RV64-SAME: (<vscale x 8 x i8> [[VS2:%.*]], <vscale x 8 x i8> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
79 // CHECK-RV64-NEXT: entry:
80 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 8 x i8> @llvm.riscv.vror.nxv8i8.nxv8i8.i64(<vscale x 8 x i8> poison, <vscale x 8 x i8> [[VS2]], <vscale x 8 x i8> [[VS1]], i64 [[VL]])
81 // CHECK-RV64-NEXT: ret <vscale x 8 x i8> [[TMP0]]
83 vuint8m1_t test_vror_vv_u8m1(vuint8m1_t vs2, vuint8m1_t vs1, size_t vl) {
84 return __riscv_vror_vv_u8m1(vs2, vs1, vl);
87 // CHECK-RV64-LABEL: define dso_local <vscale x 8 x i8> @test_vror_vx_u8m1
88 // CHECK-RV64-SAME: (<vscale x 8 x i8> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
89 // CHECK-RV64-NEXT: entry:
90 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 8 x i8> @llvm.riscv.vror.nxv8i8.i64.i64(<vscale x 8 x i8> poison, <vscale x 8 x i8> [[VS2]], i64 [[RS1]], i64 [[VL]])
91 // CHECK-RV64-NEXT: ret <vscale x 8 x i8> [[TMP0]]
93 vuint8m1_t test_vror_vx_u8m1(vuint8m1_t vs2, size_t rs1, size_t vl) {
94 return __riscv_vror_vx_u8m1(vs2, rs1, vl);
97 // CHECK-RV64-LABEL: define dso_local <vscale x 16 x i8> @test_vror_vv_u8m2
98 // CHECK-RV64-SAME: (<vscale x 16 x i8> [[VS2:%.*]], <vscale x 16 x i8> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
99 // CHECK-RV64-NEXT: entry:
100 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 16 x i8> @llvm.riscv.vror.nxv16i8.nxv16i8.i64(<vscale x 16 x i8> poison, <vscale x 16 x i8> [[VS2]], <vscale x 16 x i8> [[VS1]], i64 [[VL]])
101 // CHECK-RV64-NEXT: ret <vscale x 16 x i8> [[TMP0]]
103 vuint8m2_t test_vror_vv_u8m2(vuint8m2_t vs2, vuint8m2_t vs1, size_t vl) {
104 return __riscv_vror_vv_u8m2(vs2, vs1, vl);
107 // CHECK-RV64-LABEL: define dso_local <vscale x 16 x i8> @test_vror_vx_u8m2
108 // CHECK-RV64-SAME: (<vscale x 16 x i8> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
109 // CHECK-RV64-NEXT: entry:
110 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 16 x i8> @llvm.riscv.vror.nxv16i8.i64.i64(<vscale x 16 x i8> poison, <vscale x 16 x i8> [[VS2]], i64 [[RS1]], i64 [[VL]])
111 // CHECK-RV64-NEXT: ret <vscale x 16 x i8> [[TMP0]]
113 vuint8m2_t test_vror_vx_u8m2(vuint8m2_t vs2, size_t rs1, size_t vl) {
114 return __riscv_vror_vx_u8m2(vs2, rs1, vl);
117 // CHECK-RV64-LABEL: define dso_local <vscale x 32 x i8> @test_vror_vv_u8m4
118 // CHECK-RV64-SAME: (<vscale x 32 x i8> [[VS2:%.*]], <vscale x 32 x i8> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
119 // CHECK-RV64-NEXT: entry:
120 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 32 x i8> @llvm.riscv.vror.nxv32i8.nxv32i8.i64(<vscale x 32 x i8> poison, <vscale x 32 x i8> [[VS2]], <vscale x 32 x i8> [[VS1]], i64 [[VL]])
121 // CHECK-RV64-NEXT: ret <vscale x 32 x i8> [[TMP0]]
123 vuint8m4_t test_vror_vv_u8m4(vuint8m4_t vs2, vuint8m4_t vs1, size_t vl) {
124 return __riscv_vror_vv_u8m4(vs2, vs1, vl);
127 // CHECK-RV64-LABEL: define dso_local <vscale x 32 x i8> @test_vror_vx_u8m4
128 // CHECK-RV64-SAME: (<vscale x 32 x i8> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
129 // CHECK-RV64-NEXT: entry:
130 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 32 x i8> @llvm.riscv.vror.nxv32i8.i64.i64(<vscale x 32 x i8> poison, <vscale x 32 x i8> [[VS2]], i64 [[RS1]], i64 [[VL]])
131 // CHECK-RV64-NEXT: ret <vscale x 32 x i8> [[TMP0]]
133 vuint8m4_t test_vror_vx_u8m4(vuint8m4_t vs2, size_t rs1, size_t vl) {
134 return __riscv_vror_vx_u8m4(vs2, rs1, vl);
137 // CHECK-RV64-LABEL: define dso_local <vscale x 64 x i8> @test_vror_vv_u8m8
138 // CHECK-RV64-SAME: (<vscale x 64 x i8> [[VS2:%.*]], <vscale x 64 x i8> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
139 // CHECK-RV64-NEXT: entry:
140 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 64 x i8> @llvm.riscv.vror.nxv64i8.nxv64i8.i64(<vscale x 64 x i8> poison, <vscale x 64 x i8> [[VS2]], <vscale x 64 x i8> [[VS1]], i64 [[VL]])
141 // CHECK-RV64-NEXT: ret <vscale x 64 x i8> [[TMP0]]
143 vuint8m8_t test_vror_vv_u8m8(vuint8m8_t vs2, vuint8m8_t vs1, size_t vl) {
144 return __riscv_vror_vv_u8m8(vs2, vs1, vl);
147 // CHECK-RV64-LABEL: define dso_local <vscale x 64 x i8> @test_vror_vx_u8m8
148 // CHECK-RV64-SAME: (<vscale x 64 x i8> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
149 // CHECK-RV64-NEXT: entry:
150 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 64 x i8> @llvm.riscv.vror.nxv64i8.i64.i64(<vscale x 64 x i8> poison, <vscale x 64 x i8> [[VS2]], i64 [[RS1]], i64 [[VL]])
151 // CHECK-RV64-NEXT: ret <vscale x 64 x i8> [[TMP0]]
153 vuint8m8_t test_vror_vx_u8m8(vuint8m8_t vs2, size_t rs1, size_t vl) {
154 return __riscv_vror_vx_u8m8(vs2, rs1, vl);
157 // CHECK-RV64-LABEL: define dso_local <vscale x 1 x i16> @test_vror_vv_u16mf4
158 // CHECK-RV64-SAME: (<vscale x 1 x i16> [[VS2:%.*]], <vscale x 1 x i16> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
159 // CHECK-RV64-NEXT: entry:
160 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 1 x i16> @llvm.riscv.vror.nxv1i16.nxv1i16.i64(<vscale x 1 x i16> poison, <vscale x 1 x i16> [[VS2]], <vscale x 1 x i16> [[VS1]], i64 [[VL]])
161 // CHECK-RV64-NEXT: ret <vscale x 1 x i16> [[TMP0]]
163 vuint16mf4_t test_vror_vv_u16mf4(vuint16mf4_t vs2, vuint16mf4_t vs1, size_t vl) {
164 return __riscv_vror_vv_u16mf4(vs2, vs1, vl);
167 // CHECK-RV64-LABEL: define dso_local <vscale x 1 x i16> @test_vror_vx_u16mf4
168 // CHECK-RV64-SAME: (<vscale x 1 x i16> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
169 // CHECK-RV64-NEXT: entry:
170 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 1 x i16> @llvm.riscv.vror.nxv1i16.i64.i64(<vscale x 1 x i16> poison, <vscale x 1 x i16> [[VS2]], i64 [[RS1]], i64 [[VL]])
171 // CHECK-RV64-NEXT: ret <vscale x 1 x i16> [[TMP0]]
173 vuint16mf4_t test_vror_vx_u16mf4(vuint16mf4_t vs2, size_t rs1, size_t vl) {
174 return __riscv_vror_vx_u16mf4(vs2, rs1, vl);
177 // CHECK-RV64-LABEL: define dso_local <vscale x 2 x i16> @test_vror_vv_u16mf2
178 // CHECK-RV64-SAME: (<vscale x 2 x i16> [[VS2:%.*]], <vscale x 2 x i16> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
179 // CHECK-RV64-NEXT: entry:
180 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 2 x i16> @llvm.riscv.vror.nxv2i16.nxv2i16.i64(<vscale x 2 x i16> poison, <vscale x 2 x i16> [[VS2]], <vscale x 2 x i16> [[VS1]], i64 [[VL]])
181 // CHECK-RV64-NEXT: ret <vscale x 2 x i16> [[TMP0]]
183 vuint16mf2_t test_vror_vv_u16mf2(vuint16mf2_t vs2, vuint16mf2_t vs1, size_t vl) {
184 return __riscv_vror_vv_u16mf2(vs2, vs1, vl);
187 // CHECK-RV64-LABEL: define dso_local <vscale x 2 x i16> @test_vror_vx_u16mf2
188 // CHECK-RV64-SAME: (<vscale x 2 x i16> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
189 // CHECK-RV64-NEXT: entry:
190 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 2 x i16> @llvm.riscv.vror.nxv2i16.i64.i64(<vscale x 2 x i16> poison, <vscale x 2 x i16> [[VS2]], i64 [[RS1]], i64 [[VL]])
191 // CHECK-RV64-NEXT: ret <vscale x 2 x i16> [[TMP0]]
193 vuint16mf2_t test_vror_vx_u16mf2(vuint16mf2_t vs2, size_t rs1, size_t vl) {
194 return __riscv_vror_vx_u16mf2(vs2, rs1, vl);
197 // CHECK-RV64-LABEL: define dso_local <vscale x 4 x i16> @test_vror_vv_u16m1
198 // CHECK-RV64-SAME: (<vscale x 4 x i16> [[VS2:%.*]], <vscale x 4 x i16> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
199 // CHECK-RV64-NEXT: entry:
200 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 4 x i16> @llvm.riscv.vror.nxv4i16.nxv4i16.i64(<vscale x 4 x i16> poison, <vscale x 4 x i16> [[VS2]], <vscale x 4 x i16> [[VS1]], i64 [[VL]])
201 // CHECK-RV64-NEXT: ret <vscale x 4 x i16> [[TMP0]]
203 vuint16m1_t test_vror_vv_u16m1(vuint16m1_t vs2, vuint16m1_t vs1, size_t vl) {
204 return __riscv_vror_vv_u16m1(vs2, vs1, vl);
207 // CHECK-RV64-LABEL: define dso_local <vscale x 4 x i16> @test_vror_vx_u16m1
208 // CHECK-RV64-SAME: (<vscale x 4 x i16> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
209 // CHECK-RV64-NEXT: entry:
210 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 4 x i16> @llvm.riscv.vror.nxv4i16.i64.i64(<vscale x 4 x i16> poison, <vscale x 4 x i16> [[VS2]], i64 [[RS1]], i64 [[VL]])
211 // CHECK-RV64-NEXT: ret <vscale x 4 x i16> [[TMP0]]
213 vuint16m1_t test_vror_vx_u16m1(vuint16m1_t vs2, size_t rs1, size_t vl) {
214 return __riscv_vror_vx_u16m1(vs2, rs1, vl);
217 // CHECK-RV64-LABEL: define dso_local <vscale x 8 x i16> @test_vror_vv_u16m2
218 // CHECK-RV64-SAME: (<vscale x 8 x i16> [[VS2:%.*]], <vscale x 8 x i16> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
219 // CHECK-RV64-NEXT: entry:
220 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 8 x i16> @llvm.riscv.vror.nxv8i16.nxv8i16.i64(<vscale x 8 x i16> poison, <vscale x 8 x i16> [[VS2]], <vscale x 8 x i16> [[VS1]], i64 [[VL]])
221 // CHECK-RV64-NEXT: ret <vscale x 8 x i16> [[TMP0]]
223 vuint16m2_t test_vror_vv_u16m2(vuint16m2_t vs2, vuint16m2_t vs1, size_t vl) {
224 return __riscv_vror_vv_u16m2(vs2, vs1, vl);
227 // CHECK-RV64-LABEL: define dso_local <vscale x 8 x i16> @test_vror_vx_u16m2
228 // CHECK-RV64-SAME: (<vscale x 8 x i16> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
229 // CHECK-RV64-NEXT: entry:
230 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 8 x i16> @llvm.riscv.vror.nxv8i16.i64.i64(<vscale x 8 x i16> poison, <vscale x 8 x i16> [[VS2]], i64 [[RS1]], i64 [[VL]])
231 // CHECK-RV64-NEXT: ret <vscale x 8 x i16> [[TMP0]]
233 vuint16m2_t test_vror_vx_u16m2(vuint16m2_t vs2, size_t rs1, size_t vl) {
234 return __riscv_vror_vx_u16m2(vs2, rs1, vl);
237 // CHECK-RV64-LABEL: define dso_local <vscale x 16 x i16> @test_vror_vv_u16m4
238 // CHECK-RV64-SAME: (<vscale x 16 x i16> [[VS2:%.*]], <vscale x 16 x i16> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
239 // CHECK-RV64-NEXT: entry:
240 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 16 x i16> @llvm.riscv.vror.nxv16i16.nxv16i16.i64(<vscale x 16 x i16> poison, <vscale x 16 x i16> [[VS2]], <vscale x 16 x i16> [[VS1]], i64 [[VL]])
241 // CHECK-RV64-NEXT: ret <vscale x 16 x i16> [[TMP0]]
243 vuint16m4_t test_vror_vv_u16m4(vuint16m4_t vs2, vuint16m4_t vs1, size_t vl) {
244 return __riscv_vror_vv_u16m4(vs2, vs1, vl);
247 // CHECK-RV64-LABEL: define dso_local <vscale x 16 x i16> @test_vror_vx_u16m4
248 // CHECK-RV64-SAME: (<vscale x 16 x i16> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
249 // CHECK-RV64-NEXT: entry:
250 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 16 x i16> @llvm.riscv.vror.nxv16i16.i64.i64(<vscale x 16 x i16> poison, <vscale x 16 x i16> [[VS2]], i64 [[RS1]], i64 [[VL]])
251 // CHECK-RV64-NEXT: ret <vscale x 16 x i16> [[TMP0]]
253 vuint16m4_t test_vror_vx_u16m4(vuint16m4_t vs2, size_t rs1, size_t vl) {
254 return __riscv_vror_vx_u16m4(vs2, rs1, vl);
257 // CHECK-RV64-LABEL: define dso_local <vscale x 32 x i16> @test_vror_vv_u16m8
258 // CHECK-RV64-SAME: (<vscale x 32 x i16> [[VS2:%.*]], <vscale x 32 x i16> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
259 // CHECK-RV64-NEXT: entry:
260 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 32 x i16> @llvm.riscv.vror.nxv32i16.nxv32i16.i64(<vscale x 32 x i16> poison, <vscale x 32 x i16> [[VS2]], <vscale x 32 x i16> [[VS1]], i64 [[VL]])
261 // CHECK-RV64-NEXT: ret <vscale x 32 x i16> [[TMP0]]
263 vuint16m8_t test_vror_vv_u16m8(vuint16m8_t vs2, vuint16m8_t vs1, size_t vl) {
264 return __riscv_vror_vv_u16m8(vs2, vs1, vl);
267 // CHECK-RV64-LABEL: define dso_local <vscale x 32 x i16> @test_vror_vx_u16m8
268 // CHECK-RV64-SAME: (<vscale x 32 x i16> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
269 // CHECK-RV64-NEXT: entry:
270 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 32 x i16> @llvm.riscv.vror.nxv32i16.i64.i64(<vscale x 32 x i16> poison, <vscale x 32 x i16> [[VS2]], i64 [[RS1]], i64 [[VL]])
271 // CHECK-RV64-NEXT: ret <vscale x 32 x i16> [[TMP0]]
273 vuint16m8_t test_vror_vx_u16m8(vuint16m8_t vs2, size_t rs1, size_t vl) {
274 return __riscv_vror_vx_u16m8(vs2, rs1, vl);
277 // CHECK-RV64-LABEL: define dso_local <vscale x 1 x i32> @test_vror_vv_u32mf2
278 // CHECK-RV64-SAME: (<vscale x 1 x i32> [[VS2:%.*]], <vscale x 1 x i32> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
279 // CHECK-RV64-NEXT: entry:
280 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 1 x i32> @llvm.riscv.vror.nxv1i32.nxv1i32.i64(<vscale x 1 x i32> poison, <vscale x 1 x i32> [[VS2]], <vscale x 1 x i32> [[VS1]], i64 [[VL]])
281 // CHECK-RV64-NEXT: ret <vscale x 1 x i32> [[TMP0]]
283 vuint32mf2_t test_vror_vv_u32mf2(vuint32mf2_t vs2, vuint32mf2_t vs1, size_t vl) {
284 return __riscv_vror_vv_u32mf2(vs2, vs1, vl);
287 // CHECK-RV64-LABEL: define dso_local <vscale x 1 x i32> @test_vror_vx_u32mf2
288 // CHECK-RV64-SAME: (<vscale x 1 x i32> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
289 // CHECK-RV64-NEXT: entry:
290 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 1 x i32> @llvm.riscv.vror.nxv1i32.i64.i64(<vscale x 1 x i32> poison, <vscale x 1 x i32> [[VS2]], i64 [[RS1]], i64 [[VL]])
291 // CHECK-RV64-NEXT: ret <vscale x 1 x i32> [[TMP0]]
293 vuint32mf2_t test_vror_vx_u32mf2(vuint32mf2_t vs2, size_t rs1, size_t vl) {
294 return __riscv_vror_vx_u32mf2(vs2, rs1, vl);
297 // CHECK-RV64-LABEL: define dso_local <vscale x 2 x i32> @test_vror_vv_u32m1
298 // CHECK-RV64-SAME: (<vscale x 2 x i32> [[VS2:%.*]], <vscale x 2 x i32> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
299 // CHECK-RV64-NEXT: entry:
300 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 2 x i32> @llvm.riscv.vror.nxv2i32.nxv2i32.i64(<vscale x 2 x i32> poison, <vscale x 2 x i32> [[VS2]], <vscale x 2 x i32> [[VS1]], i64 [[VL]])
301 // CHECK-RV64-NEXT: ret <vscale x 2 x i32> [[TMP0]]
303 vuint32m1_t test_vror_vv_u32m1(vuint32m1_t vs2, vuint32m1_t vs1, size_t vl) {
304 return __riscv_vror_vv_u32m1(vs2, vs1, vl);
307 // CHECK-RV64-LABEL: define dso_local <vscale x 2 x i32> @test_vror_vx_u32m1
308 // CHECK-RV64-SAME: (<vscale x 2 x i32> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
309 // CHECK-RV64-NEXT: entry:
310 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 2 x i32> @llvm.riscv.vror.nxv2i32.i64.i64(<vscale x 2 x i32> poison, <vscale x 2 x i32> [[VS2]], i64 [[RS1]], i64 [[VL]])
311 // CHECK-RV64-NEXT: ret <vscale x 2 x i32> [[TMP0]]
313 vuint32m1_t test_vror_vx_u32m1(vuint32m1_t vs2, size_t rs1, size_t vl) {
314 return __riscv_vror_vx_u32m1(vs2, rs1, vl);
317 // CHECK-RV64-LABEL: define dso_local <vscale x 4 x i32> @test_vror_vv_u32m2
318 // CHECK-RV64-SAME: (<vscale x 4 x i32> [[VS2:%.*]], <vscale x 4 x i32> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
319 // CHECK-RV64-NEXT: entry:
320 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 4 x i32> @llvm.riscv.vror.nxv4i32.nxv4i32.i64(<vscale x 4 x i32> poison, <vscale x 4 x i32> [[VS2]], <vscale x 4 x i32> [[VS1]], i64 [[VL]])
321 // CHECK-RV64-NEXT: ret <vscale x 4 x i32> [[TMP0]]
323 vuint32m2_t test_vror_vv_u32m2(vuint32m2_t vs2, vuint32m2_t vs1, size_t vl) {
324 return __riscv_vror_vv_u32m2(vs2, vs1, vl);
327 // CHECK-RV64-LABEL: define dso_local <vscale x 4 x i32> @test_vror_vx_u32m2
328 // CHECK-RV64-SAME: (<vscale x 4 x i32> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
329 // CHECK-RV64-NEXT: entry:
330 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 4 x i32> @llvm.riscv.vror.nxv4i32.i64.i64(<vscale x 4 x i32> poison, <vscale x 4 x i32> [[VS2]], i64 [[RS1]], i64 [[VL]])
331 // CHECK-RV64-NEXT: ret <vscale x 4 x i32> [[TMP0]]
333 vuint32m2_t test_vror_vx_u32m2(vuint32m2_t vs2, size_t rs1, size_t vl) {
334 return __riscv_vror_vx_u32m2(vs2, rs1, vl);
337 // CHECK-RV64-LABEL: define dso_local <vscale x 8 x i32> @test_vror_vv_u32m4
338 // CHECK-RV64-SAME: (<vscale x 8 x i32> [[VS2:%.*]], <vscale x 8 x i32> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
339 // CHECK-RV64-NEXT: entry:
340 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 8 x i32> @llvm.riscv.vror.nxv8i32.nxv8i32.i64(<vscale x 8 x i32> poison, <vscale x 8 x i32> [[VS2]], <vscale x 8 x i32> [[VS1]], i64 [[VL]])
341 // CHECK-RV64-NEXT: ret <vscale x 8 x i32> [[TMP0]]
343 vuint32m4_t test_vror_vv_u32m4(vuint32m4_t vs2, vuint32m4_t vs1, size_t vl) {
344 return __riscv_vror_vv_u32m4(vs2, vs1, vl);
347 // CHECK-RV64-LABEL: define dso_local <vscale x 8 x i32> @test_vror_vx_u32m4
348 // CHECK-RV64-SAME: (<vscale x 8 x i32> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
349 // CHECK-RV64-NEXT: entry:
350 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 8 x i32> @llvm.riscv.vror.nxv8i32.i64.i64(<vscale x 8 x i32> poison, <vscale x 8 x i32> [[VS2]], i64 [[RS1]], i64 [[VL]])
351 // CHECK-RV64-NEXT: ret <vscale x 8 x i32> [[TMP0]]
353 vuint32m4_t test_vror_vx_u32m4(vuint32m4_t vs2, size_t rs1, size_t vl) {
354 return __riscv_vror_vx_u32m4(vs2, rs1, vl);
357 // CHECK-RV64-LABEL: define dso_local <vscale x 16 x i32> @test_vror_vv_u32m8
358 // CHECK-RV64-SAME: (<vscale x 16 x i32> [[VS2:%.*]], <vscale x 16 x i32> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
359 // CHECK-RV64-NEXT: entry:
360 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 16 x i32> @llvm.riscv.vror.nxv16i32.nxv16i32.i64(<vscale x 16 x i32> poison, <vscale x 16 x i32> [[VS2]], <vscale x 16 x i32> [[VS1]], i64 [[VL]])
361 // CHECK-RV64-NEXT: ret <vscale x 16 x i32> [[TMP0]]
363 vuint32m8_t test_vror_vv_u32m8(vuint32m8_t vs2, vuint32m8_t vs1, size_t vl) {
364 return __riscv_vror_vv_u32m8(vs2, vs1, vl);
367 // CHECK-RV64-LABEL: define dso_local <vscale x 16 x i32> @test_vror_vx_u32m8
368 // CHECK-RV64-SAME: (<vscale x 16 x i32> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
369 // CHECK-RV64-NEXT: entry:
370 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 16 x i32> @llvm.riscv.vror.nxv16i32.i64.i64(<vscale x 16 x i32> poison, <vscale x 16 x i32> [[VS2]], i64 [[RS1]], i64 [[VL]])
371 // CHECK-RV64-NEXT: ret <vscale x 16 x i32> [[TMP0]]
373 vuint32m8_t test_vror_vx_u32m8(vuint32m8_t vs2, size_t rs1, size_t vl) {
374 return __riscv_vror_vx_u32m8(vs2, rs1, vl);
377 // CHECK-RV64-LABEL: define dso_local <vscale x 1 x i64> @test_vror_vv_u64m1
378 // CHECK-RV64-SAME: (<vscale x 1 x i64> [[VS2:%.*]], <vscale x 1 x i64> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
379 // CHECK-RV64-NEXT: entry:
380 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 1 x i64> @llvm.riscv.vror.nxv1i64.nxv1i64.i64(<vscale x 1 x i64> poison, <vscale x 1 x i64> [[VS2]], <vscale x 1 x i64> [[VS1]], i64 [[VL]])
381 // CHECK-RV64-NEXT: ret <vscale x 1 x i64> [[TMP0]]
383 vuint64m1_t test_vror_vv_u64m1(vuint64m1_t vs2, vuint64m1_t vs1, size_t vl) {
384 return __riscv_vror_vv_u64m1(vs2, vs1, vl);
387 // CHECK-RV64-LABEL: define dso_local <vscale x 1 x i64> @test_vror_vx_u64m1
388 // CHECK-RV64-SAME: (<vscale x 1 x i64> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
389 // CHECK-RV64-NEXT: entry:
390 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 1 x i64> @llvm.riscv.vror.nxv1i64.i64.i64(<vscale x 1 x i64> poison, <vscale x 1 x i64> [[VS2]], i64 [[RS1]], i64 [[VL]])
391 // CHECK-RV64-NEXT: ret <vscale x 1 x i64> [[TMP0]]
393 vuint64m1_t test_vror_vx_u64m1(vuint64m1_t vs2, size_t rs1, size_t vl) {
394 return __riscv_vror_vx_u64m1(vs2, rs1, vl);
397 // CHECK-RV64-LABEL: define dso_local <vscale x 2 x i64> @test_vror_vv_u64m2
398 // CHECK-RV64-SAME: (<vscale x 2 x i64> [[VS2:%.*]], <vscale x 2 x i64> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
399 // CHECK-RV64-NEXT: entry:
400 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 2 x i64> @llvm.riscv.vror.nxv2i64.nxv2i64.i64(<vscale x 2 x i64> poison, <vscale x 2 x i64> [[VS2]], <vscale x 2 x i64> [[VS1]], i64 [[VL]])
401 // CHECK-RV64-NEXT: ret <vscale x 2 x i64> [[TMP0]]
403 vuint64m2_t test_vror_vv_u64m2(vuint64m2_t vs2, vuint64m2_t vs1, size_t vl) {
404 return __riscv_vror_vv_u64m2(vs2, vs1, vl);
407 // CHECK-RV64-LABEL: define dso_local <vscale x 2 x i64> @test_vror_vx_u64m2
408 // CHECK-RV64-SAME: (<vscale x 2 x i64> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
409 // CHECK-RV64-NEXT: entry:
410 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 2 x i64> @llvm.riscv.vror.nxv2i64.i64.i64(<vscale x 2 x i64> poison, <vscale x 2 x i64> [[VS2]], i64 [[RS1]], i64 [[VL]])
411 // CHECK-RV64-NEXT: ret <vscale x 2 x i64> [[TMP0]]
413 vuint64m2_t test_vror_vx_u64m2(vuint64m2_t vs2, size_t rs1, size_t vl) {
414 return __riscv_vror_vx_u64m2(vs2, rs1, vl);
417 // CHECK-RV64-LABEL: define dso_local <vscale x 4 x i64> @test_vror_vv_u64m4
418 // CHECK-RV64-SAME: (<vscale x 4 x i64> [[VS2:%.*]], <vscale x 4 x i64> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
419 // CHECK-RV64-NEXT: entry:
420 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 4 x i64> @llvm.riscv.vror.nxv4i64.nxv4i64.i64(<vscale x 4 x i64> poison, <vscale x 4 x i64> [[VS2]], <vscale x 4 x i64> [[VS1]], i64 [[VL]])
421 // CHECK-RV64-NEXT: ret <vscale x 4 x i64> [[TMP0]]
423 vuint64m4_t test_vror_vv_u64m4(vuint64m4_t vs2, vuint64m4_t vs1, size_t vl) {
424 return __riscv_vror_vv_u64m4(vs2, vs1, vl);
427 // CHECK-RV64-LABEL: define dso_local <vscale x 4 x i64> @test_vror_vx_u64m4
428 // CHECK-RV64-SAME: (<vscale x 4 x i64> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
429 // CHECK-RV64-NEXT: entry:
430 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 4 x i64> @llvm.riscv.vror.nxv4i64.i64.i64(<vscale x 4 x i64> poison, <vscale x 4 x i64> [[VS2]], i64 [[RS1]], i64 [[VL]])
431 // CHECK-RV64-NEXT: ret <vscale x 4 x i64> [[TMP0]]
433 vuint64m4_t test_vror_vx_u64m4(vuint64m4_t vs2, size_t rs1, size_t vl) {
434 return __riscv_vror_vx_u64m4(vs2, rs1, vl);
437 // CHECK-RV64-LABEL: define dso_local <vscale x 8 x i64> @test_vror_vv_u64m8
438 // CHECK-RV64-SAME: (<vscale x 8 x i64> [[VS2:%.*]], <vscale x 8 x i64> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
439 // CHECK-RV64-NEXT: entry:
440 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 8 x i64> @llvm.riscv.vror.nxv8i64.nxv8i64.i64(<vscale x 8 x i64> poison, <vscale x 8 x i64> [[VS2]], <vscale x 8 x i64> [[VS1]], i64 [[VL]])
441 // CHECK-RV64-NEXT: ret <vscale x 8 x i64> [[TMP0]]
443 vuint64m8_t test_vror_vv_u64m8(vuint64m8_t vs2, vuint64m8_t vs1, size_t vl) {
444 return __riscv_vror_vv_u64m8(vs2, vs1, vl);
447 // CHECK-RV64-LABEL: define dso_local <vscale x 8 x i64> @test_vror_vx_u64m8
448 // CHECK-RV64-SAME: (<vscale x 8 x i64> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
449 // CHECK-RV64-NEXT: entry:
450 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 8 x i64> @llvm.riscv.vror.nxv8i64.i64.i64(<vscale x 8 x i64> poison, <vscale x 8 x i64> [[VS2]], i64 [[RS1]], i64 [[VL]])
451 // CHECK-RV64-NEXT: ret <vscale x 8 x i64> [[TMP0]]
453 vuint64m8_t test_vror_vx_u64m8(vuint64m8_t vs2, size_t rs1, size_t vl) {
454 return __riscv_vror_vx_u64m8(vs2, rs1, vl);
457 // CHECK-RV64-LABEL: define dso_local <vscale x 1 x i8> @test_vror_vv_u8mf8_m
458 // CHECK-RV64-SAME: (<vscale x 1 x i1> [[MASK:%.*]], <vscale x 1 x i8> [[VS2:%.*]], <vscale x 1 x i8> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
459 // CHECK-RV64-NEXT: entry:
460 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 1 x i8> @llvm.riscv.vror.mask.nxv1i8.nxv1i8.i64(<vscale x 1 x i8> poison, <vscale x 1 x i8> [[VS2]], <vscale x 1 x i8> [[VS1]], <vscale x 1 x i1> [[MASK]], i64 [[VL]], i64 3)
461 // CHECK-RV64-NEXT: ret <vscale x 1 x i8> [[TMP0]]
463 vuint8mf8_t test_vror_vv_u8mf8_m(vbool64_t mask, vuint8mf8_t vs2, vuint8mf8_t vs1, size_t vl) {
464 return __riscv_vror_vv_u8mf8_m(mask, vs2, vs1, vl);
467 // CHECK-RV64-LABEL: define dso_local <vscale x 1 x i8> @test_vror_vx_u8mf8_m
468 // CHECK-RV64-SAME: (<vscale x 1 x i1> [[MASK:%.*]], <vscale x 1 x i8> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
469 // CHECK-RV64-NEXT: entry:
470 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 1 x i8> @llvm.riscv.vror.mask.nxv1i8.i64.i64(<vscale x 1 x i8> poison, <vscale x 1 x i8> [[VS2]], i64 [[RS1]], <vscale x 1 x i1> [[MASK]], i64 [[VL]], i64 3)
471 // CHECK-RV64-NEXT: ret <vscale x 1 x i8> [[TMP0]]
473 vuint8mf8_t test_vror_vx_u8mf8_m(vbool64_t mask, vuint8mf8_t vs2, size_t rs1, size_t vl) {
474 return __riscv_vror_vx_u8mf8_m(mask, vs2, rs1, vl);
477 // CHECK-RV64-LABEL: define dso_local <vscale x 2 x i8> @test_vror_vv_u8mf4_m
478 // CHECK-RV64-SAME: (<vscale x 2 x i1> [[MASK:%.*]], <vscale x 2 x i8> [[VS2:%.*]], <vscale x 2 x i8> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
479 // CHECK-RV64-NEXT: entry:
480 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 2 x i8> @llvm.riscv.vror.mask.nxv2i8.nxv2i8.i64(<vscale x 2 x i8> poison, <vscale x 2 x i8> [[VS2]], <vscale x 2 x i8> [[VS1]], <vscale x 2 x i1> [[MASK]], i64 [[VL]], i64 3)
481 // CHECK-RV64-NEXT: ret <vscale x 2 x i8> [[TMP0]]
483 vuint8mf4_t test_vror_vv_u8mf4_m(vbool32_t mask, vuint8mf4_t vs2, vuint8mf4_t vs1, size_t vl) {
484 return __riscv_vror_vv_u8mf4_m(mask, vs2, vs1, vl);
487 // CHECK-RV64-LABEL: define dso_local <vscale x 2 x i8> @test_vror_vx_u8mf4_m
488 // CHECK-RV64-SAME: (<vscale x 2 x i1> [[MASK:%.*]], <vscale x 2 x i8> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
489 // CHECK-RV64-NEXT: entry:
490 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 2 x i8> @llvm.riscv.vror.mask.nxv2i8.i64.i64(<vscale x 2 x i8> poison, <vscale x 2 x i8> [[VS2]], i64 [[RS1]], <vscale x 2 x i1> [[MASK]], i64 [[VL]], i64 3)
491 // CHECK-RV64-NEXT: ret <vscale x 2 x i8> [[TMP0]]
493 vuint8mf4_t test_vror_vx_u8mf4_m(vbool32_t mask, vuint8mf4_t vs2, size_t rs1, size_t vl) {
494 return __riscv_vror_vx_u8mf4_m(mask, vs2, rs1, vl);
497 // CHECK-RV64-LABEL: define dso_local <vscale x 4 x i8> @test_vror_vv_u8mf2_m
498 // CHECK-RV64-SAME: (<vscale x 4 x i1> [[MASK:%.*]], <vscale x 4 x i8> [[VS2:%.*]], <vscale x 4 x i8> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
499 // CHECK-RV64-NEXT: entry:
500 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 4 x i8> @llvm.riscv.vror.mask.nxv4i8.nxv4i8.i64(<vscale x 4 x i8> poison, <vscale x 4 x i8> [[VS2]], <vscale x 4 x i8> [[VS1]], <vscale x 4 x i1> [[MASK]], i64 [[VL]], i64 3)
501 // CHECK-RV64-NEXT: ret <vscale x 4 x i8> [[TMP0]]
503 vuint8mf2_t test_vror_vv_u8mf2_m(vbool16_t mask, vuint8mf2_t vs2, vuint8mf2_t vs1, size_t vl) {
504 return __riscv_vror_vv_u8mf2_m(mask, vs2, vs1, vl);
507 // CHECK-RV64-LABEL: define dso_local <vscale x 4 x i8> @test_vror_vx_u8mf2_m
508 // CHECK-RV64-SAME: (<vscale x 4 x i1> [[MASK:%.*]], <vscale x 4 x i8> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
509 // CHECK-RV64-NEXT: entry:
510 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 4 x i8> @llvm.riscv.vror.mask.nxv4i8.i64.i64(<vscale x 4 x i8> poison, <vscale x 4 x i8> [[VS2]], i64 [[RS1]], <vscale x 4 x i1> [[MASK]], i64 [[VL]], i64 3)
511 // CHECK-RV64-NEXT: ret <vscale x 4 x i8> [[TMP0]]
513 vuint8mf2_t test_vror_vx_u8mf2_m(vbool16_t mask, vuint8mf2_t vs2, size_t rs1, size_t vl) {
514 return __riscv_vror_vx_u8mf2_m(mask, vs2, rs1, vl);
517 // CHECK-RV64-LABEL: define dso_local <vscale x 8 x i8> @test_vror_vv_u8m1_m
518 // CHECK-RV64-SAME: (<vscale x 8 x i1> [[MASK:%.*]], <vscale x 8 x i8> [[VS2:%.*]], <vscale x 8 x i8> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
519 // CHECK-RV64-NEXT: entry:
520 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 8 x i8> @llvm.riscv.vror.mask.nxv8i8.nxv8i8.i64(<vscale x 8 x i8> poison, <vscale x 8 x i8> [[VS2]], <vscale x 8 x i8> [[VS1]], <vscale x 8 x i1> [[MASK]], i64 [[VL]], i64 3)
521 // CHECK-RV64-NEXT: ret <vscale x 8 x i8> [[TMP0]]
523 vuint8m1_t test_vror_vv_u8m1_m(vbool8_t mask, vuint8m1_t vs2, vuint8m1_t vs1, size_t vl) {
524 return __riscv_vror_vv_u8m1_m(mask, vs2, vs1, vl);
527 // CHECK-RV64-LABEL: define dso_local <vscale x 8 x i8> @test_vror_vx_u8m1_m
528 // CHECK-RV64-SAME: (<vscale x 8 x i1> [[MASK:%.*]], <vscale x 8 x i8> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
529 // CHECK-RV64-NEXT: entry:
530 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 8 x i8> @llvm.riscv.vror.mask.nxv8i8.i64.i64(<vscale x 8 x i8> poison, <vscale x 8 x i8> [[VS2]], i64 [[RS1]], <vscale x 8 x i1> [[MASK]], i64 [[VL]], i64 3)
531 // CHECK-RV64-NEXT: ret <vscale x 8 x i8> [[TMP0]]
533 vuint8m1_t test_vror_vx_u8m1_m(vbool8_t mask, vuint8m1_t vs2, size_t rs1, size_t vl) {
534 return __riscv_vror_vx_u8m1_m(mask, vs2, rs1, vl);
537 // CHECK-RV64-LABEL: define dso_local <vscale x 16 x i8> @test_vror_vv_u8m2_m
538 // CHECK-RV64-SAME: (<vscale x 16 x i1> [[MASK:%.*]], <vscale x 16 x i8> [[VS2:%.*]], <vscale x 16 x i8> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
539 // CHECK-RV64-NEXT: entry:
540 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 16 x i8> @llvm.riscv.vror.mask.nxv16i8.nxv16i8.i64(<vscale x 16 x i8> poison, <vscale x 16 x i8> [[VS2]], <vscale x 16 x i8> [[VS1]], <vscale x 16 x i1> [[MASK]], i64 [[VL]], i64 3)
541 // CHECK-RV64-NEXT: ret <vscale x 16 x i8> [[TMP0]]
543 vuint8m2_t test_vror_vv_u8m2_m(vbool4_t mask, vuint8m2_t vs2, vuint8m2_t vs1, size_t vl) {
544 return __riscv_vror_vv_u8m2_m(mask, vs2, vs1, vl);
547 // CHECK-RV64-LABEL: define dso_local <vscale x 16 x i8> @test_vror_vx_u8m2_m
548 // CHECK-RV64-SAME: (<vscale x 16 x i1> [[MASK:%.*]], <vscale x 16 x i8> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
549 // CHECK-RV64-NEXT: entry:
550 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 16 x i8> @llvm.riscv.vror.mask.nxv16i8.i64.i64(<vscale x 16 x i8> poison, <vscale x 16 x i8> [[VS2]], i64 [[RS1]], <vscale x 16 x i1> [[MASK]], i64 [[VL]], i64 3)
551 // CHECK-RV64-NEXT: ret <vscale x 16 x i8> [[TMP0]]
553 vuint8m2_t test_vror_vx_u8m2_m(vbool4_t mask, vuint8m2_t vs2, size_t rs1, size_t vl) {
554 return __riscv_vror_vx_u8m2_m(mask, vs2, rs1, vl);
557 // CHECK-RV64-LABEL: define dso_local <vscale x 32 x i8> @test_vror_vv_u8m4_m
558 // CHECK-RV64-SAME: (<vscale x 32 x i1> [[MASK:%.*]], <vscale x 32 x i8> [[VS2:%.*]], <vscale x 32 x i8> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
559 // CHECK-RV64-NEXT: entry:
560 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 32 x i8> @llvm.riscv.vror.mask.nxv32i8.nxv32i8.i64(<vscale x 32 x i8> poison, <vscale x 32 x i8> [[VS2]], <vscale x 32 x i8> [[VS1]], <vscale x 32 x i1> [[MASK]], i64 [[VL]], i64 3)
561 // CHECK-RV64-NEXT: ret <vscale x 32 x i8> [[TMP0]]
563 vuint8m4_t test_vror_vv_u8m4_m(vbool2_t mask, vuint8m4_t vs2, vuint8m4_t vs1, size_t vl) {
564 return __riscv_vror_vv_u8m4_m(mask, vs2, vs1, vl);
567 // CHECK-RV64-LABEL: define dso_local <vscale x 32 x i8> @test_vror_vx_u8m4_m
568 // CHECK-RV64-SAME: (<vscale x 32 x i1> [[MASK:%.*]], <vscale x 32 x i8> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
569 // CHECK-RV64-NEXT: entry:
570 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 32 x i8> @llvm.riscv.vror.mask.nxv32i8.i64.i64(<vscale x 32 x i8> poison, <vscale x 32 x i8> [[VS2]], i64 [[RS1]], <vscale x 32 x i1> [[MASK]], i64 [[VL]], i64 3)
571 // CHECK-RV64-NEXT: ret <vscale x 32 x i8> [[TMP0]]
573 vuint8m4_t test_vror_vx_u8m4_m(vbool2_t mask, vuint8m4_t vs2, size_t rs1, size_t vl) {
574 return __riscv_vror_vx_u8m4_m(mask, vs2, rs1, vl);
577 // CHECK-RV64-LABEL: define dso_local <vscale x 64 x i8> @test_vror_vv_u8m8_m
578 // CHECK-RV64-SAME: (<vscale x 64 x i1> [[MASK:%.*]], <vscale x 64 x i8> [[VS2:%.*]], <vscale x 64 x i8> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
579 // CHECK-RV64-NEXT: entry:
580 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 64 x i8> @llvm.riscv.vror.mask.nxv64i8.nxv64i8.i64(<vscale x 64 x i8> poison, <vscale x 64 x i8> [[VS2]], <vscale x 64 x i8> [[VS1]], <vscale x 64 x i1> [[MASK]], i64 [[VL]], i64 3)
581 // CHECK-RV64-NEXT: ret <vscale x 64 x i8> [[TMP0]]
583 vuint8m8_t test_vror_vv_u8m8_m(vbool1_t mask, vuint8m8_t vs2, vuint8m8_t vs1, size_t vl) {
584 return __riscv_vror_vv_u8m8_m(mask, vs2, vs1, vl);
587 // CHECK-RV64-LABEL: define dso_local <vscale x 64 x i8> @test_vror_vx_u8m8_m
588 // CHECK-RV64-SAME: (<vscale x 64 x i1> [[MASK:%.*]], <vscale x 64 x i8> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
589 // CHECK-RV64-NEXT: entry:
590 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 64 x i8> @llvm.riscv.vror.mask.nxv64i8.i64.i64(<vscale x 64 x i8> poison, <vscale x 64 x i8> [[VS2]], i64 [[RS1]], <vscale x 64 x i1> [[MASK]], i64 [[VL]], i64 3)
591 // CHECK-RV64-NEXT: ret <vscale x 64 x i8> [[TMP0]]
593 vuint8m8_t test_vror_vx_u8m8_m(vbool1_t mask, vuint8m8_t vs2, size_t rs1, size_t vl) {
594 return __riscv_vror_vx_u8m8_m(mask, vs2, rs1, vl);
597 // CHECK-RV64-LABEL: define dso_local <vscale x 1 x i16> @test_vror_vv_u16mf4_m
598 // CHECK-RV64-SAME: (<vscale x 1 x i1> [[MASK:%.*]], <vscale x 1 x i16> [[VS2:%.*]], <vscale x 1 x i16> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
599 // CHECK-RV64-NEXT: entry:
600 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 1 x i16> @llvm.riscv.vror.mask.nxv1i16.nxv1i16.i64(<vscale x 1 x i16> poison, <vscale x 1 x i16> [[VS2]], <vscale x 1 x i16> [[VS1]], <vscale x 1 x i1> [[MASK]], i64 [[VL]], i64 3)
601 // CHECK-RV64-NEXT: ret <vscale x 1 x i16> [[TMP0]]
603 vuint16mf4_t test_vror_vv_u16mf4_m(vbool64_t mask, vuint16mf4_t vs2, vuint16mf4_t vs1, size_t vl) {
604 return __riscv_vror_vv_u16mf4_m(mask, vs2, vs1, vl);
607 // CHECK-RV64-LABEL: define dso_local <vscale x 1 x i16> @test_vror_vx_u16mf4_m
608 // CHECK-RV64-SAME: (<vscale x 1 x i1> [[MASK:%.*]], <vscale x 1 x i16> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
609 // CHECK-RV64-NEXT: entry:
610 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 1 x i16> @llvm.riscv.vror.mask.nxv1i16.i64.i64(<vscale x 1 x i16> poison, <vscale x 1 x i16> [[VS2]], i64 [[RS1]], <vscale x 1 x i1> [[MASK]], i64 [[VL]], i64 3)
611 // CHECK-RV64-NEXT: ret <vscale x 1 x i16> [[TMP0]]
613 vuint16mf4_t test_vror_vx_u16mf4_m(vbool64_t mask, vuint16mf4_t vs2, size_t rs1, size_t vl) {
614 return __riscv_vror_vx_u16mf4_m(mask, vs2, rs1, vl);
617 // CHECK-RV64-LABEL: define dso_local <vscale x 2 x i16> @test_vror_vv_u16mf2_m
618 // CHECK-RV64-SAME: (<vscale x 2 x i1> [[MASK:%.*]], <vscale x 2 x i16> [[VS2:%.*]], <vscale x 2 x i16> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
619 // CHECK-RV64-NEXT: entry:
620 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 2 x i16> @llvm.riscv.vror.mask.nxv2i16.nxv2i16.i64(<vscale x 2 x i16> poison, <vscale x 2 x i16> [[VS2]], <vscale x 2 x i16> [[VS1]], <vscale x 2 x i1> [[MASK]], i64 [[VL]], i64 3)
621 // CHECK-RV64-NEXT: ret <vscale x 2 x i16> [[TMP0]]
623 vuint16mf2_t test_vror_vv_u16mf2_m(vbool32_t mask, vuint16mf2_t vs2, vuint16mf2_t vs1, size_t vl) {
624 return __riscv_vror_vv_u16mf2_m(mask, vs2, vs1, vl);
627 // CHECK-RV64-LABEL: define dso_local <vscale x 2 x i16> @test_vror_vx_u16mf2_m
628 // CHECK-RV64-SAME: (<vscale x 2 x i1> [[MASK:%.*]], <vscale x 2 x i16> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
629 // CHECK-RV64-NEXT: entry:
630 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 2 x i16> @llvm.riscv.vror.mask.nxv2i16.i64.i64(<vscale x 2 x i16> poison, <vscale x 2 x i16> [[VS2]], i64 [[RS1]], <vscale x 2 x i1> [[MASK]], i64 [[VL]], i64 3)
631 // CHECK-RV64-NEXT: ret <vscale x 2 x i16> [[TMP0]]
633 vuint16mf2_t test_vror_vx_u16mf2_m(vbool32_t mask, vuint16mf2_t vs2, size_t rs1, size_t vl) {
634 return __riscv_vror_vx_u16mf2_m(mask, vs2, rs1, vl);
637 // CHECK-RV64-LABEL: define dso_local <vscale x 4 x i16> @test_vror_vv_u16m1_m
638 // CHECK-RV64-SAME: (<vscale x 4 x i1> [[MASK:%.*]], <vscale x 4 x i16> [[VS2:%.*]], <vscale x 4 x i16> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
639 // CHECK-RV64-NEXT: entry:
640 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 4 x i16> @llvm.riscv.vror.mask.nxv4i16.nxv4i16.i64(<vscale x 4 x i16> poison, <vscale x 4 x i16> [[VS2]], <vscale x 4 x i16> [[VS1]], <vscale x 4 x i1> [[MASK]], i64 [[VL]], i64 3)
641 // CHECK-RV64-NEXT: ret <vscale x 4 x i16> [[TMP0]]
643 vuint16m1_t test_vror_vv_u16m1_m(vbool16_t mask, vuint16m1_t vs2, vuint16m1_t vs1, size_t vl) {
644 return __riscv_vror_vv_u16m1_m(mask, vs2, vs1, vl);
647 // CHECK-RV64-LABEL: define dso_local <vscale x 4 x i16> @test_vror_vx_u16m1_m
648 // CHECK-RV64-SAME: (<vscale x 4 x i1> [[MASK:%.*]], <vscale x 4 x i16> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
649 // CHECK-RV64-NEXT: entry:
650 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 4 x i16> @llvm.riscv.vror.mask.nxv4i16.i64.i64(<vscale x 4 x i16> poison, <vscale x 4 x i16> [[VS2]], i64 [[RS1]], <vscale x 4 x i1> [[MASK]], i64 [[VL]], i64 3)
651 // CHECK-RV64-NEXT: ret <vscale x 4 x i16> [[TMP0]]
653 vuint16m1_t test_vror_vx_u16m1_m(vbool16_t mask, vuint16m1_t vs2, size_t rs1, size_t vl) {
654 return __riscv_vror_vx_u16m1_m(mask, vs2, rs1, vl);
657 // CHECK-RV64-LABEL: define dso_local <vscale x 8 x i16> @test_vror_vv_u16m2_m
658 // CHECK-RV64-SAME: (<vscale x 8 x i1> [[MASK:%.*]], <vscale x 8 x i16> [[VS2:%.*]], <vscale x 8 x i16> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
659 // CHECK-RV64-NEXT: entry:
660 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 8 x i16> @llvm.riscv.vror.mask.nxv8i16.nxv8i16.i64(<vscale x 8 x i16> poison, <vscale x 8 x i16> [[VS2]], <vscale x 8 x i16> [[VS1]], <vscale x 8 x i1> [[MASK]], i64 [[VL]], i64 3)
661 // CHECK-RV64-NEXT: ret <vscale x 8 x i16> [[TMP0]]
663 vuint16m2_t test_vror_vv_u16m2_m(vbool8_t mask, vuint16m2_t vs2, vuint16m2_t vs1, size_t vl) {
664 return __riscv_vror_vv_u16m2_m(mask, vs2, vs1, vl);
667 // CHECK-RV64-LABEL: define dso_local <vscale x 8 x i16> @test_vror_vx_u16m2_m
668 // CHECK-RV64-SAME: (<vscale x 8 x i1> [[MASK:%.*]], <vscale x 8 x i16> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
669 // CHECK-RV64-NEXT: entry:
670 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 8 x i16> @llvm.riscv.vror.mask.nxv8i16.i64.i64(<vscale x 8 x i16> poison, <vscale x 8 x i16> [[VS2]], i64 [[RS1]], <vscale x 8 x i1> [[MASK]], i64 [[VL]], i64 3)
671 // CHECK-RV64-NEXT: ret <vscale x 8 x i16> [[TMP0]]
673 vuint16m2_t test_vror_vx_u16m2_m(vbool8_t mask, vuint16m2_t vs2, size_t rs1, size_t vl) {
674 return __riscv_vror_vx_u16m2_m(mask, vs2, rs1, vl);
677 // CHECK-RV64-LABEL: define dso_local <vscale x 16 x i16> @test_vror_vv_u16m4_m
678 // CHECK-RV64-SAME: (<vscale x 16 x i1> [[MASK:%.*]], <vscale x 16 x i16> [[VS2:%.*]], <vscale x 16 x i16> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
679 // CHECK-RV64-NEXT: entry:
680 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 16 x i16> @llvm.riscv.vror.mask.nxv16i16.nxv16i16.i64(<vscale x 16 x i16> poison, <vscale x 16 x i16> [[VS2]], <vscale x 16 x i16> [[VS1]], <vscale x 16 x i1> [[MASK]], i64 [[VL]], i64 3)
681 // CHECK-RV64-NEXT: ret <vscale x 16 x i16> [[TMP0]]
683 vuint16m4_t test_vror_vv_u16m4_m(vbool4_t mask, vuint16m4_t vs2, vuint16m4_t vs1, size_t vl) {
684 return __riscv_vror_vv_u16m4_m(mask, vs2, vs1, vl);
687 // CHECK-RV64-LABEL: define dso_local <vscale x 16 x i16> @test_vror_vx_u16m4_m
688 // CHECK-RV64-SAME: (<vscale x 16 x i1> [[MASK:%.*]], <vscale x 16 x i16> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
689 // CHECK-RV64-NEXT: entry:
690 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 16 x i16> @llvm.riscv.vror.mask.nxv16i16.i64.i64(<vscale x 16 x i16> poison, <vscale x 16 x i16> [[VS2]], i64 [[RS1]], <vscale x 16 x i1> [[MASK]], i64 [[VL]], i64 3)
691 // CHECK-RV64-NEXT: ret <vscale x 16 x i16> [[TMP0]]
693 vuint16m4_t test_vror_vx_u16m4_m(vbool4_t mask, vuint16m4_t vs2, size_t rs1, size_t vl) {
694 return __riscv_vror_vx_u16m4_m(mask, vs2, rs1, vl);
697 // CHECK-RV64-LABEL: define dso_local <vscale x 32 x i16> @test_vror_vv_u16m8_m
698 // CHECK-RV64-SAME: (<vscale x 32 x i1> [[MASK:%.*]], <vscale x 32 x i16> [[VS2:%.*]], <vscale x 32 x i16> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
699 // CHECK-RV64-NEXT: entry:
700 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 32 x i16> @llvm.riscv.vror.mask.nxv32i16.nxv32i16.i64(<vscale x 32 x i16> poison, <vscale x 32 x i16> [[VS2]], <vscale x 32 x i16> [[VS1]], <vscale x 32 x i1> [[MASK]], i64 [[VL]], i64 3)
701 // CHECK-RV64-NEXT: ret <vscale x 32 x i16> [[TMP0]]
703 vuint16m8_t test_vror_vv_u16m8_m(vbool2_t mask, vuint16m8_t vs2, vuint16m8_t vs1, size_t vl) {
704 return __riscv_vror_vv_u16m8_m(mask, vs2, vs1, vl);
707 // CHECK-RV64-LABEL: define dso_local <vscale x 32 x i16> @test_vror_vx_u16m8_m
708 // CHECK-RV64-SAME: (<vscale x 32 x i1> [[MASK:%.*]], <vscale x 32 x i16> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
709 // CHECK-RV64-NEXT: entry:
710 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 32 x i16> @llvm.riscv.vror.mask.nxv32i16.i64.i64(<vscale x 32 x i16> poison, <vscale x 32 x i16> [[VS2]], i64 [[RS1]], <vscale x 32 x i1> [[MASK]], i64 [[VL]], i64 3)
711 // CHECK-RV64-NEXT: ret <vscale x 32 x i16> [[TMP0]]
713 vuint16m8_t test_vror_vx_u16m8_m(vbool2_t mask, vuint16m8_t vs2, size_t rs1, size_t vl) {
714 return __riscv_vror_vx_u16m8_m(mask, vs2, rs1, vl);
717 // CHECK-RV64-LABEL: define dso_local <vscale x 1 x i32> @test_vror_vv_u32mf2_m
718 // CHECK-RV64-SAME: (<vscale x 1 x i1> [[MASK:%.*]], <vscale x 1 x i32> [[VS2:%.*]], <vscale x 1 x i32> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
719 // CHECK-RV64-NEXT: entry:
720 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 1 x i32> @llvm.riscv.vror.mask.nxv1i32.nxv1i32.i64(<vscale x 1 x i32> poison, <vscale x 1 x i32> [[VS2]], <vscale x 1 x i32> [[VS1]], <vscale x 1 x i1> [[MASK]], i64 [[VL]], i64 3)
721 // CHECK-RV64-NEXT: ret <vscale x 1 x i32> [[TMP0]]
723 vuint32mf2_t test_vror_vv_u32mf2_m(vbool64_t mask, vuint32mf2_t vs2, vuint32mf2_t vs1, size_t vl) {
724 return __riscv_vror_vv_u32mf2_m(mask, vs2, vs1, vl);
727 // CHECK-RV64-LABEL: define dso_local <vscale x 1 x i32> @test_vror_vx_u32mf2_m
728 // CHECK-RV64-SAME: (<vscale x 1 x i1> [[MASK:%.*]], <vscale x 1 x i32> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
729 // CHECK-RV64-NEXT: entry:
730 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 1 x i32> @llvm.riscv.vror.mask.nxv1i32.i64.i64(<vscale x 1 x i32> poison, <vscale x 1 x i32> [[VS2]], i64 [[RS1]], <vscale x 1 x i1> [[MASK]], i64 [[VL]], i64 3)
731 // CHECK-RV64-NEXT: ret <vscale x 1 x i32> [[TMP0]]
733 vuint32mf2_t test_vror_vx_u32mf2_m(vbool64_t mask, vuint32mf2_t vs2, size_t rs1, size_t vl) {
734 return __riscv_vror_vx_u32mf2_m(mask, vs2, rs1, vl);
737 // CHECK-RV64-LABEL: define dso_local <vscale x 2 x i32> @test_vror_vv_u32m1_m
738 // CHECK-RV64-SAME: (<vscale x 2 x i1> [[MASK:%.*]], <vscale x 2 x i32> [[VS2:%.*]], <vscale x 2 x i32> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
739 // CHECK-RV64-NEXT: entry:
740 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 2 x i32> @llvm.riscv.vror.mask.nxv2i32.nxv2i32.i64(<vscale x 2 x i32> poison, <vscale x 2 x i32> [[VS2]], <vscale x 2 x i32> [[VS1]], <vscale x 2 x i1> [[MASK]], i64 [[VL]], i64 3)
741 // CHECK-RV64-NEXT: ret <vscale x 2 x i32> [[TMP0]]
743 vuint32m1_t test_vror_vv_u32m1_m(vbool32_t mask, vuint32m1_t vs2, vuint32m1_t vs1, size_t vl) {
744 return __riscv_vror_vv_u32m1_m(mask, vs2, vs1, vl);
747 // CHECK-RV64-LABEL: define dso_local <vscale x 2 x i32> @test_vror_vx_u32m1_m
748 // CHECK-RV64-SAME: (<vscale x 2 x i1> [[MASK:%.*]], <vscale x 2 x i32> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
749 // CHECK-RV64-NEXT: entry:
750 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 2 x i32> @llvm.riscv.vror.mask.nxv2i32.i64.i64(<vscale x 2 x i32> poison, <vscale x 2 x i32> [[VS2]], i64 [[RS1]], <vscale x 2 x i1> [[MASK]], i64 [[VL]], i64 3)
751 // CHECK-RV64-NEXT: ret <vscale x 2 x i32> [[TMP0]]
753 vuint32m1_t test_vror_vx_u32m1_m(vbool32_t mask, vuint32m1_t vs2, size_t rs1, size_t vl) {
754 return __riscv_vror_vx_u32m1_m(mask, vs2, rs1, vl);
757 // CHECK-RV64-LABEL: define dso_local <vscale x 4 x i32> @test_vror_vv_u32m2_m
758 // CHECK-RV64-SAME: (<vscale x 4 x i1> [[MASK:%.*]], <vscale x 4 x i32> [[VS2:%.*]], <vscale x 4 x i32> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
759 // CHECK-RV64-NEXT: entry:
760 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 4 x i32> @llvm.riscv.vror.mask.nxv4i32.nxv4i32.i64(<vscale x 4 x i32> poison, <vscale x 4 x i32> [[VS2]], <vscale x 4 x i32> [[VS1]], <vscale x 4 x i1> [[MASK]], i64 [[VL]], i64 3)
761 // CHECK-RV64-NEXT: ret <vscale x 4 x i32> [[TMP0]]
763 vuint32m2_t test_vror_vv_u32m2_m(vbool16_t mask, vuint32m2_t vs2, vuint32m2_t vs1, size_t vl) {
764 return __riscv_vror_vv_u32m2_m(mask, vs2, vs1, vl);
767 // CHECK-RV64-LABEL: define dso_local <vscale x 4 x i32> @test_vror_vx_u32m2_m
768 // CHECK-RV64-SAME: (<vscale x 4 x i1> [[MASK:%.*]], <vscale x 4 x i32> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
769 // CHECK-RV64-NEXT: entry:
770 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 4 x i32> @llvm.riscv.vror.mask.nxv4i32.i64.i64(<vscale x 4 x i32> poison, <vscale x 4 x i32> [[VS2]], i64 [[RS1]], <vscale x 4 x i1> [[MASK]], i64 [[VL]], i64 3)
771 // CHECK-RV64-NEXT: ret <vscale x 4 x i32> [[TMP0]]
773 vuint32m2_t test_vror_vx_u32m2_m(vbool16_t mask, vuint32m2_t vs2, size_t rs1, size_t vl) {
774 return __riscv_vror_vx_u32m2_m(mask, vs2, rs1, vl);
777 // CHECK-RV64-LABEL: define dso_local <vscale x 8 x i32> @test_vror_vv_u32m4_m
778 // CHECK-RV64-SAME: (<vscale x 8 x i1> [[MASK:%.*]], <vscale x 8 x i32> [[VS2:%.*]], <vscale x 8 x i32> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
779 // CHECK-RV64-NEXT: entry:
780 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 8 x i32> @llvm.riscv.vror.mask.nxv8i32.nxv8i32.i64(<vscale x 8 x i32> poison, <vscale x 8 x i32> [[VS2]], <vscale x 8 x i32> [[VS1]], <vscale x 8 x i1> [[MASK]], i64 [[VL]], i64 3)
781 // CHECK-RV64-NEXT: ret <vscale x 8 x i32> [[TMP0]]
783 vuint32m4_t test_vror_vv_u32m4_m(vbool8_t mask, vuint32m4_t vs2, vuint32m4_t vs1, size_t vl) {
784 return __riscv_vror_vv_u32m4_m(mask, vs2, vs1, vl);
787 // CHECK-RV64-LABEL: define dso_local <vscale x 8 x i32> @test_vror_vx_u32m4_m
788 // CHECK-RV64-SAME: (<vscale x 8 x i1> [[MASK:%.*]], <vscale x 8 x i32> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
789 // CHECK-RV64-NEXT: entry:
790 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 8 x i32> @llvm.riscv.vror.mask.nxv8i32.i64.i64(<vscale x 8 x i32> poison, <vscale x 8 x i32> [[VS2]], i64 [[RS1]], <vscale x 8 x i1> [[MASK]], i64 [[VL]], i64 3)
791 // CHECK-RV64-NEXT: ret <vscale x 8 x i32> [[TMP0]]
793 vuint32m4_t test_vror_vx_u32m4_m(vbool8_t mask, vuint32m4_t vs2, size_t rs1, size_t vl) {
794 return __riscv_vror_vx_u32m4_m(mask, vs2, rs1, vl);
797 // CHECK-RV64-LABEL: define dso_local <vscale x 16 x i32> @test_vror_vv_u32m8_m
798 // CHECK-RV64-SAME: (<vscale x 16 x i1> [[MASK:%.*]], <vscale x 16 x i32> [[VS2:%.*]], <vscale x 16 x i32> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
799 // CHECK-RV64-NEXT: entry:
800 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 16 x i32> @llvm.riscv.vror.mask.nxv16i32.nxv16i32.i64(<vscale x 16 x i32> poison, <vscale x 16 x i32> [[VS2]], <vscale x 16 x i32> [[VS1]], <vscale x 16 x i1> [[MASK]], i64 [[VL]], i64 3)
801 // CHECK-RV64-NEXT: ret <vscale x 16 x i32> [[TMP0]]
803 vuint32m8_t test_vror_vv_u32m8_m(vbool4_t mask, vuint32m8_t vs2, vuint32m8_t vs1, size_t vl) {
804 return __riscv_vror_vv_u32m8_m(mask, vs2, vs1, vl);
807 // CHECK-RV64-LABEL: define dso_local <vscale x 16 x i32> @test_vror_vx_u32m8_m
808 // CHECK-RV64-SAME: (<vscale x 16 x i1> [[MASK:%.*]], <vscale x 16 x i32> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
809 // CHECK-RV64-NEXT: entry:
810 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 16 x i32> @llvm.riscv.vror.mask.nxv16i32.i64.i64(<vscale x 16 x i32> poison, <vscale x 16 x i32> [[VS2]], i64 [[RS1]], <vscale x 16 x i1> [[MASK]], i64 [[VL]], i64 3)
811 // CHECK-RV64-NEXT: ret <vscale x 16 x i32> [[TMP0]]
813 vuint32m8_t test_vror_vx_u32m8_m(vbool4_t mask, vuint32m8_t vs2, size_t rs1, size_t vl) {
814 return __riscv_vror_vx_u32m8_m(mask, vs2, rs1, vl);
817 // CHECK-RV64-LABEL: define dso_local <vscale x 1 x i64> @test_vror_vv_u64m1_m
818 // CHECK-RV64-SAME: (<vscale x 1 x i1> [[MASK:%.*]], <vscale x 1 x i64> [[VS2:%.*]], <vscale x 1 x i64> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
819 // CHECK-RV64-NEXT: entry:
820 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 1 x i64> @llvm.riscv.vror.mask.nxv1i64.nxv1i64.i64(<vscale x 1 x i64> poison, <vscale x 1 x i64> [[VS2]], <vscale x 1 x i64> [[VS1]], <vscale x 1 x i1> [[MASK]], i64 [[VL]], i64 3)
821 // CHECK-RV64-NEXT: ret <vscale x 1 x i64> [[TMP0]]
823 vuint64m1_t test_vror_vv_u64m1_m(vbool64_t mask, vuint64m1_t vs2, vuint64m1_t vs1, size_t vl) {
824 return __riscv_vror_vv_u64m1_m(mask, vs2, vs1, vl);
827 // CHECK-RV64-LABEL: define dso_local <vscale x 1 x i64> @test_vror_vx_u64m1_m
828 // CHECK-RV64-SAME: (<vscale x 1 x i1> [[MASK:%.*]], <vscale x 1 x i64> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
829 // CHECK-RV64-NEXT: entry:
830 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 1 x i64> @llvm.riscv.vror.mask.nxv1i64.i64.i64(<vscale x 1 x i64> poison, <vscale x 1 x i64> [[VS2]], i64 [[RS1]], <vscale x 1 x i1> [[MASK]], i64 [[VL]], i64 3)
831 // CHECK-RV64-NEXT: ret <vscale x 1 x i64> [[TMP0]]
833 vuint64m1_t test_vror_vx_u64m1_m(vbool64_t mask, vuint64m1_t vs2, size_t rs1, size_t vl) {
834 return __riscv_vror_vx_u64m1_m(mask, vs2, rs1, vl);
837 // CHECK-RV64-LABEL: define dso_local <vscale x 2 x i64> @test_vror_vv_u64m2_m
838 // CHECK-RV64-SAME: (<vscale x 2 x i1> [[MASK:%.*]], <vscale x 2 x i64> [[VS2:%.*]], <vscale x 2 x i64> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
839 // CHECK-RV64-NEXT: entry:
840 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 2 x i64> @llvm.riscv.vror.mask.nxv2i64.nxv2i64.i64(<vscale x 2 x i64> poison, <vscale x 2 x i64> [[VS2]], <vscale x 2 x i64> [[VS1]], <vscale x 2 x i1> [[MASK]], i64 [[VL]], i64 3)
841 // CHECK-RV64-NEXT: ret <vscale x 2 x i64> [[TMP0]]
843 vuint64m2_t test_vror_vv_u64m2_m(vbool32_t mask, vuint64m2_t vs2, vuint64m2_t vs1, size_t vl) {
844 return __riscv_vror_vv_u64m2_m(mask, vs2, vs1, vl);
847 // CHECK-RV64-LABEL: define dso_local <vscale x 2 x i64> @test_vror_vx_u64m2_m
848 // CHECK-RV64-SAME: (<vscale x 2 x i1> [[MASK:%.*]], <vscale x 2 x i64> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
849 // CHECK-RV64-NEXT: entry:
850 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 2 x i64> @llvm.riscv.vror.mask.nxv2i64.i64.i64(<vscale x 2 x i64> poison, <vscale x 2 x i64> [[VS2]], i64 [[RS1]], <vscale x 2 x i1> [[MASK]], i64 [[VL]], i64 3)
851 // CHECK-RV64-NEXT: ret <vscale x 2 x i64> [[TMP0]]
853 vuint64m2_t test_vror_vx_u64m2_m(vbool32_t mask, vuint64m2_t vs2, size_t rs1, size_t vl) {
854 return __riscv_vror_vx_u64m2_m(mask, vs2, rs1, vl);
857 // CHECK-RV64-LABEL: define dso_local <vscale x 4 x i64> @test_vror_vv_u64m4_m
858 // CHECK-RV64-SAME: (<vscale x 4 x i1> [[MASK:%.*]], <vscale x 4 x i64> [[VS2:%.*]], <vscale x 4 x i64> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
859 // CHECK-RV64-NEXT: entry:
860 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 4 x i64> @llvm.riscv.vror.mask.nxv4i64.nxv4i64.i64(<vscale x 4 x i64> poison, <vscale x 4 x i64> [[VS2]], <vscale x 4 x i64> [[VS1]], <vscale x 4 x i1> [[MASK]], i64 [[VL]], i64 3)
861 // CHECK-RV64-NEXT: ret <vscale x 4 x i64> [[TMP0]]
863 vuint64m4_t test_vror_vv_u64m4_m(vbool16_t mask, vuint64m4_t vs2, vuint64m4_t vs1, size_t vl) {
864 return __riscv_vror_vv_u64m4_m(mask, vs2, vs1, vl);
867 // CHECK-RV64-LABEL: define dso_local <vscale x 4 x i64> @test_vror_vx_u64m4_m
868 // CHECK-RV64-SAME: (<vscale x 4 x i1> [[MASK:%.*]], <vscale x 4 x i64> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
869 // CHECK-RV64-NEXT: entry:
870 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 4 x i64> @llvm.riscv.vror.mask.nxv4i64.i64.i64(<vscale x 4 x i64> poison, <vscale x 4 x i64> [[VS2]], i64 [[RS1]], <vscale x 4 x i1> [[MASK]], i64 [[VL]], i64 3)
871 // CHECK-RV64-NEXT: ret <vscale x 4 x i64> [[TMP0]]
873 vuint64m4_t test_vror_vx_u64m4_m(vbool16_t mask, vuint64m4_t vs2, size_t rs1, size_t vl) {
874 return __riscv_vror_vx_u64m4_m(mask, vs2, rs1, vl);
877 // CHECK-RV64-LABEL: define dso_local <vscale x 8 x i64> @test_vror_vv_u64m8_m
878 // CHECK-RV64-SAME: (<vscale x 8 x i1> [[MASK:%.*]], <vscale x 8 x i64> [[VS2:%.*]], <vscale x 8 x i64> [[VS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
879 // CHECK-RV64-NEXT: entry:
880 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 8 x i64> @llvm.riscv.vror.mask.nxv8i64.nxv8i64.i64(<vscale x 8 x i64> poison, <vscale x 8 x i64> [[VS2]], <vscale x 8 x i64> [[VS1]], <vscale x 8 x i1> [[MASK]], i64 [[VL]], i64 3)
881 // CHECK-RV64-NEXT: ret <vscale x 8 x i64> [[TMP0]]
883 vuint64m8_t test_vror_vv_u64m8_m(vbool8_t mask, vuint64m8_t vs2, vuint64m8_t vs1, size_t vl) {
884 return __riscv_vror_vv_u64m8_m(mask, vs2, vs1, vl);
887 // CHECK-RV64-LABEL: define dso_local <vscale x 8 x i64> @test_vror_vx_u64m8_m
888 // CHECK-RV64-SAME: (<vscale x 8 x i1> [[MASK:%.*]], <vscale x 8 x i64> [[VS2:%.*]], i64 noundef [[RS1:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] {
889 // CHECK-RV64-NEXT: entry:
890 // CHECK-RV64-NEXT: [[TMP0:%.*]] = call <vscale x 8 x i64> @llvm.riscv.vror.mask.nxv8i64.i64.i64(<vscale x 8 x i64> poison, <vscale x 8 x i64> [[VS2]], i64 [[RS1]], <vscale x 8 x i1> [[MASK]], i64 [[VL]], i64 3)
891 // CHECK-RV64-NEXT: ret <vscale x 8 x i64> [[TMP0]]
893 vuint64m8_t test_vror_vx_u64m8_m(vbool8_t mask, vuint64m8_t vs2, size_t rs1, size_t vl) {
894 return __riscv_vror_vx_u64m8_m(mask, vs2, rs1, vl);