Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / RISCV / rvv / vmv.x.s-rv32.ll
blob3fc5f1b60fbb1e9e6a1fe15c8f4fba838908ddb3
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -mtriple=riscv32 -mattr=+v -verify-machineinstrs < %s | FileCheck %s
4 declare i8 @llvm.riscv.vmv.x.s.nxv1i8(<vscale x 1 x i8>)
6 define signext i8 @intrinsic_vmv.x.s_s_nxv1i8(<vscale x 1 x i8> %0) nounwind {
7 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv1i8:
8 ; CHECK:       # %bb.0: # %entry
9 ; CHECK-NEXT:    vsetivli zero, 1, e8, mf8, ta, ma
10 ; CHECK-NEXT:    vmv.x.s a0, v8
11 ; CHECK-NEXT:    ret
12 entry:
13   %a = call i8 @llvm.riscv.vmv.x.s.nxv1i8(<vscale x 1 x i8> %0)
14   ret i8 %a
17 declare i8 @llvm.riscv.vmv.x.s.nxv2i8(<vscale x 2 x i8>)
19 define signext i8 @intrinsic_vmv.x.s_s_nxv2i8(<vscale x 2 x i8> %0) nounwind {
20 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv2i8:
21 ; CHECK:       # %bb.0: # %entry
22 ; CHECK-NEXT:    vsetivli zero, 1, e8, mf4, ta, ma
23 ; CHECK-NEXT:    vmv.x.s a0, v8
24 ; CHECK-NEXT:    ret
25 entry:
26   %a = call i8 @llvm.riscv.vmv.x.s.nxv2i8(<vscale x 2 x i8> %0)
27   ret i8 %a
30 declare i8 @llvm.riscv.vmv.x.s.nxv4i8(<vscale x 4 x i8>)
32 define signext i8 @intrinsic_vmv.x.s_s_nxv4i8(<vscale x 4 x i8> %0) nounwind {
33 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv4i8:
34 ; CHECK:       # %bb.0: # %entry
35 ; CHECK-NEXT:    vsetivli zero, 1, e8, mf2, ta, ma
36 ; CHECK-NEXT:    vmv.x.s a0, v8
37 ; CHECK-NEXT:    ret
38 entry:
39   %a = call i8 @llvm.riscv.vmv.x.s.nxv4i8(<vscale x 4 x i8> %0)
40   ret i8 %a
43 declare i8 @llvm.riscv.vmv.x.s.nxv8i8(<vscale x 8 x i8>)
45 define signext i8 @intrinsic_vmv.x.s_s_nxv8i8(<vscale x 8 x i8> %0) nounwind {
46 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv8i8:
47 ; CHECK:       # %bb.0: # %entry
48 ; CHECK-NEXT:    vsetivli zero, 1, e8, m1, ta, ma
49 ; CHECK-NEXT:    vmv.x.s a0, v8
50 ; CHECK-NEXT:    ret
51 entry:
52   %a = call i8 @llvm.riscv.vmv.x.s.nxv8i8(<vscale x 8 x i8> %0)
53   ret i8 %a
56 declare i8 @llvm.riscv.vmv.x.s.nxv16i8(<vscale x 16 x i8>)
58 define signext i8 @intrinsic_vmv.x.s_s_nxv16i8(<vscale x 16 x i8> %0) nounwind {
59 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv16i8:
60 ; CHECK:       # %bb.0: # %entry
61 ; CHECK-NEXT:    vsetivli zero, 1, e8, m2, ta, ma
62 ; CHECK-NEXT:    vmv.x.s a0, v8
63 ; CHECK-NEXT:    ret
64 entry:
65   %a = call i8 @llvm.riscv.vmv.x.s.nxv16i8(<vscale x 16 x i8> %0)
66   ret i8 %a
69 declare i8 @llvm.riscv.vmv.x.s.nxv32i8(<vscale x 32 x i8>)
71 define signext i8 @intrinsic_vmv.x.s_s_nxv32i8(<vscale x 32 x i8> %0) nounwind {
72 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv32i8:
73 ; CHECK:       # %bb.0: # %entry
74 ; CHECK-NEXT:    vsetivli zero, 1, e8, m4, ta, ma
75 ; CHECK-NEXT:    vmv.x.s a0, v8
76 ; CHECK-NEXT:    ret
77 entry:
78   %a = call i8 @llvm.riscv.vmv.x.s.nxv32i8(<vscale x 32 x i8> %0)
79   ret i8 %a
82 declare i8 @llvm.riscv.vmv.x.s.nxv64i8(<vscale x 64 x i8>)
84 define signext i8 @intrinsic_vmv.x.s_s_nxv64i8(<vscale x 64 x i8> %0) nounwind {
85 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv64i8:
86 ; CHECK:       # %bb.0: # %entry
87 ; CHECK-NEXT:    vsetivli zero, 1, e8, m8, ta, ma
88 ; CHECK-NEXT:    vmv.x.s a0, v8
89 ; CHECK-NEXT:    ret
90 entry:
91   %a = call i8 @llvm.riscv.vmv.x.s.nxv64i8(<vscale x 64 x i8> %0)
92   ret i8 %a
95 declare i16 @llvm.riscv.vmv.x.s.nxv1i16(<vscale x 1 x i16>)
97 define signext i16 @intrinsic_vmv.x.s_s_nxv1i16(<vscale x 1 x i16> %0) nounwind {
98 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv1i16:
99 ; CHECK:       # %bb.0: # %entry
100 ; CHECK-NEXT:    vsetivli zero, 1, e16, mf4, ta, ma
101 ; CHECK-NEXT:    vmv.x.s a0, v8
102 ; CHECK-NEXT:    ret
103 entry:
104   %a = call i16 @llvm.riscv.vmv.x.s.nxv1i16(<vscale x 1 x i16> %0)
105   ret i16 %a
108 declare i16 @llvm.riscv.vmv.x.s.nxv2i16(<vscale x 2 x i16>)
110 define signext i16 @intrinsic_vmv.x.s_s_nxv2i16(<vscale x 2 x i16> %0) nounwind {
111 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv2i16:
112 ; CHECK:       # %bb.0: # %entry
113 ; CHECK-NEXT:    vsetivli zero, 1, e16, mf2, ta, ma
114 ; CHECK-NEXT:    vmv.x.s a0, v8
115 ; CHECK-NEXT:    ret
116 entry:
117   %a = call i16 @llvm.riscv.vmv.x.s.nxv2i16(<vscale x 2 x i16> %0)
118   ret i16 %a
121 declare i16 @llvm.riscv.vmv.x.s.nxv4i16(<vscale x 4 x i16>)
123 define signext i16 @intrinsic_vmv.x.s_s_nxv4i16(<vscale x 4 x i16> %0) nounwind {
124 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv4i16:
125 ; CHECK:       # %bb.0: # %entry
126 ; CHECK-NEXT:    vsetivli zero, 1, e16, m1, ta, ma
127 ; CHECK-NEXT:    vmv.x.s a0, v8
128 ; CHECK-NEXT:    ret
129 entry:
130   %a = call i16 @llvm.riscv.vmv.x.s.nxv4i16(<vscale x 4 x i16> %0)
131   ret i16 %a
134 declare i16 @llvm.riscv.vmv.x.s.nxv8i16(<vscale x 8 x i16>)
136 define signext i16 @intrinsic_vmv.x.s_s_nxv8i16(<vscale x 8 x i16> %0) nounwind {
137 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv8i16:
138 ; CHECK:       # %bb.0: # %entry
139 ; CHECK-NEXT:    vsetivli zero, 1, e16, m2, ta, ma
140 ; CHECK-NEXT:    vmv.x.s a0, v8
141 ; CHECK-NEXT:    ret
142 entry:
143   %a = call i16 @llvm.riscv.vmv.x.s.nxv8i16(<vscale x 8 x i16> %0)
144   ret i16 %a
147 declare i16 @llvm.riscv.vmv.x.s.nxv16i16(<vscale x 16 x i16>)
149 define signext i16 @intrinsic_vmv.x.s_s_nxv16i16(<vscale x 16 x i16> %0) nounwind {
150 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv16i16:
151 ; CHECK:       # %bb.0: # %entry
152 ; CHECK-NEXT:    vsetivli zero, 1, e16, m4, ta, ma
153 ; CHECK-NEXT:    vmv.x.s a0, v8
154 ; CHECK-NEXT:    ret
155 entry:
156   %a = call i16 @llvm.riscv.vmv.x.s.nxv16i16( <vscale x 16 x i16> %0)
157   ret i16 %a
160 declare i16 @llvm.riscv.vmv.x.s.nxv32i16( <vscale x 32 x i16>)
162 define signext i16 @intrinsic_vmv.x.s_s_nxv32i16(<vscale x 32 x i16> %0) nounwind {
163 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv32i16:
164 ; CHECK:       # %bb.0: # %entry
165 ; CHECK-NEXT:    vsetivli zero, 1, e16, m8, ta, ma
166 ; CHECK-NEXT:    vmv.x.s a0, v8
167 ; CHECK-NEXT:    ret
168 entry:
169   %a = call i16 @llvm.riscv.vmv.x.s.nxv32i16( <vscale x 32 x i16> %0)
170   ret i16 %a
173 declare i32 @llvm.riscv.vmv.x.s.nxv1i32( <vscale x 1 x i32>)
175 define i32 @intrinsic_vmv.x.s_s_nxv1i32(<vscale x 1 x i32> %0) nounwind {
176 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv1i32:
177 ; CHECK:       # %bb.0: # %entry
178 ; CHECK-NEXT:    vsetivli zero, 1, e32, mf2, ta, ma
179 ; CHECK-NEXT:    vmv.x.s a0, v8
180 ; CHECK-NEXT:    ret
181 entry:
182   %a = call i32 @llvm.riscv.vmv.x.s.nxv1i32( <vscale x 1 x i32> %0)
183   ret i32 %a
186 declare i32 @llvm.riscv.vmv.x.s.nxv2i32( <vscale x 2 x i32>)
188 define i32 @intrinsic_vmv.x.s_s_nxv2i32(<vscale x 2 x i32> %0) nounwind {
189 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv2i32:
190 ; CHECK:       # %bb.0: # %entry
191 ; CHECK-NEXT:    vsetivli zero, 1, e32, m1, ta, ma
192 ; CHECK-NEXT:    vmv.x.s a0, v8
193 ; CHECK-NEXT:    ret
194 entry:
195   %a = call i32 @llvm.riscv.vmv.x.s.nxv2i32( <vscale x 2 x i32> %0)
196   ret i32 %a
199 declare i32 @llvm.riscv.vmv.x.s.nxv4i32( <vscale x 4 x i32>)
201 define i32 @intrinsic_vmv.x.s_s_nxv4i32(<vscale x 4 x i32> %0) nounwind {
202 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv4i32:
203 ; CHECK:       # %bb.0: # %entry
204 ; CHECK-NEXT:    vsetivli zero, 1, e32, m2, ta, ma
205 ; CHECK-NEXT:    vmv.x.s a0, v8
206 ; CHECK-NEXT:    ret
207 entry:
208   %a = call i32 @llvm.riscv.vmv.x.s.nxv4i32( <vscale x 4 x i32> %0)
209   ret i32 %a
212 declare i32 @llvm.riscv.vmv.x.s.nxv8i32( <vscale x 8 x i32>)
214 define i32 @intrinsic_vmv.x.s_s_nxv8i32(<vscale x 8 x i32> %0) nounwind {
215 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv8i32:
216 ; CHECK:       # %bb.0: # %entry
217 ; CHECK-NEXT:    vsetivli zero, 1, e32, m4, ta, ma
218 ; CHECK-NEXT:    vmv.x.s a0, v8
219 ; CHECK-NEXT:    ret
220 entry:
221   %a = call i32 @llvm.riscv.vmv.x.s.nxv8i32( <vscale x 8 x i32> %0)
222   ret i32 %a
225 declare i32 @llvm.riscv.vmv.x.s.nxv16i32( <vscale x 16 x i32>)
227 define i32 @intrinsic_vmv.x.s_s_nxv16i32(<vscale x 16 x i32> %0) nounwind {
228 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv16i32:
229 ; CHECK:       # %bb.0: # %entry
230 ; CHECK-NEXT:    vsetivli zero, 1, e32, m8, ta, ma
231 ; CHECK-NEXT:    vmv.x.s a0, v8
232 ; CHECK-NEXT:    ret
233 entry:
234   %a = call i32 @llvm.riscv.vmv.x.s.nxv16i32( <vscale x 16 x i32> %0)
235   ret i32 %a
238 declare i64 @llvm.riscv.vmv.x.s.nxv1i64( <vscale x 1 x i64>)
240 define i64 @intrinsic_vmv.x.s_s_nxv1i64(<vscale x 1 x i64> %0) nounwind {
241 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv1i64:
242 ; CHECK:       # %bb.0: # %entry
243 ; CHECK-NEXT:    li a0, 32
244 ; CHECK-NEXT:    vsetivli zero, 1, e64, m1, ta, ma
245 ; CHECK-NEXT:    vsrl.vx v9, v8, a0
246 ; CHECK-NEXT:    vmv.x.s a1, v9
247 ; CHECK-NEXT:    vmv.x.s a0, v8
248 ; CHECK-NEXT:    ret
249 entry:
250   %a = call i64 @llvm.riscv.vmv.x.s.nxv1i64( <vscale x 1 x i64> %0)
251   ret i64 %a
254 declare i64 @llvm.riscv.vmv.x.s.nxv2i64( <vscale x 2 x i64>)
256 define i64 @intrinsic_vmv.x.s_s_nxv2i64(<vscale x 2 x i64> %0) nounwind {
257 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv2i64:
258 ; CHECK:       # %bb.0: # %entry
259 ; CHECK-NEXT:    li a0, 32
260 ; CHECK-NEXT:    vsetivli zero, 1, e64, m2, ta, ma
261 ; CHECK-NEXT:    vsrl.vx v10, v8, a0
262 ; CHECK-NEXT:    vmv.x.s a1, v10
263 ; CHECK-NEXT:    vmv.x.s a0, v8
264 ; CHECK-NEXT:    ret
265 entry:
266   %a = call i64 @llvm.riscv.vmv.x.s.nxv2i64( <vscale x 2 x i64> %0)
267   ret i64 %a
270 declare i64 @llvm.riscv.vmv.x.s.nxv4i64( <vscale x 4 x i64>)
272 define i64 @intrinsic_vmv.x.s_s_nxv4i64(<vscale x 4 x i64> %0) nounwind {
273 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv4i64:
274 ; CHECK:       # %bb.0: # %entry
275 ; CHECK-NEXT:    li a0, 32
276 ; CHECK-NEXT:    vsetivli zero, 1, e64, m4, ta, ma
277 ; CHECK-NEXT:    vsrl.vx v12, v8, a0
278 ; CHECK-NEXT:    vmv.x.s a1, v12
279 ; CHECK-NEXT:    vmv.x.s a0, v8
280 ; CHECK-NEXT:    ret
281 entry:
282   %a = call i64 @llvm.riscv.vmv.x.s.nxv4i64( <vscale x 4 x i64> %0)
283   ret i64 %a
286 declare i64 @llvm.riscv.vmv.x.s.nxv8i64(<vscale x 8 x i64>)
288 define i64 @intrinsic_vmv.x.s_s_nxv8i64(<vscale x 8 x i64> %0) nounwind {
289 ; CHECK-LABEL: intrinsic_vmv.x.s_s_nxv8i64:
290 ; CHECK:       # %bb.0: # %entry
291 ; CHECK-NEXT:    li a0, 32
292 ; CHECK-NEXT:    vsetivli zero, 1, e64, m8, ta, ma
293 ; CHECK-NEXT:    vsrl.vx v16, v8, a0
294 ; CHECK-NEXT:    vmv.x.s a1, v16
295 ; CHECK-NEXT:    vmv.x.s a0, v8
296 ; CHECK-NEXT:    ret
297 entry:
298   %a = call i64 @llvm.riscv.vmv.x.s.nxv8i64(<vscale x 8 x i64> %0)
299   ret i64 %a