Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / RISCV / rvv / vfmv.f.s.ll
blob47b4b612311222a34796890065946c9b2d33b81e
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -mtriple=riscv64 -mattr=+d,+v,+zfh,+zvfh -target-abi lp64d -verify-machineinstrs < %s | FileCheck %s
3 ; RUN: llc -mtriple=riscv32 -mattr=+d,+v,+zfh,+zvfh -target-abi ilp32d -verify-machineinstrs < %s | FileCheck %s
5 declare half @llvm.riscv.vfmv.f.s.nxv1f16(<vscale x 1 x half>)
7 define half @intrinsic_vfmv.f.s_s_nxv1f16(<vscale x 1 x half> %0) nounwind {
8 ; CHECK-LABEL: intrinsic_vfmv.f.s_s_nxv1f16:
9 ; CHECK:       # %bb.0: # %entry
10 ; CHECK-NEXT:    vsetivli zero, 1, e16, mf4, ta, ma
11 ; CHECK-NEXT:    vfmv.f.s fa0, v8
12 ; CHECK-NEXT:    ret
13 entry:
14   %a = call half @llvm.riscv.vfmv.f.s.nxv1f16(<vscale x 1 x half> %0)
15   ret half %a
18 declare half @llvm.riscv.vfmv.f.s.nxv2f16(<vscale x 2 x half>)
20 define half @intrinsic_vfmv.f.s_s_nxv2f16(<vscale x 2 x half> %0) nounwind {
21 ; CHECK-LABEL: intrinsic_vfmv.f.s_s_nxv2f16:
22 ; CHECK:       # %bb.0: # %entry
23 ; CHECK-NEXT:    vsetivli zero, 1, e16, mf2, ta, ma
24 ; CHECK-NEXT:    vfmv.f.s fa0, v8
25 ; CHECK-NEXT:    ret
26 entry:
27   %a = call half @llvm.riscv.vfmv.f.s.nxv2f16(<vscale x 2 x half> %0)
28   ret half %a
31 declare half @llvm.riscv.vfmv.f.s.nxv4f16(<vscale x 4 x half>)
33 define half @intrinsic_vfmv.f.s_s_nxv4f16(<vscale x 4 x half> %0) nounwind {
34 ; CHECK-LABEL: intrinsic_vfmv.f.s_s_nxv4f16:
35 ; CHECK:       # %bb.0: # %entry
36 ; CHECK-NEXT:    vsetivli zero, 1, e16, m1, ta, ma
37 ; CHECK-NEXT:    vfmv.f.s fa0, v8
38 ; CHECK-NEXT:    ret
39 entry:
40   %a = call half @llvm.riscv.vfmv.f.s.nxv4f16(<vscale x 4 x half> %0)
41   ret half %a
44 declare half @llvm.riscv.vfmv.f.s.nxv8f16(<vscale x 8 x half>)
46 define half @intrinsic_vfmv.f.s_s_nxv8f16(<vscale x 8 x half> %0) nounwind {
47 ; CHECK-LABEL: intrinsic_vfmv.f.s_s_nxv8f16:
48 ; CHECK:       # %bb.0: # %entry
49 ; CHECK-NEXT:    vsetivli zero, 1, e16, m1, ta, ma
50 ; CHECK-NEXT:    vfmv.f.s fa0, v8
51 ; CHECK-NEXT:    ret
52 entry:
53   %a = call half @llvm.riscv.vfmv.f.s.nxv8f16(<vscale x 8 x half> %0)
54   ret half %a
57 declare half @llvm.riscv.vfmv.f.s.nxv16f16(<vscale x 16 x half>)
59 define half @intrinsic_vfmv.f.s_s_nxv16f16(<vscale x 16 x half> %0) nounwind {
60 ; CHECK-LABEL: intrinsic_vfmv.f.s_s_nxv16f16:
61 ; CHECK:       # %bb.0: # %entry
62 ; CHECK-NEXT:    vsetivli zero, 1, e16, m1, ta, ma
63 ; CHECK-NEXT:    vfmv.f.s fa0, v8
64 ; CHECK-NEXT:    ret
65 entry:
66   %a = call half @llvm.riscv.vfmv.f.s.nxv16f16(<vscale x 16 x half> %0)
67   ret half %a
70 declare half @llvm.riscv.vfmv.f.s.nxv32f16(<vscale x 32 x half>)
72 define half @intrinsic_vfmv.f.s_s_nxv32f16(<vscale x 32 x half> %0) nounwind {
73 ; CHECK-LABEL: intrinsic_vfmv.f.s_s_nxv32f16:
74 ; CHECK:       # %bb.0: # %entry
75 ; CHECK-NEXT:    vsetivli zero, 1, e16, m1, ta, ma
76 ; CHECK-NEXT:    vfmv.f.s fa0, v8
77 ; CHECK-NEXT:    ret
78 entry:
79   %a = call half @llvm.riscv.vfmv.f.s.nxv32f16(<vscale x 32 x half> %0)
80   ret half %a
83 declare float @llvm.riscv.vfmv.f.s.nxv1f32(<vscale x 1 x float>)
85 define float @intrinsic_vfmv.f.s_s_nxv1f32(<vscale x 1 x float> %0) nounwind {
86 ; CHECK-LABEL: intrinsic_vfmv.f.s_s_nxv1f32:
87 ; CHECK:       # %bb.0: # %entry
88 ; CHECK-NEXT:    vsetivli zero, 1, e32, mf2, ta, ma
89 ; CHECK-NEXT:    vfmv.f.s fa0, v8
90 ; CHECK-NEXT:    ret
91 entry:
92   %a = call float @llvm.riscv.vfmv.f.s.nxv1f32(<vscale x 1 x float> %0)
93   ret float %a
96 declare float @llvm.riscv.vfmv.f.s.nxv2f32(<vscale x 2 x float>)
98 define float @intrinsic_vfmv.f.s_s_nxv2f32(<vscale x 2 x float> %0) nounwind {
99 ; CHECK-LABEL: intrinsic_vfmv.f.s_s_nxv2f32:
100 ; CHECK:       # %bb.0: # %entry
101 ; CHECK-NEXT:    vsetivli zero, 1, e32, m1, ta, ma
102 ; CHECK-NEXT:    vfmv.f.s fa0, v8
103 ; CHECK-NEXT:    ret
104 entry:
105   %a = call float @llvm.riscv.vfmv.f.s.nxv2f32(<vscale x 2 x float> %0)
106   ret float %a
109 declare float @llvm.riscv.vfmv.f.s.nxv4f32(<vscale x 4 x float>)
111 define float @intrinsic_vfmv.f.s_s_nxv4f32(<vscale x 4 x float> %0) nounwind {
112 ; CHECK-LABEL: intrinsic_vfmv.f.s_s_nxv4f32:
113 ; CHECK:       # %bb.0: # %entry
114 ; CHECK-NEXT:    vsetivli zero, 1, e32, m1, ta, ma
115 ; CHECK-NEXT:    vfmv.f.s fa0, v8
116 ; CHECK-NEXT:    ret
117 entry:
118   %a = call float @llvm.riscv.vfmv.f.s.nxv4f32(<vscale x 4 x float> %0)
119   ret float %a
122 declare float @llvm.riscv.vfmv.f.s.nxv8f32(<vscale x 8 x float>)
124 define float @intrinsic_vfmv.f.s_s_nxv8f32(<vscale x 8 x float> %0) nounwind {
125 ; CHECK-LABEL: intrinsic_vfmv.f.s_s_nxv8f32:
126 ; CHECK:       # %bb.0: # %entry
127 ; CHECK-NEXT:    vsetivli zero, 1, e32, m1, ta, ma
128 ; CHECK-NEXT:    vfmv.f.s fa0, v8
129 ; CHECK-NEXT:    ret
130 entry:
131   %a = call float @llvm.riscv.vfmv.f.s.nxv8f32(<vscale x 8 x float> %0)
132   ret float %a
135 declare float @llvm.riscv.vfmv.f.s.nxv16f32(<vscale x 16 x float>)
137 define float @intrinsic_vfmv.f.s_s_nxv16f32(<vscale x 16 x float> %0) nounwind {
138 ; CHECK-LABEL: intrinsic_vfmv.f.s_s_nxv16f32:
139 ; CHECK:       # %bb.0: # %entry
140 ; CHECK-NEXT:    vsetivli zero, 1, e32, m1, ta, ma
141 ; CHECK-NEXT:    vfmv.f.s fa0, v8
142 ; CHECK-NEXT:    ret
143 entry:
144   %a = call float @llvm.riscv.vfmv.f.s.nxv16f32(<vscale x 16 x float> %0)
145   ret float %a
148 declare double @llvm.riscv.vfmv.f.s.nxv1f64(<vscale x 1 x double>)
150 define double @intrinsic_vfmv.f.s_s_nxv1f64(<vscale x 1 x double> %0) nounwind {
151 ; CHECK-LABEL: intrinsic_vfmv.f.s_s_nxv1f64:
152 ; CHECK:       # %bb.0: # %entry
153 ; CHECK-NEXT:    vsetivli zero, 1, e64, m1, ta, ma
154 ; CHECK-NEXT:    vfmv.f.s fa0, v8
155 ; CHECK-NEXT:    ret
156 entry:
157   %a = call double @llvm.riscv.vfmv.f.s.nxv1f64(<vscale x 1 x double> %0)
158   ret double %a
161 declare double @llvm.riscv.vfmv.f.s.nxv2f64(<vscale x 2 x double>)
163 define double @intrinsic_vfmv.f.s_s_nxv2f64(<vscale x 2 x double> %0) nounwind {
164 ; CHECK-LABEL: intrinsic_vfmv.f.s_s_nxv2f64:
165 ; CHECK:       # %bb.0: # %entry
166 ; CHECK-NEXT:    vsetivli zero, 1, e64, m1, ta, ma
167 ; CHECK-NEXT:    vfmv.f.s fa0, v8
168 ; CHECK-NEXT:    ret
169 entry:
170   %a = call double @llvm.riscv.vfmv.f.s.nxv2f64(<vscale x 2 x double> %0)
171   ret double %a
174 declare double @llvm.riscv.vfmv.f.s.nxv4f64(<vscale x 4 x double>)
176 define double @intrinsic_vfmv.f.s_s_nxv4f64(<vscale x 4 x double> %0) nounwind {
177 ; CHECK-LABEL: intrinsic_vfmv.f.s_s_nxv4f64:
178 ; CHECK:       # %bb.0: # %entry
179 ; CHECK-NEXT:    vsetivli zero, 1, e64, m1, ta, ma
180 ; CHECK-NEXT:    vfmv.f.s fa0, v8
181 ; CHECK-NEXT:    ret
182 entry:
183   %a = call double @llvm.riscv.vfmv.f.s.nxv4f64(<vscale x 4 x double> %0)
184   ret double %a
187 declare double @llvm.riscv.vfmv.f.s.nxv8f64(<vscale x 8 x double>)
189 define double @intrinsic_vfmv.f.s_s_nxv8f64(<vscale x 8 x double> %0) nounwind {
190 ; CHECK-LABEL: intrinsic_vfmv.f.s_s_nxv8f64:
191 ; CHECK:       # %bb.0: # %entry
192 ; CHECK-NEXT:    vsetivli zero, 1, e64, m1, ta, ma
193 ; CHECK-NEXT:    vfmv.f.s fa0, v8
194 ; CHECK-NEXT:    ret
195 entry:
196   %a = call double @llvm.riscv.vfmv.f.s.nxv8f64(<vscale x 8 x double> %0)
197   ret double %a