1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: sed 's/iXLen/i32/g' %s | llc -mtriple=riscv32 -mattr=+d \
3 ; RUN: -verify-machineinstrs -target-abi=ilp32d \
4 ; RUN: | FileCheck -check-prefixes=CHECKIFD,RV32IFD %s
5 ; RUN: sed 's/iXLen/i64/g' %s | llc -mtriple=riscv64 -mattr=+d \
6 ; RUN: -verify-machineinstrs -target-abi=lp64d \
7 ; RUN: | FileCheck -check-prefixes=CHECKIFD,RV64IFD %s
8 ; RUN: sed 's/iXLen/i32/g' %s | llc -mtriple=riscv32 -mattr=+zdinx \
9 ; RUN: -verify-machineinstrs -target-abi=ilp32 \
10 ; RUN: | FileCheck -check-prefix=RV32IZFINXZDINX %s
11 ; RUN: sed 's/iXLen/i64/g' %s | llc -mtriple=riscv64 -mattr=+zdinx \
12 ; RUN: -verify-machineinstrs -target-abi=lp64 \
13 ; RUN: | FileCheck -check-prefix=RV64IZFINXZDINX %s
14 ; RUN: sed 's/iXLen/i32/g' %s | llc -mtriple=riscv32 \
15 ; RUN: -verify-machineinstrs | FileCheck -check-prefix=RV32I %s
16 ; RUN: sed 's/iXLen/i64/g' %s | llc -mtriple=riscv64 \
17 ; RUN: -verify-machineinstrs | FileCheck -check-prefix=RV64I %s
19 declare double @llvm.sqrt.f64(double)
21 define double @sqrt_f64(double %a) nounwind {
22 ; CHECKIFD-LABEL: sqrt_f64:
24 ; CHECKIFD-NEXT: fsqrt.d fa0, fa0
27 ; RV32IZFINXZDINX-LABEL: sqrt_f64:
28 ; RV32IZFINXZDINX: # %bb.0:
29 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
30 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
31 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
32 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
33 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
34 ; RV32IZFINXZDINX-NEXT: fsqrt.d a0, a0
35 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
36 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
37 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
38 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
39 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
40 ; RV32IZFINXZDINX-NEXT: ret
42 ; RV64IZFINXZDINX-LABEL: sqrt_f64:
43 ; RV64IZFINXZDINX: # %bb.0:
44 ; RV64IZFINXZDINX-NEXT: fsqrt.d a0, a0
45 ; RV64IZFINXZDINX-NEXT: ret
47 ; RV32I-LABEL: sqrt_f64:
49 ; RV32I-NEXT: addi sp, sp, -16
50 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
51 ; RV32I-NEXT: call sqrt@plt
52 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
53 ; RV32I-NEXT: addi sp, sp, 16
56 ; RV64I-LABEL: sqrt_f64:
58 ; RV64I-NEXT: addi sp, sp, -16
59 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
60 ; RV64I-NEXT: call sqrt@plt
61 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
62 ; RV64I-NEXT: addi sp, sp, 16
64 %1 = call double @llvm.sqrt.f64(double %a)
68 declare double @llvm.powi.f64.i32(double, i32)
70 define double @powi_f64(double %a, i32 %b) nounwind {
71 ; RV32IFD-LABEL: powi_f64:
73 ; RV32IFD-NEXT: tail __powidf2@plt
75 ; RV64IFD-LABEL: powi_f64:
77 ; RV64IFD-NEXT: addi sp, sp, -16
78 ; RV64IFD-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
79 ; RV64IFD-NEXT: sext.w a0, a0
80 ; RV64IFD-NEXT: call __powidf2@plt
81 ; RV64IFD-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
82 ; RV64IFD-NEXT: addi sp, sp, 16
85 ; RV32IZFINXZDINX-LABEL: powi_f64:
86 ; RV32IZFINXZDINX: # %bb.0:
87 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
88 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
89 ; RV32IZFINXZDINX-NEXT: call __powidf2@plt
90 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
91 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
92 ; RV32IZFINXZDINX-NEXT: ret
94 ; RV64IZFINXZDINX-LABEL: powi_f64:
95 ; RV64IZFINXZDINX: # %bb.0:
96 ; RV64IZFINXZDINX-NEXT: addi sp, sp, -16
97 ; RV64IZFINXZDINX-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
98 ; RV64IZFINXZDINX-NEXT: sext.w a1, a1
99 ; RV64IZFINXZDINX-NEXT: call __powidf2@plt
100 ; RV64IZFINXZDINX-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
101 ; RV64IZFINXZDINX-NEXT: addi sp, sp, 16
102 ; RV64IZFINXZDINX-NEXT: ret
104 ; RV32I-LABEL: powi_f64:
106 ; RV32I-NEXT: addi sp, sp, -16
107 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
108 ; RV32I-NEXT: call __powidf2@plt
109 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
110 ; RV32I-NEXT: addi sp, sp, 16
113 ; RV64I-LABEL: powi_f64:
115 ; RV64I-NEXT: addi sp, sp, -16
116 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
117 ; RV64I-NEXT: sext.w a1, a1
118 ; RV64I-NEXT: call __powidf2@plt
119 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
120 ; RV64I-NEXT: addi sp, sp, 16
122 %1 = call double @llvm.powi.f64.i32(double %a, i32 %b)
126 declare double @llvm.sin.f64(double)
128 define double @sin_f64(double %a) nounwind {
129 ; CHECKIFD-LABEL: sin_f64:
131 ; CHECKIFD-NEXT: tail sin@plt
133 ; RV32IZFINXZDINX-LABEL: sin_f64:
134 ; RV32IZFINXZDINX: # %bb.0:
135 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
136 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
137 ; RV32IZFINXZDINX-NEXT: call sin@plt
138 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
139 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
140 ; RV32IZFINXZDINX-NEXT: ret
142 ; RV64IZFINXZDINX-LABEL: sin_f64:
143 ; RV64IZFINXZDINX: # %bb.0:
144 ; RV64IZFINXZDINX-NEXT: tail sin@plt
146 ; RV32I-LABEL: sin_f64:
148 ; RV32I-NEXT: addi sp, sp, -16
149 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
150 ; RV32I-NEXT: call sin@plt
151 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
152 ; RV32I-NEXT: addi sp, sp, 16
155 ; RV64I-LABEL: sin_f64:
157 ; RV64I-NEXT: addi sp, sp, -16
158 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
159 ; RV64I-NEXT: call sin@plt
160 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
161 ; RV64I-NEXT: addi sp, sp, 16
163 %1 = call double @llvm.sin.f64(double %a)
167 declare double @llvm.cos.f64(double)
169 define double @cos_f64(double %a) nounwind {
170 ; CHECKIFD-LABEL: cos_f64:
172 ; CHECKIFD-NEXT: tail cos@plt
174 ; RV32IZFINXZDINX-LABEL: cos_f64:
175 ; RV32IZFINXZDINX: # %bb.0:
176 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
177 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
178 ; RV32IZFINXZDINX-NEXT: call cos@plt
179 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
180 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
181 ; RV32IZFINXZDINX-NEXT: ret
183 ; RV64IZFINXZDINX-LABEL: cos_f64:
184 ; RV64IZFINXZDINX: # %bb.0:
185 ; RV64IZFINXZDINX-NEXT: tail cos@plt
187 ; RV32I-LABEL: cos_f64:
189 ; RV32I-NEXT: addi sp, sp, -16
190 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
191 ; RV32I-NEXT: call cos@plt
192 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
193 ; RV32I-NEXT: addi sp, sp, 16
196 ; RV64I-LABEL: cos_f64:
198 ; RV64I-NEXT: addi sp, sp, -16
199 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
200 ; RV64I-NEXT: call cos@plt
201 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
202 ; RV64I-NEXT: addi sp, sp, 16
204 %1 = call double @llvm.cos.f64(double %a)
208 ; The sin+cos combination results in an FSINCOS SelectionDAG node.
209 define double @sincos_f64(double %a) nounwind {
210 ; RV32IFD-LABEL: sincos_f64:
212 ; RV32IFD-NEXT: addi sp, sp, -32
213 ; RV32IFD-NEXT: sw ra, 28(sp) # 4-byte Folded Spill
214 ; RV32IFD-NEXT: fsd fs0, 16(sp) # 8-byte Folded Spill
215 ; RV32IFD-NEXT: fsd fs1, 8(sp) # 8-byte Folded Spill
216 ; RV32IFD-NEXT: fmv.d fs0, fa0
217 ; RV32IFD-NEXT: call sin@plt
218 ; RV32IFD-NEXT: fmv.d fs1, fa0
219 ; RV32IFD-NEXT: fmv.d fa0, fs0
220 ; RV32IFD-NEXT: call cos@plt
221 ; RV32IFD-NEXT: fadd.d fa0, fs1, fa0
222 ; RV32IFD-NEXT: lw ra, 28(sp) # 4-byte Folded Reload
223 ; RV32IFD-NEXT: fld fs0, 16(sp) # 8-byte Folded Reload
224 ; RV32IFD-NEXT: fld fs1, 8(sp) # 8-byte Folded Reload
225 ; RV32IFD-NEXT: addi sp, sp, 32
228 ; RV64IFD-LABEL: sincos_f64:
230 ; RV64IFD-NEXT: addi sp, sp, -32
231 ; RV64IFD-NEXT: sd ra, 24(sp) # 8-byte Folded Spill
232 ; RV64IFD-NEXT: fsd fs0, 16(sp) # 8-byte Folded Spill
233 ; RV64IFD-NEXT: fsd fs1, 8(sp) # 8-byte Folded Spill
234 ; RV64IFD-NEXT: fmv.d fs0, fa0
235 ; RV64IFD-NEXT: call sin@plt
236 ; RV64IFD-NEXT: fmv.d fs1, fa0
237 ; RV64IFD-NEXT: fmv.d fa0, fs0
238 ; RV64IFD-NEXT: call cos@plt
239 ; RV64IFD-NEXT: fadd.d fa0, fs1, fa0
240 ; RV64IFD-NEXT: ld ra, 24(sp) # 8-byte Folded Reload
241 ; RV64IFD-NEXT: fld fs0, 16(sp) # 8-byte Folded Reload
242 ; RV64IFD-NEXT: fld fs1, 8(sp) # 8-byte Folded Reload
243 ; RV64IFD-NEXT: addi sp, sp, 32
246 ; RV32IZFINXZDINX-LABEL: sincos_f64:
247 ; RV32IZFINXZDINX: # %bb.0:
248 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -32
249 ; RV32IZFINXZDINX-NEXT: sw ra, 28(sp) # 4-byte Folded Spill
250 ; RV32IZFINXZDINX-NEXT: sw s0, 24(sp) # 4-byte Folded Spill
251 ; RV32IZFINXZDINX-NEXT: sw s1, 20(sp) # 4-byte Folded Spill
252 ; RV32IZFINXZDINX-NEXT: sw s2, 16(sp) # 4-byte Folded Spill
253 ; RV32IZFINXZDINX-NEXT: sw s3, 12(sp) # 4-byte Folded Spill
254 ; RV32IZFINXZDINX-NEXT: mv s0, a1
255 ; RV32IZFINXZDINX-NEXT: mv s1, a0
256 ; RV32IZFINXZDINX-NEXT: call sin@plt
257 ; RV32IZFINXZDINX-NEXT: sw a0, 0(sp)
258 ; RV32IZFINXZDINX-NEXT: sw a1, 4(sp)
259 ; RV32IZFINXZDINX-NEXT: lw s2, 0(sp)
260 ; RV32IZFINXZDINX-NEXT: lw s3, 4(sp)
261 ; RV32IZFINXZDINX-NEXT: mv a0, s1
262 ; RV32IZFINXZDINX-NEXT: mv a1, s0
263 ; RV32IZFINXZDINX-NEXT: call cos@plt
264 ; RV32IZFINXZDINX-NEXT: sw a0, 0(sp)
265 ; RV32IZFINXZDINX-NEXT: sw a1, 4(sp)
266 ; RV32IZFINXZDINX-NEXT: lw a0, 0(sp)
267 ; RV32IZFINXZDINX-NEXT: lw a1, 4(sp)
268 ; RV32IZFINXZDINX-NEXT: fadd.d a0, s2, a0
269 ; RV32IZFINXZDINX-NEXT: sw a0, 0(sp)
270 ; RV32IZFINXZDINX-NEXT: sw a1, 4(sp)
271 ; RV32IZFINXZDINX-NEXT: lw a0, 0(sp)
272 ; RV32IZFINXZDINX-NEXT: lw a1, 4(sp)
273 ; RV32IZFINXZDINX-NEXT: lw ra, 28(sp) # 4-byte Folded Reload
274 ; RV32IZFINXZDINX-NEXT: lw s0, 24(sp) # 4-byte Folded Reload
275 ; RV32IZFINXZDINX-NEXT: lw s1, 20(sp) # 4-byte Folded Reload
276 ; RV32IZFINXZDINX-NEXT: lw s2, 16(sp) # 4-byte Folded Reload
277 ; RV32IZFINXZDINX-NEXT: lw s3, 12(sp) # 4-byte Folded Reload
278 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 32
279 ; RV32IZFINXZDINX-NEXT: ret
281 ; RV64IZFINXZDINX-LABEL: sincos_f64:
282 ; RV64IZFINXZDINX: # %bb.0:
283 ; RV64IZFINXZDINX-NEXT: addi sp, sp, -32
284 ; RV64IZFINXZDINX-NEXT: sd ra, 24(sp) # 8-byte Folded Spill
285 ; RV64IZFINXZDINX-NEXT: sd s0, 16(sp) # 8-byte Folded Spill
286 ; RV64IZFINXZDINX-NEXT: sd s1, 8(sp) # 8-byte Folded Spill
287 ; RV64IZFINXZDINX-NEXT: mv s0, a0
288 ; RV64IZFINXZDINX-NEXT: call sin@plt
289 ; RV64IZFINXZDINX-NEXT: mv s1, a0
290 ; RV64IZFINXZDINX-NEXT: mv a0, s0
291 ; RV64IZFINXZDINX-NEXT: call cos@plt
292 ; RV64IZFINXZDINX-NEXT: fadd.d a0, s1, a0
293 ; RV64IZFINXZDINX-NEXT: ld ra, 24(sp) # 8-byte Folded Reload
294 ; RV64IZFINXZDINX-NEXT: ld s0, 16(sp) # 8-byte Folded Reload
295 ; RV64IZFINXZDINX-NEXT: ld s1, 8(sp) # 8-byte Folded Reload
296 ; RV64IZFINXZDINX-NEXT: addi sp, sp, 32
297 ; RV64IZFINXZDINX-NEXT: ret
299 ; RV32I-LABEL: sincos_f64:
301 ; RV32I-NEXT: addi sp, sp, -32
302 ; RV32I-NEXT: sw ra, 28(sp) # 4-byte Folded Spill
303 ; RV32I-NEXT: sw s0, 24(sp) # 4-byte Folded Spill
304 ; RV32I-NEXT: sw s1, 20(sp) # 4-byte Folded Spill
305 ; RV32I-NEXT: sw s2, 16(sp) # 4-byte Folded Spill
306 ; RV32I-NEXT: sw s3, 12(sp) # 4-byte Folded Spill
307 ; RV32I-NEXT: mv s0, a1
308 ; RV32I-NEXT: mv s1, a0
309 ; RV32I-NEXT: call sin@plt
310 ; RV32I-NEXT: mv s2, a0
311 ; RV32I-NEXT: mv s3, a1
312 ; RV32I-NEXT: mv a0, s1
313 ; RV32I-NEXT: mv a1, s0
314 ; RV32I-NEXT: call cos@plt
315 ; RV32I-NEXT: mv a2, a0
316 ; RV32I-NEXT: mv a3, a1
317 ; RV32I-NEXT: mv a0, s2
318 ; RV32I-NEXT: mv a1, s3
319 ; RV32I-NEXT: call __adddf3@plt
320 ; RV32I-NEXT: lw ra, 28(sp) # 4-byte Folded Reload
321 ; RV32I-NEXT: lw s0, 24(sp) # 4-byte Folded Reload
322 ; RV32I-NEXT: lw s1, 20(sp) # 4-byte Folded Reload
323 ; RV32I-NEXT: lw s2, 16(sp) # 4-byte Folded Reload
324 ; RV32I-NEXT: lw s3, 12(sp) # 4-byte Folded Reload
325 ; RV32I-NEXT: addi sp, sp, 32
328 ; RV64I-LABEL: sincos_f64:
330 ; RV64I-NEXT: addi sp, sp, -32
331 ; RV64I-NEXT: sd ra, 24(sp) # 8-byte Folded Spill
332 ; RV64I-NEXT: sd s0, 16(sp) # 8-byte Folded Spill
333 ; RV64I-NEXT: sd s1, 8(sp) # 8-byte Folded Spill
334 ; RV64I-NEXT: mv s0, a0
335 ; RV64I-NEXT: call sin@plt
336 ; RV64I-NEXT: mv s1, a0
337 ; RV64I-NEXT: mv a0, s0
338 ; RV64I-NEXT: call cos@plt
339 ; RV64I-NEXT: mv a1, a0
340 ; RV64I-NEXT: mv a0, s1
341 ; RV64I-NEXT: call __adddf3@plt
342 ; RV64I-NEXT: ld ra, 24(sp) # 8-byte Folded Reload
343 ; RV64I-NEXT: ld s0, 16(sp) # 8-byte Folded Reload
344 ; RV64I-NEXT: ld s1, 8(sp) # 8-byte Folded Reload
345 ; RV64I-NEXT: addi sp, sp, 32
347 %1 = call double @llvm.sin.f64(double %a)
348 %2 = call double @llvm.cos.f64(double %a)
349 %3 = fadd double %1, %2
353 declare double @llvm.pow.f64(double, double)
355 define double @pow_f64(double %a, double %b) nounwind {
356 ; CHECKIFD-LABEL: pow_f64:
358 ; CHECKIFD-NEXT: tail pow@plt
360 ; RV32IZFINXZDINX-LABEL: pow_f64:
361 ; RV32IZFINXZDINX: # %bb.0:
362 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
363 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
364 ; RV32IZFINXZDINX-NEXT: call pow@plt
365 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
366 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
367 ; RV32IZFINXZDINX-NEXT: ret
369 ; RV64IZFINXZDINX-LABEL: pow_f64:
370 ; RV64IZFINXZDINX: # %bb.0:
371 ; RV64IZFINXZDINX-NEXT: tail pow@plt
373 ; RV32I-LABEL: pow_f64:
375 ; RV32I-NEXT: addi sp, sp, -16
376 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
377 ; RV32I-NEXT: call pow@plt
378 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
379 ; RV32I-NEXT: addi sp, sp, 16
382 ; RV64I-LABEL: pow_f64:
384 ; RV64I-NEXT: addi sp, sp, -16
385 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
386 ; RV64I-NEXT: call pow@plt
387 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
388 ; RV64I-NEXT: addi sp, sp, 16
390 %1 = call double @llvm.pow.f64(double %a, double %b)
394 declare double @llvm.exp.f64(double)
396 define double @exp_f64(double %a) nounwind {
397 ; CHECKIFD-LABEL: exp_f64:
399 ; CHECKIFD-NEXT: tail exp@plt
401 ; RV32IZFINXZDINX-LABEL: exp_f64:
402 ; RV32IZFINXZDINX: # %bb.0:
403 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
404 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
405 ; RV32IZFINXZDINX-NEXT: call exp@plt
406 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
407 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
408 ; RV32IZFINXZDINX-NEXT: ret
410 ; RV64IZFINXZDINX-LABEL: exp_f64:
411 ; RV64IZFINXZDINX: # %bb.0:
412 ; RV64IZFINXZDINX-NEXT: tail exp@plt
414 ; RV32I-LABEL: exp_f64:
416 ; RV32I-NEXT: addi sp, sp, -16
417 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
418 ; RV32I-NEXT: call exp@plt
419 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
420 ; RV32I-NEXT: addi sp, sp, 16
423 ; RV64I-LABEL: exp_f64:
425 ; RV64I-NEXT: addi sp, sp, -16
426 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
427 ; RV64I-NEXT: call exp@plt
428 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
429 ; RV64I-NEXT: addi sp, sp, 16
431 %1 = call double @llvm.exp.f64(double %a)
435 declare double @llvm.exp2.f64(double)
437 define double @exp2_f64(double %a) nounwind {
438 ; CHECKIFD-LABEL: exp2_f64:
440 ; CHECKIFD-NEXT: tail exp2@plt
442 ; RV32IZFINXZDINX-LABEL: exp2_f64:
443 ; RV32IZFINXZDINX: # %bb.0:
444 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
445 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
446 ; RV32IZFINXZDINX-NEXT: call exp2@plt
447 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
448 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
449 ; RV32IZFINXZDINX-NEXT: ret
451 ; RV64IZFINXZDINX-LABEL: exp2_f64:
452 ; RV64IZFINXZDINX: # %bb.0:
453 ; RV64IZFINXZDINX-NEXT: tail exp2@plt
455 ; RV32I-LABEL: exp2_f64:
457 ; RV32I-NEXT: addi sp, sp, -16
458 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
459 ; RV32I-NEXT: call exp2@plt
460 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
461 ; RV32I-NEXT: addi sp, sp, 16
464 ; RV64I-LABEL: exp2_f64:
466 ; RV64I-NEXT: addi sp, sp, -16
467 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
468 ; RV64I-NEXT: call exp2@plt
469 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
470 ; RV64I-NEXT: addi sp, sp, 16
472 %1 = call double @llvm.exp2.f64(double %a)
476 declare double @llvm.log.f64(double)
478 define double @log_f64(double %a) nounwind {
479 ; CHECKIFD-LABEL: log_f64:
481 ; CHECKIFD-NEXT: tail log@plt
483 ; RV32IZFINXZDINX-LABEL: log_f64:
484 ; RV32IZFINXZDINX: # %bb.0:
485 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
486 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
487 ; RV32IZFINXZDINX-NEXT: call log@plt
488 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
489 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
490 ; RV32IZFINXZDINX-NEXT: ret
492 ; RV64IZFINXZDINX-LABEL: log_f64:
493 ; RV64IZFINXZDINX: # %bb.0:
494 ; RV64IZFINXZDINX-NEXT: tail log@plt
496 ; RV32I-LABEL: log_f64:
498 ; RV32I-NEXT: addi sp, sp, -16
499 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
500 ; RV32I-NEXT: call log@plt
501 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
502 ; RV32I-NEXT: addi sp, sp, 16
505 ; RV64I-LABEL: log_f64:
507 ; RV64I-NEXT: addi sp, sp, -16
508 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
509 ; RV64I-NEXT: call log@plt
510 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
511 ; RV64I-NEXT: addi sp, sp, 16
513 %1 = call double @llvm.log.f64(double %a)
517 declare double @llvm.log10.f64(double)
519 define double @log10_f64(double %a) nounwind {
520 ; CHECKIFD-LABEL: log10_f64:
522 ; CHECKIFD-NEXT: tail log10@plt
524 ; RV32IZFINXZDINX-LABEL: log10_f64:
525 ; RV32IZFINXZDINX: # %bb.0:
526 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
527 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
528 ; RV32IZFINXZDINX-NEXT: call log10@plt
529 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
530 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
531 ; RV32IZFINXZDINX-NEXT: ret
533 ; RV64IZFINXZDINX-LABEL: log10_f64:
534 ; RV64IZFINXZDINX: # %bb.0:
535 ; RV64IZFINXZDINX-NEXT: tail log10@plt
537 ; RV32I-LABEL: log10_f64:
539 ; RV32I-NEXT: addi sp, sp, -16
540 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
541 ; RV32I-NEXT: call log10@plt
542 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
543 ; RV32I-NEXT: addi sp, sp, 16
546 ; RV64I-LABEL: log10_f64:
548 ; RV64I-NEXT: addi sp, sp, -16
549 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
550 ; RV64I-NEXT: call log10@plt
551 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
552 ; RV64I-NEXT: addi sp, sp, 16
554 %1 = call double @llvm.log10.f64(double %a)
558 declare double @llvm.log2.f64(double)
560 define double @log2_f64(double %a) nounwind {
561 ; CHECKIFD-LABEL: log2_f64:
563 ; CHECKIFD-NEXT: tail log2@plt
565 ; RV32IZFINXZDINX-LABEL: log2_f64:
566 ; RV32IZFINXZDINX: # %bb.0:
567 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
568 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
569 ; RV32IZFINXZDINX-NEXT: call log2@plt
570 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
571 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
572 ; RV32IZFINXZDINX-NEXT: ret
574 ; RV64IZFINXZDINX-LABEL: log2_f64:
575 ; RV64IZFINXZDINX: # %bb.0:
576 ; RV64IZFINXZDINX-NEXT: tail log2@plt
578 ; RV32I-LABEL: log2_f64:
580 ; RV32I-NEXT: addi sp, sp, -16
581 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
582 ; RV32I-NEXT: call log2@plt
583 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
584 ; RV32I-NEXT: addi sp, sp, 16
587 ; RV64I-LABEL: log2_f64:
589 ; RV64I-NEXT: addi sp, sp, -16
590 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
591 ; RV64I-NEXT: call log2@plt
592 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
593 ; RV64I-NEXT: addi sp, sp, 16
595 %1 = call double @llvm.log2.f64(double %a)
599 declare double @llvm.fma.f64(double, double, double)
601 define double @fma_f64(double %a, double %b, double %c) nounwind {
602 ; CHECKIFD-LABEL: fma_f64:
604 ; CHECKIFD-NEXT: fmadd.d fa0, fa0, fa1, fa2
607 ; RV32IZFINXZDINX-LABEL: fma_f64:
608 ; RV32IZFINXZDINX: # %bb.0:
609 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
610 ; RV32IZFINXZDINX-NEXT: sw a4, 8(sp)
611 ; RV32IZFINXZDINX-NEXT: sw a5, 12(sp)
612 ; RV32IZFINXZDINX-NEXT: lw a4, 8(sp)
613 ; RV32IZFINXZDINX-NEXT: lw a5, 12(sp)
614 ; RV32IZFINXZDINX-NEXT: sw a2, 8(sp)
615 ; RV32IZFINXZDINX-NEXT: sw a3, 12(sp)
616 ; RV32IZFINXZDINX-NEXT: lw a2, 8(sp)
617 ; RV32IZFINXZDINX-NEXT: lw a3, 12(sp)
618 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
619 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
620 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
621 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
622 ; RV32IZFINXZDINX-NEXT: fmadd.d a0, a0, a2, a4
623 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
624 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
625 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
626 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
627 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
628 ; RV32IZFINXZDINX-NEXT: ret
630 ; RV64IZFINXZDINX-LABEL: fma_f64:
631 ; RV64IZFINXZDINX: # %bb.0:
632 ; RV64IZFINXZDINX-NEXT: fmadd.d a0, a0, a1, a2
633 ; RV64IZFINXZDINX-NEXT: ret
635 ; RV32I-LABEL: fma_f64:
637 ; RV32I-NEXT: addi sp, sp, -16
638 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
639 ; RV32I-NEXT: call fma@plt
640 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
641 ; RV32I-NEXT: addi sp, sp, 16
644 ; RV64I-LABEL: fma_f64:
646 ; RV64I-NEXT: addi sp, sp, -16
647 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
648 ; RV64I-NEXT: call fma@plt
649 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
650 ; RV64I-NEXT: addi sp, sp, 16
652 %1 = call double @llvm.fma.f64(double %a, double %b, double %c)
656 declare double @llvm.fmuladd.f64(double, double, double)
658 define double @fmuladd_f64(double %a, double %b, double %c) nounwind {
659 ; CHECKIFD-LABEL: fmuladd_f64:
661 ; CHECKIFD-NEXT: fmadd.d fa0, fa0, fa1, fa2
664 ; RV32IZFINXZDINX-LABEL: fmuladd_f64:
665 ; RV32IZFINXZDINX: # %bb.0:
666 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
667 ; RV32IZFINXZDINX-NEXT: sw a4, 8(sp)
668 ; RV32IZFINXZDINX-NEXT: sw a5, 12(sp)
669 ; RV32IZFINXZDINX-NEXT: lw a4, 8(sp)
670 ; RV32IZFINXZDINX-NEXT: lw a5, 12(sp)
671 ; RV32IZFINXZDINX-NEXT: sw a2, 8(sp)
672 ; RV32IZFINXZDINX-NEXT: sw a3, 12(sp)
673 ; RV32IZFINXZDINX-NEXT: lw a2, 8(sp)
674 ; RV32IZFINXZDINX-NEXT: lw a3, 12(sp)
675 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
676 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
677 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
678 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
679 ; RV32IZFINXZDINX-NEXT: fmadd.d a0, a0, a2, a4
680 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
681 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
682 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
683 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
684 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
685 ; RV32IZFINXZDINX-NEXT: ret
687 ; RV64IZFINXZDINX-LABEL: fmuladd_f64:
688 ; RV64IZFINXZDINX: # %bb.0:
689 ; RV64IZFINXZDINX-NEXT: fmadd.d a0, a0, a1, a2
690 ; RV64IZFINXZDINX-NEXT: ret
692 ; RV32I-LABEL: fmuladd_f64:
694 ; RV32I-NEXT: addi sp, sp, -16
695 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
696 ; RV32I-NEXT: sw s0, 8(sp) # 4-byte Folded Spill
697 ; RV32I-NEXT: sw s1, 4(sp) # 4-byte Folded Spill
698 ; RV32I-NEXT: mv s0, a5
699 ; RV32I-NEXT: mv s1, a4
700 ; RV32I-NEXT: call __muldf3@plt
701 ; RV32I-NEXT: mv a2, s1
702 ; RV32I-NEXT: mv a3, s0
703 ; RV32I-NEXT: call __adddf3@plt
704 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
705 ; RV32I-NEXT: lw s0, 8(sp) # 4-byte Folded Reload
706 ; RV32I-NEXT: lw s1, 4(sp) # 4-byte Folded Reload
707 ; RV32I-NEXT: addi sp, sp, 16
710 ; RV64I-LABEL: fmuladd_f64:
712 ; RV64I-NEXT: addi sp, sp, -16
713 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
714 ; RV64I-NEXT: sd s0, 0(sp) # 8-byte Folded Spill
715 ; RV64I-NEXT: mv s0, a2
716 ; RV64I-NEXT: call __muldf3@plt
717 ; RV64I-NEXT: mv a1, s0
718 ; RV64I-NEXT: call __adddf3@plt
719 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
720 ; RV64I-NEXT: ld s0, 0(sp) # 8-byte Folded Reload
721 ; RV64I-NEXT: addi sp, sp, 16
723 %1 = call double @llvm.fmuladd.f64(double %a, double %b, double %c)
727 declare double @llvm.fabs.f64(double)
729 define double @fabs_f64(double %a) nounwind {
730 ; CHECKIFD-LABEL: fabs_f64:
732 ; CHECKIFD-NEXT: fabs.d fa0, fa0
735 ; RV32IZFINXZDINX-LABEL: fabs_f64:
736 ; RV32IZFINXZDINX: # %bb.0:
737 ; RV32IZFINXZDINX-NEXT: slli a1, a1, 1
738 ; RV32IZFINXZDINX-NEXT: srli a1, a1, 1
739 ; RV32IZFINXZDINX-NEXT: ret
741 ; RV64IZFINXZDINX-LABEL: fabs_f64:
742 ; RV64IZFINXZDINX: # %bb.0:
743 ; RV64IZFINXZDINX-NEXT: slli a0, a0, 1
744 ; RV64IZFINXZDINX-NEXT: srli a0, a0, 1
745 ; RV64IZFINXZDINX-NEXT: ret
747 ; RV32I-LABEL: fabs_f64:
749 ; RV32I-NEXT: slli a1, a1, 1
750 ; RV32I-NEXT: srli a1, a1, 1
753 ; RV64I-LABEL: fabs_f64:
755 ; RV64I-NEXT: slli a0, a0, 1
756 ; RV64I-NEXT: srli a0, a0, 1
758 %1 = call double @llvm.fabs.f64(double %a)
762 declare double @llvm.minnum.f64(double, double)
764 define double @minnum_f64(double %a, double %b) nounwind {
765 ; CHECKIFD-LABEL: minnum_f64:
767 ; CHECKIFD-NEXT: fmin.d fa0, fa0, fa1
770 ; RV32IZFINXZDINX-LABEL: minnum_f64:
771 ; RV32IZFINXZDINX: # %bb.0:
772 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
773 ; RV32IZFINXZDINX-NEXT: sw a2, 8(sp)
774 ; RV32IZFINXZDINX-NEXT: sw a3, 12(sp)
775 ; RV32IZFINXZDINX-NEXT: lw a2, 8(sp)
776 ; RV32IZFINXZDINX-NEXT: lw a3, 12(sp)
777 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
778 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
779 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
780 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
781 ; RV32IZFINXZDINX-NEXT: fmin.d a0, a0, a2
782 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
783 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
784 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
785 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
786 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
787 ; RV32IZFINXZDINX-NEXT: ret
789 ; RV64IZFINXZDINX-LABEL: minnum_f64:
790 ; RV64IZFINXZDINX: # %bb.0:
791 ; RV64IZFINXZDINX-NEXT: fmin.d a0, a0, a1
792 ; RV64IZFINXZDINX-NEXT: ret
794 ; RV32I-LABEL: minnum_f64:
796 ; RV32I-NEXT: addi sp, sp, -16
797 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
798 ; RV32I-NEXT: call fmin@plt
799 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
800 ; RV32I-NEXT: addi sp, sp, 16
803 ; RV64I-LABEL: minnum_f64:
805 ; RV64I-NEXT: addi sp, sp, -16
806 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
807 ; RV64I-NEXT: call fmin@plt
808 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
809 ; RV64I-NEXT: addi sp, sp, 16
811 %1 = call double @llvm.minnum.f64(double %a, double %b)
815 declare double @llvm.maxnum.f64(double, double)
817 define double @maxnum_f64(double %a, double %b) nounwind {
818 ; CHECKIFD-LABEL: maxnum_f64:
820 ; CHECKIFD-NEXT: fmax.d fa0, fa0, fa1
823 ; RV32IZFINXZDINX-LABEL: maxnum_f64:
824 ; RV32IZFINXZDINX: # %bb.0:
825 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
826 ; RV32IZFINXZDINX-NEXT: sw a2, 8(sp)
827 ; RV32IZFINXZDINX-NEXT: sw a3, 12(sp)
828 ; RV32IZFINXZDINX-NEXT: lw a2, 8(sp)
829 ; RV32IZFINXZDINX-NEXT: lw a3, 12(sp)
830 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
831 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
832 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
833 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
834 ; RV32IZFINXZDINX-NEXT: fmax.d a0, a0, a2
835 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
836 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
837 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
838 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
839 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
840 ; RV32IZFINXZDINX-NEXT: ret
842 ; RV64IZFINXZDINX-LABEL: maxnum_f64:
843 ; RV64IZFINXZDINX: # %bb.0:
844 ; RV64IZFINXZDINX-NEXT: fmax.d a0, a0, a1
845 ; RV64IZFINXZDINX-NEXT: ret
847 ; RV32I-LABEL: maxnum_f64:
849 ; RV32I-NEXT: addi sp, sp, -16
850 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
851 ; RV32I-NEXT: call fmax@plt
852 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
853 ; RV32I-NEXT: addi sp, sp, 16
856 ; RV64I-LABEL: maxnum_f64:
858 ; RV64I-NEXT: addi sp, sp, -16
859 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
860 ; RV64I-NEXT: call fmax@plt
861 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
862 ; RV64I-NEXT: addi sp, sp, 16
864 %1 = call double @llvm.maxnum.f64(double %a, double %b)
868 ; TODO: FMINNAN and FMAXNAN aren't handled in
869 ; SelectionDAGLegalize::ExpandNode.
871 ; declare double @llvm.minimum.f64(double, double)
873 ; define double @fminimum_f64(double %a, double %b) nounwind {
874 ; %1 = call double @llvm.minimum.f64(double %a, double %b)
878 ; declare double @llvm.maximum.f64(double, double)
880 ; define double @fmaximum_f64(double %a, double %b) nounwind {
881 ; %1 = call double @llvm.maximum.f64(double %a, double %b)
885 declare double @llvm.copysign.f64(double, double)
887 define double @copysign_f64(double %a, double %b) nounwind {
888 ; CHECKIFD-LABEL: copysign_f64:
890 ; CHECKIFD-NEXT: fsgnj.d fa0, fa0, fa1
893 ; RV32IZFINXZDINX-LABEL: copysign_f64:
894 ; RV32IZFINXZDINX: # %bb.0:
895 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
896 ; RV32IZFINXZDINX-NEXT: sw a2, 8(sp)
897 ; RV32IZFINXZDINX-NEXT: sw a3, 12(sp)
898 ; RV32IZFINXZDINX-NEXT: lw a2, 8(sp)
899 ; RV32IZFINXZDINX-NEXT: lw a3, 12(sp)
900 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
901 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
902 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
903 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
904 ; RV32IZFINXZDINX-NEXT: fsgnj.d a0, a0, a2
905 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
906 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
907 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
908 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
909 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
910 ; RV32IZFINXZDINX-NEXT: ret
912 ; RV64IZFINXZDINX-LABEL: copysign_f64:
913 ; RV64IZFINXZDINX: # %bb.0:
914 ; RV64IZFINXZDINX-NEXT: fsgnj.d a0, a0, a1
915 ; RV64IZFINXZDINX-NEXT: ret
917 ; RV32I-LABEL: copysign_f64:
919 ; RV32I-NEXT: lui a2, 524288
920 ; RV32I-NEXT: and a2, a3, a2
921 ; RV32I-NEXT: slli a1, a1, 1
922 ; RV32I-NEXT: srli a1, a1, 1
923 ; RV32I-NEXT: or a1, a1, a2
926 ; RV64I-LABEL: copysign_f64:
928 ; RV64I-NEXT: srli a1, a1, 63
929 ; RV64I-NEXT: slli a1, a1, 63
930 ; RV64I-NEXT: slli a0, a0, 1
931 ; RV64I-NEXT: srli a0, a0, 1
932 ; RV64I-NEXT: or a0, a0, a1
934 %1 = call double @llvm.copysign.f64(double %a, double %b)
938 declare double @llvm.floor.f64(double)
940 define double @floor_f64(double %a) nounwind {
941 ; RV32IFD-LABEL: floor_f64:
943 ; RV32IFD-NEXT: tail floor@plt
945 ; RV64IFD-LABEL: floor_f64:
947 ; RV64IFD-NEXT: lui a0, %hi(.LCPI17_0)
948 ; RV64IFD-NEXT: fld fa5, %lo(.LCPI17_0)(a0)
949 ; RV64IFD-NEXT: fabs.d fa4, fa0
950 ; RV64IFD-NEXT: flt.d a0, fa4, fa5
951 ; RV64IFD-NEXT: beqz a0, .LBB17_2
952 ; RV64IFD-NEXT: # %bb.1:
953 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rdn
954 ; RV64IFD-NEXT: fcvt.d.l fa5, a0, rdn
955 ; RV64IFD-NEXT: fsgnj.d fa0, fa5, fa0
956 ; RV64IFD-NEXT: .LBB17_2:
959 ; RV32IZFINXZDINX-LABEL: floor_f64:
960 ; RV32IZFINXZDINX: # %bb.0:
961 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
962 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
963 ; RV32IZFINXZDINX-NEXT: call floor@plt
964 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
965 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
966 ; RV32IZFINXZDINX-NEXT: ret
968 ; RV64IZFINXZDINX-LABEL: floor_f64:
969 ; RV64IZFINXZDINX: # %bb.0:
970 ; RV64IZFINXZDINX-NEXT: lui a1, %hi(.LCPI17_0)
971 ; RV64IZFINXZDINX-NEXT: ld a1, %lo(.LCPI17_0)(a1)
972 ; RV64IZFINXZDINX-NEXT: fabs.d a2, a0
973 ; RV64IZFINXZDINX-NEXT: flt.d a1, a2, a1
974 ; RV64IZFINXZDINX-NEXT: beqz a1, .LBB17_2
975 ; RV64IZFINXZDINX-NEXT: # %bb.1:
976 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a1, a0, rdn
977 ; RV64IZFINXZDINX-NEXT: fcvt.d.l a1, a1, rdn
978 ; RV64IZFINXZDINX-NEXT: fsgnj.d a0, a1, a0
979 ; RV64IZFINXZDINX-NEXT: .LBB17_2:
980 ; RV64IZFINXZDINX-NEXT: ret
982 ; RV32I-LABEL: floor_f64:
984 ; RV32I-NEXT: addi sp, sp, -16
985 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
986 ; RV32I-NEXT: call floor@plt
987 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
988 ; RV32I-NEXT: addi sp, sp, 16
991 ; RV64I-LABEL: floor_f64:
993 ; RV64I-NEXT: addi sp, sp, -16
994 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
995 ; RV64I-NEXT: call floor@plt
996 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
997 ; RV64I-NEXT: addi sp, sp, 16
999 %1 = call double @llvm.floor.f64(double %a)
1003 declare double @llvm.ceil.f64(double)
1005 define double @ceil_f64(double %a) nounwind {
1006 ; RV32IFD-LABEL: ceil_f64:
1008 ; RV32IFD-NEXT: tail ceil@plt
1010 ; RV64IFD-LABEL: ceil_f64:
1012 ; RV64IFD-NEXT: lui a0, %hi(.LCPI18_0)
1013 ; RV64IFD-NEXT: fld fa5, %lo(.LCPI18_0)(a0)
1014 ; RV64IFD-NEXT: fabs.d fa4, fa0
1015 ; RV64IFD-NEXT: flt.d a0, fa4, fa5
1016 ; RV64IFD-NEXT: beqz a0, .LBB18_2
1017 ; RV64IFD-NEXT: # %bb.1:
1018 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rup
1019 ; RV64IFD-NEXT: fcvt.d.l fa5, a0, rup
1020 ; RV64IFD-NEXT: fsgnj.d fa0, fa5, fa0
1021 ; RV64IFD-NEXT: .LBB18_2:
1024 ; RV32IZFINXZDINX-LABEL: ceil_f64:
1025 ; RV32IZFINXZDINX: # %bb.0:
1026 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1027 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1028 ; RV32IZFINXZDINX-NEXT: call ceil@plt
1029 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1030 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1031 ; RV32IZFINXZDINX-NEXT: ret
1033 ; RV64IZFINXZDINX-LABEL: ceil_f64:
1034 ; RV64IZFINXZDINX: # %bb.0:
1035 ; RV64IZFINXZDINX-NEXT: lui a1, %hi(.LCPI18_0)
1036 ; RV64IZFINXZDINX-NEXT: ld a1, %lo(.LCPI18_0)(a1)
1037 ; RV64IZFINXZDINX-NEXT: fabs.d a2, a0
1038 ; RV64IZFINXZDINX-NEXT: flt.d a1, a2, a1
1039 ; RV64IZFINXZDINX-NEXT: beqz a1, .LBB18_2
1040 ; RV64IZFINXZDINX-NEXT: # %bb.1:
1041 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a1, a0, rup
1042 ; RV64IZFINXZDINX-NEXT: fcvt.d.l a1, a1, rup
1043 ; RV64IZFINXZDINX-NEXT: fsgnj.d a0, a1, a0
1044 ; RV64IZFINXZDINX-NEXT: .LBB18_2:
1045 ; RV64IZFINXZDINX-NEXT: ret
1047 ; RV32I-LABEL: ceil_f64:
1049 ; RV32I-NEXT: addi sp, sp, -16
1050 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1051 ; RV32I-NEXT: call ceil@plt
1052 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1053 ; RV32I-NEXT: addi sp, sp, 16
1056 ; RV64I-LABEL: ceil_f64:
1058 ; RV64I-NEXT: addi sp, sp, -16
1059 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
1060 ; RV64I-NEXT: call ceil@plt
1061 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
1062 ; RV64I-NEXT: addi sp, sp, 16
1064 %1 = call double @llvm.ceil.f64(double %a)
1068 declare double @llvm.trunc.f64(double)
1070 define double @trunc_f64(double %a) nounwind {
1071 ; RV32IFD-LABEL: trunc_f64:
1073 ; RV32IFD-NEXT: tail trunc@plt
1075 ; RV64IFD-LABEL: trunc_f64:
1077 ; RV64IFD-NEXT: lui a0, %hi(.LCPI19_0)
1078 ; RV64IFD-NEXT: fld fa5, %lo(.LCPI19_0)(a0)
1079 ; RV64IFD-NEXT: fabs.d fa4, fa0
1080 ; RV64IFD-NEXT: flt.d a0, fa4, fa5
1081 ; RV64IFD-NEXT: beqz a0, .LBB19_2
1082 ; RV64IFD-NEXT: # %bb.1:
1083 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rtz
1084 ; RV64IFD-NEXT: fcvt.d.l fa5, a0, rtz
1085 ; RV64IFD-NEXT: fsgnj.d fa0, fa5, fa0
1086 ; RV64IFD-NEXT: .LBB19_2:
1089 ; RV32IZFINXZDINX-LABEL: trunc_f64:
1090 ; RV32IZFINXZDINX: # %bb.0:
1091 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1092 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1093 ; RV32IZFINXZDINX-NEXT: call trunc@plt
1094 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1095 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1096 ; RV32IZFINXZDINX-NEXT: ret
1098 ; RV64IZFINXZDINX-LABEL: trunc_f64:
1099 ; RV64IZFINXZDINX: # %bb.0:
1100 ; RV64IZFINXZDINX-NEXT: lui a1, %hi(.LCPI19_0)
1101 ; RV64IZFINXZDINX-NEXT: ld a1, %lo(.LCPI19_0)(a1)
1102 ; RV64IZFINXZDINX-NEXT: fabs.d a2, a0
1103 ; RV64IZFINXZDINX-NEXT: flt.d a1, a2, a1
1104 ; RV64IZFINXZDINX-NEXT: beqz a1, .LBB19_2
1105 ; RV64IZFINXZDINX-NEXT: # %bb.1:
1106 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a1, a0, rtz
1107 ; RV64IZFINXZDINX-NEXT: fcvt.d.l a1, a1, rtz
1108 ; RV64IZFINXZDINX-NEXT: fsgnj.d a0, a1, a0
1109 ; RV64IZFINXZDINX-NEXT: .LBB19_2:
1110 ; RV64IZFINXZDINX-NEXT: ret
1112 ; RV32I-LABEL: trunc_f64:
1114 ; RV32I-NEXT: addi sp, sp, -16
1115 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1116 ; RV32I-NEXT: call trunc@plt
1117 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1118 ; RV32I-NEXT: addi sp, sp, 16
1121 ; RV64I-LABEL: trunc_f64:
1123 ; RV64I-NEXT: addi sp, sp, -16
1124 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
1125 ; RV64I-NEXT: call trunc@plt
1126 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
1127 ; RV64I-NEXT: addi sp, sp, 16
1129 %1 = call double @llvm.trunc.f64(double %a)
1133 declare double @llvm.rint.f64(double)
1135 define double @rint_f64(double %a) nounwind {
1136 ; RV32IFD-LABEL: rint_f64:
1138 ; RV32IFD-NEXT: tail rint@plt
1140 ; RV64IFD-LABEL: rint_f64:
1142 ; RV64IFD-NEXT: lui a0, %hi(.LCPI20_0)
1143 ; RV64IFD-NEXT: fld fa5, %lo(.LCPI20_0)(a0)
1144 ; RV64IFD-NEXT: fabs.d fa4, fa0
1145 ; RV64IFD-NEXT: flt.d a0, fa4, fa5
1146 ; RV64IFD-NEXT: beqz a0, .LBB20_2
1147 ; RV64IFD-NEXT: # %bb.1:
1148 ; RV64IFD-NEXT: fcvt.l.d a0, fa0
1149 ; RV64IFD-NEXT: fcvt.d.l fa5, a0
1150 ; RV64IFD-NEXT: fsgnj.d fa0, fa5, fa0
1151 ; RV64IFD-NEXT: .LBB20_2:
1154 ; RV32IZFINXZDINX-LABEL: rint_f64:
1155 ; RV32IZFINXZDINX: # %bb.0:
1156 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1157 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1158 ; RV32IZFINXZDINX-NEXT: call rint@plt
1159 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1160 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1161 ; RV32IZFINXZDINX-NEXT: ret
1163 ; RV64IZFINXZDINX-LABEL: rint_f64:
1164 ; RV64IZFINXZDINX: # %bb.0:
1165 ; RV64IZFINXZDINX-NEXT: lui a1, %hi(.LCPI20_0)
1166 ; RV64IZFINXZDINX-NEXT: ld a1, %lo(.LCPI20_0)(a1)
1167 ; RV64IZFINXZDINX-NEXT: fabs.d a2, a0
1168 ; RV64IZFINXZDINX-NEXT: flt.d a1, a2, a1
1169 ; RV64IZFINXZDINX-NEXT: beqz a1, .LBB20_2
1170 ; RV64IZFINXZDINX-NEXT: # %bb.1:
1171 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a1, a0
1172 ; RV64IZFINXZDINX-NEXT: fcvt.d.l a1, a1
1173 ; RV64IZFINXZDINX-NEXT: fsgnj.d a0, a1, a0
1174 ; RV64IZFINXZDINX-NEXT: .LBB20_2:
1175 ; RV64IZFINXZDINX-NEXT: ret
1177 ; RV32I-LABEL: rint_f64:
1179 ; RV32I-NEXT: addi sp, sp, -16
1180 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1181 ; RV32I-NEXT: call rint@plt
1182 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1183 ; RV32I-NEXT: addi sp, sp, 16
1186 ; RV64I-LABEL: rint_f64:
1188 ; RV64I-NEXT: addi sp, sp, -16
1189 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
1190 ; RV64I-NEXT: call rint@plt
1191 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
1192 ; RV64I-NEXT: addi sp, sp, 16
1194 %1 = call double @llvm.rint.f64(double %a)
1198 declare double @llvm.nearbyint.f64(double)
1200 define double @nearbyint_f64(double %a) nounwind {
1201 ; CHECKIFD-LABEL: nearbyint_f64:
1202 ; CHECKIFD: # %bb.0:
1203 ; CHECKIFD-NEXT: tail nearbyint@plt
1205 ; RV32IZFINXZDINX-LABEL: nearbyint_f64:
1206 ; RV32IZFINXZDINX: # %bb.0:
1207 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1208 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1209 ; RV32IZFINXZDINX-NEXT: call nearbyint@plt
1210 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1211 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1212 ; RV32IZFINXZDINX-NEXT: ret
1214 ; RV64IZFINXZDINX-LABEL: nearbyint_f64:
1215 ; RV64IZFINXZDINX: # %bb.0:
1216 ; RV64IZFINXZDINX-NEXT: tail nearbyint@plt
1218 ; RV32I-LABEL: nearbyint_f64:
1220 ; RV32I-NEXT: addi sp, sp, -16
1221 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1222 ; RV32I-NEXT: call nearbyint@plt
1223 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1224 ; RV32I-NEXT: addi sp, sp, 16
1227 ; RV64I-LABEL: nearbyint_f64:
1229 ; RV64I-NEXT: addi sp, sp, -16
1230 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
1231 ; RV64I-NEXT: call nearbyint@plt
1232 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
1233 ; RV64I-NEXT: addi sp, sp, 16
1235 %1 = call double @llvm.nearbyint.f64(double %a)
1239 declare double @llvm.round.f64(double)
1241 define double @round_f64(double %a) nounwind {
1242 ; RV32IFD-LABEL: round_f64:
1244 ; RV32IFD-NEXT: tail round@plt
1246 ; RV64IFD-LABEL: round_f64:
1248 ; RV64IFD-NEXT: lui a0, %hi(.LCPI22_0)
1249 ; RV64IFD-NEXT: fld fa5, %lo(.LCPI22_0)(a0)
1250 ; RV64IFD-NEXT: fabs.d fa4, fa0
1251 ; RV64IFD-NEXT: flt.d a0, fa4, fa5
1252 ; RV64IFD-NEXT: beqz a0, .LBB22_2
1253 ; RV64IFD-NEXT: # %bb.1:
1254 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rmm
1255 ; RV64IFD-NEXT: fcvt.d.l fa5, a0, rmm
1256 ; RV64IFD-NEXT: fsgnj.d fa0, fa5, fa0
1257 ; RV64IFD-NEXT: .LBB22_2:
1260 ; RV32IZFINXZDINX-LABEL: round_f64:
1261 ; RV32IZFINXZDINX: # %bb.0:
1262 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1263 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1264 ; RV32IZFINXZDINX-NEXT: call round@plt
1265 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1266 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1267 ; RV32IZFINXZDINX-NEXT: ret
1269 ; RV64IZFINXZDINX-LABEL: round_f64:
1270 ; RV64IZFINXZDINX: # %bb.0:
1271 ; RV64IZFINXZDINX-NEXT: lui a1, %hi(.LCPI22_0)
1272 ; RV64IZFINXZDINX-NEXT: ld a1, %lo(.LCPI22_0)(a1)
1273 ; RV64IZFINXZDINX-NEXT: fabs.d a2, a0
1274 ; RV64IZFINXZDINX-NEXT: flt.d a1, a2, a1
1275 ; RV64IZFINXZDINX-NEXT: beqz a1, .LBB22_2
1276 ; RV64IZFINXZDINX-NEXT: # %bb.1:
1277 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a1, a0, rmm
1278 ; RV64IZFINXZDINX-NEXT: fcvt.d.l a1, a1, rmm
1279 ; RV64IZFINXZDINX-NEXT: fsgnj.d a0, a1, a0
1280 ; RV64IZFINXZDINX-NEXT: .LBB22_2:
1281 ; RV64IZFINXZDINX-NEXT: ret
1283 ; RV32I-LABEL: round_f64:
1285 ; RV32I-NEXT: addi sp, sp, -16
1286 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1287 ; RV32I-NEXT: call round@plt
1288 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1289 ; RV32I-NEXT: addi sp, sp, 16
1292 ; RV64I-LABEL: round_f64:
1294 ; RV64I-NEXT: addi sp, sp, -16
1295 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
1296 ; RV64I-NEXT: call round@plt
1297 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
1298 ; RV64I-NEXT: addi sp, sp, 16
1300 %1 = call double @llvm.round.f64(double %a)
1304 declare double @llvm.roundeven.f64(double)
1306 define double @roundeven_f64(double %a) nounwind {
1307 ; RV32IFD-LABEL: roundeven_f64:
1309 ; RV32IFD-NEXT: tail roundeven@plt
1311 ; RV64IFD-LABEL: roundeven_f64:
1313 ; RV64IFD-NEXT: lui a0, %hi(.LCPI23_0)
1314 ; RV64IFD-NEXT: fld fa5, %lo(.LCPI23_0)(a0)
1315 ; RV64IFD-NEXT: fabs.d fa4, fa0
1316 ; RV64IFD-NEXT: flt.d a0, fa4, fa5
1317 ; RV64IFD-NEXT: beqz a0, .LBB23_2
1318 ; RV64IFD-NEXT: # %bb.1:
1319 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rne
1320 ; RV64IFD-NEXT: fcvt.d.l fa5, a0, rne
1321 ; RV64IFD-NEXT: fsgnj.d fa0, fa5, fa0
1322 ; RV64IFD-NEXT: .LBB23_2:
1325 ; RV32IZFINXZDINX-LABEL: roundeven_f64:
1326 ; RV32IZFINXZDINX: # %bb.0:
1327 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1328 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1329 ; RV32IZFINXZDINX-NEXT: call roundeven@plt
1330 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1331 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1332 ; RV32IZFINXZDINX-NEXT: ret
1334 ; RV64IZFINXZDINX-LABEL: roundeven_f64:
1335 ; RV64IZFINXZDINX: # %bb.0:
1336 ; RV64IZFINXZDINX-NEXT: lui a1, %hi(.LCPI23_0)
1337 ; RV64IZFINXZDINX-NEXT: ld a1, %lo(.LCPI23_0)(a1)
1338 ; RV64IZFINXZDINX-NEXT: fabs.d a2, a0
1339 ; RV64IZFINXZDINX-NEXT: flt.d a1, a2, a1
1340 ; RV64IZFINXZDINX-NEXT: beqz a1, .LBB23_2
1341 ; RV64IZFINXZDINX-NEXT: # %bb.1:
1342 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a1, a0, rne
1343 ; RV64IZFINXZDINX-NEXT: fcvt.d.l a1, a1, rne
1344 ; RV64IZFINXZDINX-NEXT: fsgnj.d a0, a1, a0
1345 ; RV64IZFINXZDINX-NEXT: .LBB23_2:
1346 ; RV64IZFINXZDINX-NEXT: ret
1348 ; RV32I-LABEL: roundeven_f64:
1350 ; RV32I-NEXT: addi sp, sp, -16
1351 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1352 ; RV32I-NEXT: call roundeven@plt
1353 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1354 ; RV32I-NEXT: addi sp, sp, 16
1357 ; RV64I-LABEL: roundeven_f64:
1359 ; RV64I-NEXT: addi sp, sp, -16
1360 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
1361 ; RV64I-NEXT: call roundeven@plt
1362 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
1363 ; RV64I-NEXT: addi sp, sp, 16
1365 %1 = call double @llvm.roundeven.f64(double %a)
1369 declare iXLen @llvm.lrint.iXLen.f64(double)
1371 define iXLen @lrint_f64(double %a) nounwind {
1372 ; RV32IFD-LABEL: lrint_f64:
1374 ; RV32IFD-NEXT: fcvt.w.d a0, fa0
1377 ; RV64IFD-LABEL: lrint_f64:
1379 ; RV64IFD-NEXT: fcvt.l.d a0, fa0
1382 ; RV32IZFINXZDINX-LABEL: lrint_f64:
1383 ; RV32IZFINXZDINX: # %bb.0:
1384 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1385 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
1386 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
1387 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
1388 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
1389 ; RV32IZFINXZDINX-NEXT: fcvt.w.d a0, a0
1390 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1391 ; RV32IZFINXZDINX-NEXT: ret
1393 ; RV64IZFINXZDINX-LABEL: lrint_f64:
1394 ; RV64IZFINXZDINX: # %bb.0:
1395 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a0, a0
1396 ; RV64IZFINXZDINX-NEXT: ret
1398 ; RV32I-LABEL: lrint_f64:
1400 ; RV32I-NEXT: addi sp, sp, -16
1401 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1402 ; RV32I-NEXT: call lrint@plt
1403 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1404 ; RV32I-NEXT: addi sp, sp, 16
1407 ; RV64I-LABEL: lrint_f64:
1409 ; RV64I-NEXT: addi sp, sp, -16
1410 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
1411 ; RV64I-NEXT: call lrint@plt
1412 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
1413 ; RV64I-NEXT: addi sp, sp, 16
1415 %1 = call iXLen @llvm.lrint.iXLen.f64(double %a)
1419 declare i32 @llvm.lround.i32.f64(double)
1420 declare i64 @llvm.lround.i64.f64(double)
1422 define iXLen @lround_f64(double %a) nounwind {
1423 ; RV32IFD-LABEL: lround_f64:
1425 ; RV32IFD-NEXT: fcvt.w.d a0, fa0, rmm
1428 ; RV64IFD-LABEL: lround_f64:
1430 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rmm
1433 ; RV32IZFINXZDINX-LABEL: lround_f64:
1434 ; RV32IZFINXZDINX: # %bb.0:
1435 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1436 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
1437 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
1438 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
1439 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
1440 ; RV32IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rmm
1441 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1442 ; RV32IZFINXZDINX-NEXT: ret
1444 ; RV64IZFINXZDINX-LABEL: lround_f64:
1445 ; RV64IZFINXZDINX: # %bb.0:
1446 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a0, a0, rmm
1447 ; RV64IZFINXZDINX-NEXT: ret
1449 ; RV32I-LABEL: lround_f64:
1451 ; RV32I-NEXT: addi sp, sp, -16
1452 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1453 ; RV32I-NEXT: call lround@plt
1454 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1455 ; RV32I-NEXT: addi sp, sp, 16
1458 ; RV64I-LABEL: lround_f64:
1460 ; RV64I-NEXT: addi sp, sp, -16
1461 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
1462 ; RV64I-NEXT: call lround@plt
1463 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
1464 ; RV64I-NEXT: addi sp, sp, 16
1466 %1 = call iXLen @llvm.lround.iXLen.f64(double %a)
1470 define i32 @lround_i32_f64(double %a) nounwind {
1471 ; CHECKIFD-LABEL: lround_i32_f64:
1472 ; CHECKIFD: # %bb.0:
1473 ; CHECKIFD-NEXT: fcvt.w.d a0, fa0, rmm
1474 ; CHECKIFD-NEXT: ret
1476 ; RV32IZFINXZDINX-LABEL: lround_i32_f64:
1477 ; RV32IZFINXZDINX: # %bb.0:
1478 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1479 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
1480 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
1481 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
1482 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
1483 ; RV32IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rmm
1484 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1485 ; RV32IZFINXZDINX-NEXT: ret
1487 ; RV64IZFINXZDINX-LABEL: lround_i32_f64:
1488 ; RV64IZFINXZDINX: # %bb.0:
1489 ; RV64IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rmm
1490 ; RV64IZFINXZDINX-NEXT: ret
1492 ; RV32I-LABEL: lround_i32_f64:
1494 ; RV32I-NEXT: addi sp, sp, -16
1495 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1496 ; RV32I-NEXT: call lround@plt
1497 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1498 ; RV32I-NEXT: addi sp, sp, 16
1501 ; RV64I-LABEL: lround_i32_f64:
1503 ; RV64I-NEXT: addi sp, sp, -16
1504 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
1505 ; RV64I-NEXT: call lround@plt
1506 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
1507 ; RV64I-NEXT: addi sp, sp, 16
1509 %1 = call i32 @llvm.lround.i32.f64(double %a)
1513 declare i64 @llvm.llrint.i64.f64(double)
1515 define i64 @llrint_f64(double %a) nounwind {
1516 ; RV32IFD-LABEL: llrint_f64:
1518 ; RV32IFD-NEXT: addi sp, sp, -16
1519 ; RV32IFD-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1520 ; RV32IFD-NEXT: call llrint@plt
1521 ; RV32IFD-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1522 ; RV32IFD-NEXT: addi sp, sp, 16
1525 ; RV64IFD-LABEL: llrint_f64:
1527 ; RV64IFD-NEXT: fcvt.l.d a0, fa0
1530 ; RV32IZFINXZDINX-LABEL: llrint_f64:
1531 ; RV32IZFINXZDINX: # %bb.0:
1532 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1533 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1534 ; RV32IZFINXZDINX-NEXT: call llrint@plt
1535 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1536 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1537 ; RV32IZFINXZDINX-NEXT: ret
1539 ; RV64IZFINXZDINX-LABEL: llrint_f64:
1540 ; RV64IZFINXZDINX: # %bb.0:
1541 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a0, a0
1542 ; RV64IZFINXZDINX-NEXT: ret
1544 ; RV32I-LABEL: llrint_f64:
1546 ; RV32I-NEXT: addi sp, sp, -16
1547 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1548 ; RV32I-NEXT: call llrint@plt
1549 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1550 ; RV32I-NEXT: addi sp, sp, 16
1553 ; RV64I-LABEL: llrint_f64:
1555 ; RV64I-NEXT: addi sp, sp, -16
1556 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
1557 ; RV64I-NEXT: call llrint@plt
1558 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
1559 ; RV64I-NEXT: addi sp, sp, 16
1561 %1 = call i64 @llvm.llrint.i64.f64(double %a)
1565 declare i64 @llvm.llround.i64.f64(double)
1567 define i64 @llround_f64(double %a) nounwind {
1568 ; RV32IFD-LABEL: llround_f64:
1570 ; RV32IFD-NEXT: addi sp, sp, -16
1571 ; RV32IFD-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1572 ; RV32IFD-NEXT: call llround@plt
1573 ; RV32IFD-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1574 ; RV32IFD-NEXT: addi sp, sp, 16
1577 ; RV64IFD-LABEL: llround_f64:
1579 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rmm
1582 ; RV32IZFINXZDINX-LABEL: llround_f64:
1583 ; RV32IZFINXZDINX: # %bb.0:
1584 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1585 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1586 ; RV32IZFINXZDINX-NEXT: call llround@plt
1587 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1588 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1589 ; RV32IZFINXZDINX-NEXT: ret
1591 ; RV64IZFINXZDINX-LABEL: llround_f64:
1592 ; RV64IZFINXZDINX: # %bb.0:
1593 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a0, a0, rmm
1594 ; RV64IZFINXZDINX-NEXT: ret
1596 ; RV32I-LABEL: llround_f64:
1598 ; RV32I-NEXT: addi sp, sp, -16
1599 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1600 ; RV32I-NEXT: call llround@plt
1601 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1602 ; RV32I-NEXT: addi sp, sp, 16
1605 ; RV64I-LABEL: llround_f64:
1607 ; RV64I-NEXT: addi sp, sp, -16
1608 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
1609 ; RV64I-NEXT: call llround@plt
1610 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
1611 ; RV64I-NEXT: addi sp, sp, 16
1613 %1 = call i64 @llvm.llround.i64.f64(double %a)
1617 declare i1 @llvm.is.fpclass.f64(double, i32)
1618 define i1 @isnan_d_fpclass(double %x) {
1619 ; CHECKIFD-LABEL: isnan_d_fpclass:
1620 ; CHECKIFD: # %bb.0:
1621 ; CHECKIFD-NEXT: fclass.d a0, fa0
1622 ; CHECKIFD-NEXT: andi a0, a0, 768
1623 ; CHECKIFD-NEXT: snez a0, a0
1624 ; CHECKIFD-NEXT: ret
1626 ; RV32IZFINXZDINX-LABEL: isnan_d_fpclass:
1627 ; RV32IZFINXZDINX: # %bb.0:
1628 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1629 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
1630 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
1631 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
1632 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
1633 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
1634 ; RV32IZFINXZDINX-NEXT: fclass.d a0, a0
1635 ; RV32IZFINXZDINX-NEXT: andi a0, a0, 768
1636 ; RV32IZFINXZDINX-NEXT: snez a0, a0
1637 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1638 ; RV32IZFINXZDINX-NEXT: ret
1640 ; RV64IZFINXZDINX-LABEL: isnan_d_fpclass:
1641 ; RV64IZFINXZDINX: # %bb.0:
1642 ; RV64IZFINXZDINX-NEXT: fclass.d a0, a0
1643 ; RV64IZFINXZDINX-NEXT: andi a0, a0, 768
1644 ; RV64IZFINXZDINX-NEXT: snez a0, a0
1645 ; RV64IZFINXZDINX-NEXT: ret
1647 ; RV32I-LABEL: isnan_d_fpclass:
1649 ; RV32I-NEXT: slli a1, a1, 1
1650 ; RV32I-NEXT: srli a1, a1, 1
1651 ; RV32I-NEXT: lui a2, 524032
1652 ; RV32I-NEXT: beq a1, a2, .LBB29_2
1653 ; RV32I-NEXT: # %bb.1:
1654 ; RV32I-NEXT: slt a0, a2, a1
1656 ; RV32I-NEXT: .LBB29_2:
1657 ; RV32I-NEXT: snez a0, a0
1660 ; RV64I-LABEL: isnan_d_fpclass:
1662 ; RV64I-NEXT: slli a0, a0, 1
1663 ; RV64I-NEXT: srli a0, a0, 1
1664 ; RV64I-NEXT: li a1, 2047
1665 ; RV64I-NEXT: slli a1, a1, 52
1666 ; RV64I-NEXT: slt a0, a1, a0
1668 %1 = call i1 @llvm.is.fpclass.f64(double %x, i32 3) ; nan