Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / CSKY / fpu / base-f.ll
blob041dbd3dc51d27db0dbed196bfd6a04b60915fe8
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
3 ; RUN: llc -verify-machineinstrs -csky-no-aliases < %s -mtriple=csky -float-abi=hard -mattr=+hard-float -mattr=+2e3 -mattr=+fpuv2_sf | FileCheck %s --check-prefix=CHECK-SF
4 ; RUN: llc -verify-machineinstrs -csky-no-aliases < %s -mtriple=csky -float-abi=hard -mattr=+hard-float -mattr=+2e3 -mattr=+fpuv3_sf | FileCheck %s --check-prefix=CHECK-SF2
7 define float @faddRR(float %x, float %y) {
9 ; CHECK-SF-LABEL: faddRR:
10 ; CHECK-SF:       # %bb.0: # %entry
11 ; CHECK-SF-NEXT:    fadds vr0, vr1, vr0
12 ; CHECK-SF-NEXT:    rts16
14 ; CHECK-SF2-LABEL: faddRR:
15 ; CHECK-SF2:       # %bb.0: # %entry
16 ; CHECK-SF2-NEXT:    fadd.32 vr0, vr1, vr0
17 ; CHECK-SF2-NEXT:    rts16
19 entry:
20   %fadd = fadd  float %y, %x
21   ret float %fadd
24 define float @faddRI(float %x) {
26 ; CHECK-SF-LABEL: faddRI:
27 ; CHECK-SF:       # %bb.0: # %entry
28 ; CHECK-SF-NEXT:    movih32 a0, 16672
29 ; CHECK-SF-NEXT:    fmtvrl vr1, a0
30 ; CHECK-SF-NEXT:    fadds vr0, vr0, vr1
31 ; CHECK-SF-NEXT:    rts16
33 ; CHECK-SF2-LABEL: faddRI:
34 ; CHECK-SF2:       # %bb.0: # %entry
35 ; CHECK-SF2-NEXT:    movih32 a0, 16672
36 ; CHECK-SF2-NEXT:    fmtvr.32.1 vr1, a0
37 ; CHECK-SF2-NEXT:    fadd.32 vr0, vr0, vr1
38 ; CHECK-SF2-NEXT:    rts16
40 entry:
41   %fadd = fadd  float %x, 10.0
42   ret float %fadd
45 define float @faddRI_X(float %x) {
47 ; CHECK-SF-LABEL: faddRI_X:
48 ; CHECK-SF:       # %bb.0: # %entry
49 ; CHECK-SF-NEXT:    movih32 a0, 17792
50 ; CHECK-SF-NEXT:    ori32 a0, a0, 2048
51 ; CHECK-SF-NEXT:    fmtvrl vr1, a0
52 ; CHECK-SF-NEXT:    fadds vr0, vr0, vr1
53 ; CHECK-SF-NEXT:    rts16
55 ; CHECK-SF2-LABEL: faddRI_X:
56 ; CHECK-SF2:       # %bb.0: # %entry
57 ; CHECK-SF2-NEXT:    movih32 a0, 17792
58 ; CHECK-SF2-NEXT:    ori32 a0, a0, 2048
59 ; CHECK-SF2-NEXT:    fmtvr.32.1 vr1, a0
60 ; CHECK-SF2-NEXT:    fadd.32 vr0, vr0, vr1
61 ; CHECK-SF2-NEXT:    rts16
63 entry:
64   %fadd = fadd  float %x, 4097.0
65   ret float %fadd
68 define float @fsubRR(float %x, float %y) {
70 ; CHECK-SF-LABEL: fsubRR:
71 ; CHECK-SF:       # %bb.0: # %entry
72 ; CHECK-SF-NEXT:    fsubs vr0, vr1, vr0
73 ; CHECK-SF-NEXT:    rts16
75 ; CHECK-SF2-LABEL: fsubRR:
76 ; CHECK-SF2:       # %bb.0: # %entry
77 ; CHECK-SF2-NEXT:    fsub.32 vr0, vr1, vr0
78 ; CHECK-SF2-NEXT:    rts16
81 entry:
82   %fsub = fsub  float %y, %x
83   ret float %fsub
86 define float @fsubRI(float %x) {
88 ; CHECK-SF-LABEL: fsubRI:
89 ; CHECK-SF:       # %bb.0: # %entry
90 ; CHECK-SF-NEXT:    movih32 a0, 49440
91 ; CHECK-SF-NEXT:    fmtvrl vr1, a0
92 ; CHECK-SF-NEXT:    fadds vr0, vr0, vr1
93 ; CHECK-SF-NEXT:    rts16
95 ; CHECK-SF2-LABEL: fsubRI:
96 ; CHECK-SF2:       # %bb.0: # %entry
97 ; CHECK-SF2-NEXT:    movih32 a0, 49440
98 ; CHECK-SF2-NEXT:    fmtvr.32.1 vr1, a0
99 ; CHECK-SF2-NEXT:    fadd.32 vr0, vr0, vr1
100 ; CHECK-SF2-NEXT:    rts16
102 entry:
103   %fsub = fsub  float %x, 10.0
104   ret float %fsub
107 define float @fsubRI_X(float %x) {
109 ; CHECK-SF-LABEL: fsubRI_X:
110 ; CHECK-SF:       # %bb.0: # %entry
111 ; CHECK-SF-NEXT:    movih32 a0, 50560
112 ; CHECK-SF-NEXT:    ori32 a0, a0, 2048
113 ; CHECK-SF-NEXT:    fmtvrl vr1, a0
114 ; CHECK-SF-NEXT:    fadds vr0, vr0, vr1
115 ; CHECK-SF-NEXT:    rts16
117 ; CHECK-SF2-LABEL: fsubRI_X:
118 ; CHECK-SF2:       # %bb.0: # %entry
119 ; CHECK-SF2-NEXT:    movih32 a0, 50560
120 ; CHECK-SF2-NEXT:    ori32 a0, a0, 2048
121 ; CHECK-SF2-NEXT:    fmtvr.32.1 vr1, a0
122 ; CHECK-SF2-NEXT:    fadd.32 vr0, vr0, vr1
123 ; CHECK-SF2-NEXT:    rts16
125 entry:
126   %fsub = fsub  float %x, 4097.0
127   ret float %fsub
130 define float @fmulRR(float %x, float %y) {
132 ; CHECK-SF-LABEL: fmulRR:
133 ; CHECK-SF:       # %bb.0: # %entry
134 ; CHECK-SF-NEXT:    fmuls vr0, vr1, vr0
135 ; CHECK-SF-NEXT:    rts16
137 ; CHECK-SF2-LABEL: fmulRR:
138 ; CHECK-SF2:       # %bb.0: # %entry
139 ; CHECK-SF2-NEXT:    fmul.32 vr0, vr1, vr0
140 ; CHECK-SF2-NEXT:    rts16
142 entry:
143   %fmul = fmul  float %y, %x
144   ret float %fmul
147 define float @fnmulRR_a(float %x, float %y) {
149 ; CHECK-SF-LABEL: fnmulRR_a:
150 ; CHECK-SF:       # %bb.0: # %entry
151 ; CHECK-SF-NEXT:    fnmuls vr0, vr1, vr0
152 ; CHECK-SF-NEXT:    rts16
154 ; CHECK-SF2-LABEL: fnmulRR_a:
155 ; CHECK-SF2:       # %bb.0: # %entry
156 ; CHECK-SF2-NEXT:    fnmul.32 vr0, vr1, vr0
157 ; CHECK-SF2-NEXT:    rts16
159 entry:
160   %z = fneg float %y
161   %fnmul = fmul float %z, %x
162   ret float %fnmul
165 define float @fnmulRR_b(float %x, float %y) {
166 ; CHECK-SF-LABEL: fnmulRR_b:
167 ; CHECK-SF:       # %bb.0: # %entry
168 ; CHECK-SF-NEXT:    fnmuls vr0, vr0, vr1
169 ; CHECK-SF-NEXT:    rts16
171 ; CHECK-SF2-LABEL: fnmulRR_b:
172 ; CHECK-SF2:       # %bb.0: # %entry
173 ; CHECK-SF2-NEXT:    fnmul.32 vr0, vr0, vr1
174 ; CHECK-SF2-NEXT:    rts16
175 entry:
176   %z = fneg float %x
177   %fnmul = fmul float %y, %z
178   ret float %fnmul
181 define float @fmulRI(float %x) {
183 ; CHECK-SF-LABEL: fmulRI:
184 ; CHECK-SF:       # %bb.0: # %entry
185 ; CHECK-SF-NEXT:    movih32 a0, 16672
186 ; CHECK-SF-NEXT:    fmtvrl vr1, a0
187 ; CHECK-SF-NEXT:    fmuls vr0, vr0, vr1
188 ; CHECK-SF-NEXT:    rts16
190 ; CHECK-SF2-LABEL: fmulRI:
191 ; CHECK-SF2:       # %bb.0: # %entry
192 ; CHECK-SF2-NEXT:    movih32 a0, 16672
193 ; CHECK-SF2-NEXT:    fmtvr.32.1 vr1, a0
194 ; CHECK-SF2-NEXT:    fmul.32 vr0, vr0, vr1
195 ; CHECK-SF2-NEXT:    rts16
197 entry:
198   %fmul = fmul  float %x, 10.0
199   ret float %fmul
202 define float @fmulRI_X(float %x) {
204 ; CHECK-SF-LABEL: fmulRI_X:
205 ; CHECK-SF:       # %bb.0: # %entry
206 ; CHECK-SF-NEXT:    movih32 a0, 17792
207 ; CHECK-SF-NEXT:    ori32 a0, a0, 2048
208 ; CHECK-SF-NEXT:    fmtvrl vr1, a0
209 ; CHECK-SF-NEXT:    fmuls vr0, vr0, vr1
210 ; CHECK-SF-NEXT:    rts16
212 ; CHECK-SF2-LABEL: fmulRI_X:
213 ; CHECK-SF2:       # %bb.0: # %entry
214 ; CHECK-SF2-NEXT:    movih32 a0, 17792
215 ; CHECK-SF2-NEXT:    ori32 a0, a0, 2048
216 ; CHECK-SF2-NEXT:    fmtvr.32.1 vr1, a0
217 ; CHECK-SF2-NEXT:    fmul.32 vr0, vr0, vr1
218 ; CHECK-SF2-NEXT:    rts16
220 entry:
221   %fmul = fmul  float %x, 4097.0
222   ret float %fmul
225 define float @fdivRR(float %x, float %y) {
227 ; CHECK-SF-LABEL: fdivRR:
228 ; CHECK-SF:       # %bb.0: # %entry
229 ; CHECK-SF-NEXT:    fdivs vr0, vr1, vr0
230 ; CHECK-SF-NEXT:    rts16
232 ; CHECK-SF2-LABEL: fdivRR:
233 ; CHECK-SF2:       # %bb.0: # %entry
234 ; CHECK-SF2-NEXT:    fdiv.32 vr0, vr1, vr0
235 ; CHECK-SF2-NEXT:    rts16
238 entry:
239   %fdiv = fdiv  float %y, %x
240   ret float %fdiv
243 define float @fdivRI(float %x) {
245 ; CHECK-SF-LABEL: fdivRI:
246 ; CHECK-SF:       # %bb.0: # %entry
247 ; CHECK-SF-NEXT:    movih32 a0, 16672
248 ; CHECK-SF-NEXT:    fmtvrl vr1, a0
249 ; CHECK-SF-NEXT:    fdivs vr0, vr0, vr1
250 ; CHECK-SF-NEXT:    rts16
252 ; CHECK-SF2-LABEL: fdivRI:
253 ; CHECK-SF2:       # %bb.0: # %entry
254 ; CHECK-SF2-NEXT:    movih32 a0, 16672
255 ; CHECK-SF2-NEXT:    fmtvr.32.1 vr1, a0
256 ; CHECK-SF2-NEXT:    fdiv.32 vr0, vr0, vr1
257 ; CHECK-SF2-NEXT:    rts16
260 entry:
261   %fdiv = fdiv  float %x, 10.0
262   ret float %fdiv
265 define float @fdivRI_X(float %x) {
267 ; CHECK-SF-LABEL: fdivRI_X:
268 ; CHECK-SF:       # %bb.0: # %entry
269 ; CHECK-SF-NEXT:    movih32 a0, 17792
270 ; CHECK-SF-NEXT:    ori32 a0, a0, 2048
271 ; CHECK-SF-NEXT:    fmtvrl vr1, a0
272 ; CHECK-SF-NEXT:    fdivs vr0, vr0, vr1
273 ; CHECK-SF-NEXT:    rts16
275 ; CHECK-SF2-LABEL: fdivRI_X:
276 ; CHECK-SF2:       # %bb.0: # %entry
277 ; CHECK-SF2-NEXT:    movih32 a0, 17792
278 ; CHECK-SF2-NEXT:    ori32 a0, a0, 2048
279 ; CHECK-SF2-NEXT:    fmtvr.32.1 vr1, a0
280 ; CHECK-SF2-NEXT:    fdiv.32 vr0, vr0, vr1
281 ; CHECK-SF2-NEXT:    rts16
283 entry:
284   %fdiv = fdiv  float %x, 4097.0
285   ret float %fdiv
288 define float @fnegRR(float %x) {
290 ; CHECK-SF-LABEL: fnegRR:
291 ; CHECK-SF:       # %bb.0: # %entry
292 ; CHECK-SF-NEXT:    fnegs vr0, vr0
293 ; CHECK-SF-NEXT:    rts16
295 ; CHECK-SF2-LABEL: fnegRR:
296 ; CHECK-SF2:       # %bb.0: # %entry
297 ; CHECK-SF2-NEXT:    fneg.32 vr0, vr0
298 ; CHECK-SF2-NEXT:    rts16
300 entry:
301   %fneg = fneg  float %x
302   ret float %fneg