1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -mtriple=riscv32 -mattr=+d -verify-machineinstrs < %s \
3 ; RUN: -target-abi=ilp32d | FileCheck -check-prefixes=CHECKIFD,RV32IFD %s
4 ; RUN: llc -mtriple=riscv64 -mattr=+d -verify-machineinstrs < %s \
5 ; RUN: -target-abi=lp64d | FileCheck -check-prefixes=CHECKIFD,RV64IFD %s
6 ; RUN: llc -mtriple=riscv32 -mattr=+zdinx -verify-machineinstrs < %s \
7 ; RUN: -target-abi=ilp32 | FileCheck -check-prefixes=RV32IZFINXZDINX %s
8 ; RUN: llc -mtriple=riscv64 -mattr=+zdinx -verify-machineinstrs < %s \
9 ; RUN: -target-abi=lp64 | FileCheck -check-prefixes=RV64IZFINXZDINX %s
11 define signext i8 @test_floor_si8(double %x) {
12 ; RV32IFD-LABEL: test_floor_si8:
14 ; RV32IFD-NEXT: fcvt.w.d a0, fa0, rdn
17 ; RV64IFD-LABEL: test_floor_si8:
19 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rdn
22 ; RV32IZFINXZDINX-LABEL: test_floor_si8:
23 ; RV32IZFINXZDINX: # %bb.0:
24 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
25 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
26 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
27 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
28 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
29 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
30 ; RV32IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rdn
31 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
32 ; RV32IZFINXZDINX-NEXT: ret
34 ; RV64IZFINXZDINX-LABEL: test_floor_si8:
35 ; RV64IZFINXZDINX: # %bb.0:
36 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a0, a0, rdn
37 ; RV64IZFINXZDINX-NEXT: ret
38 %a = call double @llvm.floor.f64(double %x)
39 %b = fptosi double %a to i8
43 define signext i16 @test_floor_si16(double %x) {
44 ; RV32IFD-LABEL: test_floor_si16:
46 ; RV32IFD-NEXT: fcvt.w.d a0, fa0, rdn
49 ; RV64IFD-LABEL: test_floor_si16:
51 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rdn
54 ; RV32IZFINXZDINX-LABEL: test_floor_si16:
55 ; RV32IZFINXZDINX: # %bb.0:
56 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
57 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
58 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
59 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
60 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
61 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
62 ; RV32IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rdn
63 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
64 ; RV32IZFINXZDINX-NEXT: ret
66 ; RV64IZFINXZDINX-LABEL: test_floor_si16:
67 ; RV64IZFINXZDINX: # %bb.0:
68 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a0, a0, rdn
69 ; RV64IZFINXZDINX-NEXT: ret
70 %a = call double @llvm.floor.f64(double %x)
71 %b = fptosi double %a to i16
75 define signext i32 @test_floor_si32(double %x) {
76 ; CHECKIFD-LABEL: test_floor_si32:
78 ; CHECKIFD-NEXT: fcvt.w.d a0, fa0, rdn
81 ; RV32IZFINXZDINX-LABEL: test_floor_si32:
82 ; RV32IZFINXZDINX: # %bb.0:
83 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
84 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
85 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
86 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
87 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
88 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
89 ; RV32IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rdn
90 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
91 ; RV32IZFINXZDINX-NEXT: ret
93 ; RV64IZFINXZDINX-LABEL: test_floor_si32:
94 ; RV64IZFINXZDINX: # %bb.0:
95 ; RV64IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rdn
96 ; RV64IZFINXZDINX-NEXT: ret
97 %a = call double @llvm.floor.f64(double %x)
98 %b = fptosi double %a to i32
102 define i64 @test_floor_si64(double %x) {
103 ; RV32IFD-LABEL: test_floor_si64:
105 ; RV32IFD-NEXT: addi sp, sp, -16
106 ; RV32IFD-NEXT: .cfi_def_cfa_offset 16
107 ; RV32IFD-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
108 ; RV32IFD-NEXT: .cfi_offset ra, -4
109 ; RV32IFD-NEXT: call floor
110 ; RV32IFD-NEXT: call __fixdfdi
111 ; RV32IFD-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
112 ; RV32IFD-NEXT: addi sp, sp, 16
115 ; RV64IFD-LABEL: test_floor_si64:
117 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rdn
120 ; RV32IZFINXZDINX-LABEL: test_floor_si64:
121 ; RV32IZFINXZDINX: # %bb.0:
122 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
123 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
124 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
125 ; RV32IZFINXZDINX-NEXT: .cfi_offset ra, -4
126 ; RV32IZFINXZDINX-NEXT: call floor
127 ; RV32IZFINXZDINX-NEXT: call __fixdfdi
128 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
129 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
130 ; RV32IZFINXZDINX-NEXT: ret
132 ; RV64IZFINXZDINX-LABEL: test_floor_si64:
133 ; RV64IZFINXZDINX: # %bb.0:
134 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a0, a0, rdn
135 ; RV64IZFINXZDINX-NEXT: ret
136 %a = call double @llvm.floor.f64(double %x)
137 %b = fptosi double %a to i64
141 define zeroext i8 @test_floor_ui8(double %x) {
142 ; RV32IFD-LABEL: test_floor_ui8:
144 ; RV32IFD-NEXT: fcvt.wu.d a0, fa0, rdn
147 ; RV64IFD-LABEL: test_floor_ui8:
149 ; RV64IFD-NEXT: fcvt.lu.d a0, fa0, rdn
152 ; RV32IZFINXZDINX-LABEL: test_floor_ui8:
153 ; RV32IZFINXZDINX: # %bb.0:
154 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
155 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
156 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
157 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
158 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
159 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
160 ; RV32IZFINXZDINX-NEXT: fcvt.wu.d a0, a0, rdn
161 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
162 ; RV32IZFINXZDINX-NEXT: ret
164 ; RV64IZFINXZDINX-LABEL: test_floor_ui8:
165 ; RV64IZFINXZDINX: # %bb.0:
166 ; RV64IZFINXZDINX-NEXT: fcvt.lu.d a0, a0, rdn
167 ; RV64IZFINXZDINX-NEXT: ret
168 %a = call double @llvm.floor.f64(double %x)
169 %b = fptoui double %a to i8
173 define zeroext i16 @test_floor_ui16(double %x) {
174 ; RV32IFD-LABEL: test_floor_ui16:
176 ; RV32IFD-NEXT: fcvt.wu.d a0, fa0, rdn
179 ; RV64IFD-LABEL: test_floor_ui16:
181 ; RV64IFD-NEXT: fcvt.lu.d a0, fa0, rdn
184 ; RV32IZFINXZDINX-LABEL: test_floor_ui16:
185 ; RV32IZFINXZDINX: # %bb.0:
186 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
187 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
188 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
189 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
190 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
191 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
192 ; RV32IZFINXZDINX-NEXT: fcvt.wu.d a0, a0, rdn
193 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
194 ; RV32IZFINXZDINX-NEXT: ret
196 ; RV64IZFINXZDINX-LABEL: test_floor_ui16:
197 ; RV64IZFINXZDINX: # %bb.0:
198 ; RV64IZFINXZDINX-NEXT: fcvt.lu.d a0, a0, rdn
199 ; RV64IZFINXZDINX-NEXT: ret
200 %a = call double @llvm.floor.f64(double %x)
201 %b = fptoui double %a to i16
205 define signext i32 @test_floor_ui32(double %x) {
206 ; CHECKIFD-LABEL: test_floor_ui32:
208 ; CHECKIFD-NEXT: fcvt.wu.d a0, fa0, rdn
211 ; RV32IZFINXZDINX-LABEL: test_floor_ui32:
212 ; RV32IZFINXZDINX: # %bb.0:
213 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
214 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
215 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
216 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
217 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
218 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
219 ; RV32IZFINXZDINX-NEXT: fcvt.wu.d a0, a0, rdn
220 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
221 ; RV32IZFINXZDINX-NEXT: ret
223 ; RV64IZFINXZDINX-LABEL: test_floor_ui32:
224 ; RV64IZFINXZDINX: # %bb.0:
225 ; RV64IZFINXZDINX-NEXT: fcvt.wu.d a0, a0, rdn
226 ; RV64IZFINXZDINX-NEXT: ret
227 %a = call double @llvm.floor.f64(double %x)
228 %b = fptoui double %a to i32
232 define i64 @test_floor_ui64(double %x) {
233 ; RV32IFD-LABEL: test_floor_ui64:
235 ; RV32IFD-NEXT: addi sp, sp, -16
236 ; RV32IFD-NEXT: .cfi_def_cfa_offset 16
237 ; RV32IFD-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
238 ; RV32IFD-NEXT: .cfi_offset ra, -4
239 ; RV32IFD-NEXT: call floor
240 ; RV32IFD-NEXT: call __fixunsdfdi
241 ; RV32IFD-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
242 ; RV32IFD-NEXT: addi sp, sp, 16
245 ; RV64IFD-LABEL: test_floor_ui64:
247 ; RV64IFD-NEXT: fcvt.lu.d a0, fa0, rdn
250 ; RV32IZFINXZDINX-LABEL: test_floor_ui64:
251 ; RV32IZFINXZDINX: # %bb.0:
252 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
253 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
254 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
255 ; RV32IZFINXZDINX-NEXT: .cfi_offset ra, -4
256 ; RV32IZFINXZDINX-NEXT: call floor
257 ; RV32IZFINXZDINX-NEXT: call __fixunsdfdi
258 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
259 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
260 ; RV32IZFINXZDINX-NEXT: ret
262 ; RV64IZFINXZDINX-LABEL: test_floor_ui64:
263 ; RV64IZFINXZDINX: # %bb.0:
264 ; RV64IZFINXZDINX-NEXT: fcvt.lu.d a0, a0, rdn
265 ; RV64IZFINXZDINX-NEXT: ret
266 %a = call double @llvm.floor.f64(double %x)
267 %b = fptoui double %a to i64
271 define signext i8 @test_ceil_si8(double %x) {
272 ; RV32IFD-LABEL: test_ceil_si8:
274 ; RV32IFD-NEXT: fcvt.w.d a0, fa0, rup
277 ; RV64IFD-LABEL: test_ceil_si8:
279 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rup
282 ; RV32IZFINXZDINX-LABEL: test_ceil_si8:
283 ; RV32IZFINXZDINX: # %bb.0:
284 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
285 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
286 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
287 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
288 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
289 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
290 ; RV32IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rup
291 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
292 ; RV32IZFINXZDINX-NEXT: ret
294 ; RV64IZFINXZDINX-LABEL: test_ceil_si8:
295 ; RV64IZFINXZDINX: # %bb.0:
296 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a0, a0, rup
297 ; RV64IZFINXZDINX-NEXT: ret
298 %a = call double @llvm.ceil.f64(double %x)
299 %b = fptosi double %a to i8
303 define signext i16 @test_ceil_si16(double %x) {
304 ; RV32IFD-LABEL: test_ceil_si16:
306 ; RV32IFD-NEXT: fcvt.w.d a0, fa0, rup
309 ; RV64IFD-LABEL: test_ceil_si16:
311 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rup
314 ; RV32IZFINXZDINX-LABEL: test_ceil_si16:
315 ; RV32IZFINXZDINX: # %bb.0:
316 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
317 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
318 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
319 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
320 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
321 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
322 ; RV32IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rup
323 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
324 ; RV32IZFINXZDINX-NEXT: ret
326 ; RV64IZFINXZDINX-LABEL: test_ceil_si16:
327 ; RV64IZFINXZDINX: # %bb.0:
328 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a0, a0, rup
329 ; RV64IZFINXZDINX-NEXT: ret
330 %a = call double @llvm.ceil.f64(double %x)
331 %b = fptosi double %a to i16
335 define signext i32 @test_ceil_si32(double %x) {
336 ; CHECKIFD-LABEL: test_ceil_si32:
338 ; CHECKIFD-NEXT: fcvt.w.d a0, fa0, rup
341 ; RV32IZFINXZDINX-LABEL: test_ceil_si32:
342 ; RV32IZFINXZDINX: # %bb.0:
343 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
344 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
345 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
346 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
347 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
348 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
349 ; RV32IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rup
350 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
351 ; RV32IZFINXZDINX-NEXT: ret
353 ; RV64IZFINXZDINX-LABEL: test_ceil_si32:
354 ; RV64IZFINXZDINX: # %bb.0:
355 ; RV64IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rup
356 ; RV64IZFINXZDINX-NEXT: ret
357 %a = call double @llvm.ceil.f64(double %x)
358 %b = fptosi double %a to i32
362 define i64 @test_ceil_si64(double %x) {
363 ; RV32IFD-LABEL: test_ceil_si64:
365 ; RV32IFD-NEXT: addi sp, sp, -16
366 ; RV32IFD-NEXT: .cfi_def_cfa_offset 16
367 ; RV32IFD-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
368 ; RV32IFD-NEXT: .cfi_offset ra, -4
369 ; RV32IFD-NEXT: call ceil
370 ; RV32IFD-NEXT: call __fixdfdi
371 ; RV32IFD-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
372 ; RV32IFD-NEXT: addi sp, sp, 16
375 ; RV64IFD-LABEL: test_ceil_si64:
377 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rup
380 ; RV32IZFINXZDINX-LABEL: test_ceil_si64:
381 ; RV32IZFINXZDINX: # %bb.0:
382 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
383 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
384 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
385 ; RV32IZFINXZDINX-NEXT: .cfi_offset ra, -4
386 ; RV32IZFINXZDINX-NEXT: call ceil
387 ; RV32IZFINXZDINX-NEXT: call __fixdfdi
388 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
389 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
390 ; RV32IZFINXZDINX-NEXT: ret
392 ; RV64IZFINXZDINX-LABEL: test_ceil_si64:
393 ; RV64IZFINXZDINX: # %bb.0:
394 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a0, a0, rup
395 ; RV64IZFINXZDINX-NEXT: ret
396 %a = call double @llvm.ceil.f64(double %x)
397 %b = fptosi double %a to i64
401 define zeroext i8 @test_ceil_ui8(double %x) {
402 ; RV32IFD-LABEL: test_ceil_ui8:
404 ; RV32IFD-NEXT: fcvt.wu.d a0, fa0, rup
407 ; RV64IFD-LABEL: test_ceil_ui8:
409 ; RV64IFD-NEXT: fcvt.lu.d a0, fa0, rup
412 ; RV32IZFINXZDINX-LABEL: test_ceil_ui8:
413 ; RV32IZFINXZDINX: # %bb.0:
414 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
415 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
416 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
417 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
418 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
419 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
420 ; RV32IZFINXZDINX-NEXT: fcvt.wu.d a0, a0, rup
421 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
422 ; RV32IZFINXZDINX-NEXT: ret
424 ; RV64IZFINXZDINX-LABEL: test_ceil_ui8:
425 ; RV64IZFINXZDINX: # %bb.0:
426 ; RV64IZFINXZDINX-NEXT: fcvt.lu.d a0, a0, rup
427 ; RV64IZFINXZDINX-NEXT: ret
428 %a = call double @llvm.ceil.f64(double %x)
429 %b = fptoui double %a to i8
433 define zeroext i16 @test_ceil_ui16(double %x) {
434 ; RV32IFD-LABEL: test_ceil_ui16:
436 ; RV32IFD-NEXT: fcvt.wu.d a0, fa0, rup
439 ; RV64IFD-LABEL: test_ceil_ui16:
441 ; RV64IFD-NEXT: fcvt.lu.d a0, fa0, rup
444 ; RV32IZFINXZDINX-LABEL: test_ceil_ui16:
445 ; RV32IZFINXZDINX: # %bb.0:
446 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
447 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
448 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
449 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
450 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
451 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
452 ; RV32IZFINXZDINX-NEXT: fcvt.wu.d a0, a0, rup
453 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
454 ; RV32IZFINXZDINX-NEXT: ret
456 ; RV64IZFINXZDINX-LABEL: test_ceil_ui16:
457 ; RV64IZFINXZDINX: # %bb.0:
458 ; RV64IZFINXZDINX-NEXT: fcvt.lu.d a0, a0, rup
459 ; RV64IZFINXZDINX-NEXT: ret
460 %a = call double @llvm.ceil.f64(double %x)
461 %b = fptoui double %a to i16
465 define signext i32 @test_ceil_ui32(double %x) {
466 ; CHECKIFD-LABEL: test_ceil_ui32:
468 ; CHECKIFD-NEXT: fcvt.wu.d a0, fa0, rup
471 ; RV32IZFINXZDINX-LABEL: test_ceil_ui32:
472 ; RV32IZFINXZDINX: # %bb.0:
473 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
474 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
475 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
476 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
477 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
478 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
479 ; RV32IZFINXZDINX-NEXT: fcvt.wu.d a0, a0, rup
480 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
481 ; RV32IZFINXZDINX-NEXT: ret
483 ; RV64IZFINXZDINX-LABEL: test_ceil_ui32:
484 ; RV64IZFINXZDINX: # %bb.0:
485 ; RV64IZFINXZDINX-NEXT: fcvt.wu.d a0, a0, rup
486 ; RV64IZFINXZDINX-NEXT: ret
487 %a = call double @llvm.ceil.f64(double %x)
488 %b = fptoui double %a to i32
492 define i64 @test_ceil_ui64(double %x) {
493 ; RV32IFD-LABEL: test_ceil_ui64:
495 ; RV32IFD-NEXT: addi sp, sp, -16
496 ; RV32IFD-NEXT: .cfi_def_cfa_offset 16
497 ; RV32IFD-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
498 ; RV32IFD-NEXT: .cfi_offset ra, -4
499 ; RV32IFD-NEXT: call ceil
500 ; RV32IFD-NEXT: call __fixunsdfdi
501 ; RV32IFD-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
502 ; RV32IFD-NEXT: addi sp, sp, 16
505 ; RV64IFD-LABEL: test_ceil_ui64:
507 ; RV64IFD-NEXT: fcvt.lu.d a0, fa0, rup
510 ; RV32IZFINXZDINX-LABEL: test_ceil_ui64:
511 ; RV32IZFINXZDINX: # %bb.0:
512 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
513 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
514 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
515 ; RV32IZFINXZDINX-NEXT: .cfi_offset ra, -4
516 ; RV32IZFINXZDINX-NEXT: call ceil
517 ; RV32IZFINXZDINX-NEXT: call __fixunsdfdi
518 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
519 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
520 ; RV32IZFINXZDINX-NEXT: ret
522 ; RV64IZFINXZDINX-LABEL: test_ceil_ui64:
523 ; RV64IZFINXZDINX: # %bb.0:
524 ; RV64IZFINXZDINX-NEXT: fcvt.lu.d a0, a0, rup
525 ; RV64IZFINXZDINX-NEXT: ret
526 %a = call double @llvm.ceil.f64(double %x)
527 %b = fptoui double %a to i64
531 define signext i8 @test_trunc_si8(double %x) {
532 ; RV32IFD-LABEL: test_trunc_si8:
534 ; RV32IFD-NEXT: fcvt.w.d a0, fa0, rtz
537 ; RV64IFD-LABEL: test_trunc_si8:
539 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rtz
542 ; RV32IZFINXZDINX-LABEL: test_trunc_si8:
543 ; RV32IZFINXZDINX: # %bb.0:
544 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
545 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
546 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
547 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
548 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
549 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
550 ; RV32IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rtz
551 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
552 ; RV32IZFINXZDINX-NEXT: ret
554 ; RV64IZFINXZDINX-LABEL: test_trunc_si8:
555 ; RV64IZFINXZDINX: # %bb.0:
556 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a0, a0, rtz
557 ; RV64IZFINXZDINX-NEXT: ret
558 %a = call double @llvm.trunc.f64(double %x)
559 %b = fptosi double %a to i8
563 define signext i16 @test_trunc_si16(double %x) {
564 ; RV32IFD-LABEL: test_trunc_si16:
566 ; RV32IFD-NEXT: fcvt.w.d a0, fa0, rtz
569 ; RV64IFD-LABEL: test_trunc_si16:
571 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rtz
574 ; RV32IZFINXZDINX-LABEL: test_trunc_si16:
575 ; RV32IZFINXZDINX: # %bb.0:
576 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
577 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
578 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
579 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
580 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
581 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
582 ; RV32IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rtz
583 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
584 ; RV32IZFINXZDINX-NEXT: ret
586 ; RV64IZFINXZDINX-LABEL: test_trunc_si16:
587 ; RV64IZFINXZDINX: # %bb.0:
588 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a0, a0, rtz
589 ; RV64IZFINXZDINX-NEXT: ret
590 %a = call double @llvm.trunc.f64(double %x)
591 %b = fptosi double %a to i16
595 define signext i32 @test_trunc_si32(double %x) {
596 ; CHECKIFD-LABEL: test_trunc_si32:
598 ; CHECKIFD-NEXT: fcvt.w.d a0, fa0, rtz
601 ; RV32IZFINXZDINX-LABEL: test_trunc_si32:
602 ; RV32IZFINXZDINX: # %bb.0:
603 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
604 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
605 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
606 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
607 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
608 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
609 ; RV32IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rtz
610 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
611 ; RV32IZFINXZDINX-NEXT: ret
613 ; RV64IZFINXZDINX-LABEL: test_trunc_si32:
614 ; RV64IZFINXZDINX: # %bb.0:
615 ; RV64IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rtz
616 ; RV64IZFINXZDINX-NEXT: ret
617 %a = call double @llvm.trunc.f64(double %x)
618 %b = fptosi double %a to i32
622 define i64 @test_trunc_si64(double %x) {
623 ; RV32IFD-LABEL: test_trunc_si64:
625 ; RV32IFD-NEXT: addi sp, sp, -16
626 ; RV32IFD-NEXT: .cfi_def_cfa_offset 16
627 ; RV32IFD-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
628 ; RV32IFD-NEXT: .cfi_offset ra, -4
629 ; RV32IFD-NEXT: call trunc
630 ; RV32IFD-NEXT: call __fixdfdi
631 ; RV32IFD-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
632 ; RV32IFD-NEXT: addi sp, sp, 16
635 ; RV64IFD-LABEL: test_trunc_si64:
637 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rtz
640 ; RV32IZFINXZDINX-LABEL: test_trunc_si64:
641 ; RV32IZFINXZDINX: # %bb.0:
642 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
643 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
644 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
645 ; RV32IZFINXZDINX-NEXT: .cfi_offset ra, -4
646 ; RV32IZFINXZDINX-NEXT: call trunc
647 ; RV32IZFINXZDINX-NEXT: call __fixdfdi
648 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
649 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
650 ; RV32IZFINXZDINX-NEXT: ret
652 ; RV64IZFINXZDINX-LABEL: test_trunc_si64:
653 ; RV64IZFINXZDINX: # %bb.0:
654 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a0, a0, rtz
655 ; RV64IZFINXZDINX-NEXT: ret
656 %a = call double @llvm.trunc.f64(double %x)
657 %b = fptosi double %a to i64
661 define zeroext i8 @test_trunc_ui8(double %x) {
662 ; RV32IFD-LABEL: test_trunc_ui8:
664 ; RV32IFD-NEXT: fcvt.wu.d a0, fa0, rtz
667 ; RV64IFD-LABEL: test_trunc_ui8:
669 ; RV64IFD-NEXT: fcvt.lu.d a0, fa0, rtz
672 ; RV32IZFINXZDINX-LABEL: test_trunc_ui8:
673 ; RV32IZFINXZDINX: # %bb.0:
674 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
675 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
676 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
677 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
678 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
679 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
680 ; RV32IZFINXZDINX-NEXT: fcvt.wu.d a0, a0, rtz
681 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
682 ; RV32IZFINXZDINX-NEXT: ret
684 ; RV64IZFINXZDINX-LABEL: test_trunc_ui8:
685 ; RV64IZFINXZDINX: # %bb.0:
686 ; RV64IZFINXZDINX-NEXT: fcvt.lu.d a0, a0, rtz
687 ; RV64IZFINXZDINX-NEXT: ret
688 %a = call double @llvm.trunc.f64(double %x)
689 %b = fptoui double %a to i8
693 define zeroext i16 @test_trunc_ui16(double %x) {
694 ; RV32IFD-LABEL: test_trunc_ui16:
696 ; RV32IFD-NEXT: fcvt.wu.d a0, fa0, rtz
699 ; RV64IFD-LABEL: test_trunc_ui16:
701 ; RV64IFD-NEXT: fcvt.lu.d a0, fa0, rtz
704 ; RV32IZFINXZDINX-LABEL: test_trunc_ui16:
705 ; RV32IZFINXZDINX: # %bb.0:
706 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
707 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
708 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
709 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
710 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
711 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
712 ; RV32IZFINXZDINX-NEXT: fcvt.wu.d a0, a0, rtz
713 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
714 ; RV32IZFINXZDINX-NEXT: ret
716 ; RV64IZFINXZDINX-LABEL: test_trunc_ui16:
717 ; RV64IZFINXZDINX: # %bb.0:
718 ; RV64IZFINXZDINX-NEXT: fcvt.lu.d a0, a0, rtz
719 ; RV64IZFINXZDINX-NEXT: ret
720 %a = call double @llvm.trunc.f64(double %x)
721 %b = fptoui double %a to i16
725 define signext i32 @test_trunc_ui32(double %x) {
726 ; CHECKIFD-LABEL: test_trunc_ui32:
728 ; CHECKIFD-NEXT: fcvt.wu.d a0, fa0, rtz
731 ; RV32IZFINXZDINX-LABEL: test_trunc_ui32:
732 ; RV32IZFINXZDINX: # %bb.0:
733 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
734 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
735 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
736 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
737 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
738 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
739 ; RV32IZFINXZDINX-NEXT: fcvt.wu.d a0, a0, rtz
740 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
741 ; RV32IZFINXZDINX-NEXT: ret
743 ; RV64IZFINXZDINX-LABEL: test_trunc_ui32:
744 ; RV64IZFINXZDINX: # %bb.0:
745 ; RV64IZFINXZDINX-NEXT: fcvt.wu.d a0, a0, rtz
746 ; RV64IZFINXZDINX-NEXT: ret
747 %a = call double @llvm.trunc.f64(double %x)
748 %b = fptoui double %a to i32
752 define i64 @test_trunc_ui64(double %x) {
753 ; RV32IFD-LABEL: test_trunc_ui64:
755 ; RV32IFD-NEXT: addi sp, sp, -16
756 ; RV32IFD-NEXT: .cfi_def_cfa_offset 16
757 ; RV32IFD-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
758 ; RV32IFD-NEXT: .cfi_offset ra, -4
759 ; RV32IFD-NEXT: call trunc
760 ; RV32IFD-NEXT: call __fixunsdfdi
761 ; RV32IFD-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
762 ; RV32IFD-NEXT: addi sp, sp, 16
765 ; RV64IFD-LABEL: test_trunc_ui64:
767 ; RV64IFD-NEXT: fcvt.lu.d a0, fa0, rtz
770 ; RV32IZFINXZDINX-LABEL: test_trunc_ui64:
771 ; RV32IZFINXZDINX: # %bb.0:
772 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
773 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
774 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
775 ; RV32IZFINXZDINX-NEXT: .cfi_offset ra, -4
776 ; RV32IZFINXZDINX-NEXT: call trunc
777 ; RV32IZFINXZDINX-NEXT: call __fixunsdfdi
778 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
779 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
780 ; RV32IZFINXZDINX-NEXT: ret
782 ; RV64IZFINXZDINX-LABEL: test_trunc_ui64:
783 ; RV64IZFINXZDINX: # %bb.0:
784 ; RV64IZFINXZDINX-NEXT: fcvt.lu.d a0, a0, rtz
785 ; RV64IZFINXZDINX-NEXT: ret
786 %a = call double @llvm.trunc.f64(double %x)
787 %b = fptoui double %a to i64
791 define signext i8 @test_round_si8(double %x) {
792 ; RV32IFD-LABEL: test_round_si8:
794 ; RV32IFD-NEXT: fcvt.w.d a0, fa0, rmm
797 ; RV64IFD-LABEL: test_round_si8:
799 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rmm
802 ; RV32IZFINXZDINX-LABEL: test_round_si8:
803 ; RV32IZFINXZDINX: # %bb.0:
804 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
805 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
806 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
807 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
808 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
809 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
810 ; RV32IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rmm
811 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
812 ; RV32IZFINXZDINX-NEXT: ret
814 ; RV64IZFINXZDINX-LABEL: test_round_si8:
815 ; RV64IZFINXZDINX: # %bb.0:
816 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a0, a0, rmm
817 ; RV64IZFINXZDINX-NEXT: ret
818 %a = call double @llvm.round.f64(double %x)
819 %b = fptosi double %a to i8
823 define signext i16 @test_round_si16(double %x) {
824 ; RV32IFD-LABEL: test_round_si16:
826 ; RV32IFD-NEXT: fcvt.w.d a0, fa0, rmm
829 ; RV64IFD-LABEL: test_round_si16:
831 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rmm
834 ; RV32IZFINXZDINX-LABEL: test_round_si16:
835 ; RV32IZFINXZDINX: # %bb.0:
836 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
837 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
838 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
839 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
840 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
841 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
842 ; RV32IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rmm
843 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
844 ; RV32IZFINXZDINX-NEXT: ret
846 ; RV64IZFINXZDINX-LABEL: test_round_si16:
847 ; RV64IZFINXZDINX: # %bb.0:
848 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a0, a0, rmm
849 ; RV64IZFINXZDINX-NEXT: ret
850 %a = call double @llvm.round.f64(double %x)
851 %b = fptosi double %a to i16
855 define signext i32 @test_round_si32(double %x) {
856 ; CHECKIFD-LABEL: test_round_si32:
858 ; CHECKIFD-NEXT: fcvt.w.d a0, fa0, rmm
861 ; RV32IZFINXZDINX-LABEL: test_round_si32:
862 ; RV32IZFINXZDINX: # %bb.0:
863 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
864 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
865 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
866 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
867 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
868 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
869 ; RV32IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rmm
870 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
871 ; RV32IZFINXZDINX-NEXT: ret
873 ; RV64IZFINXZDINX-LABEL: test_round_si32:
874 ; RV64IZFINXZDINX: # %bb.0:
875 ; RV64IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rmm
876 ; RV64IZFINXZDINX-NEXT: ret
877 %a = call double @llvm.round.f64(double %x)
878 %b = fptosi double %a to i32
882 define i64 @test_round_si64(double %x) {
883 ; RV32IFD-LABEL: test_round_si64:
885 ; RV32IFD-NEXT: addi sp, sp, -16
886 ; RV32IFD-NEXT: .cfi_def_cfa_offset 16
887 ; RV32IFD-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
888 ; RV32IFD-NEXT: .cfi_offset ra, -4
889 ; RV32IFD-NEXT: call round
890 ; RV32IFD-NEXT: call __fixdfdi
891 ; RV32IFD-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
892 ; RV32IFD-NEXT: addi sp, sp, 16
895 ; RV64IFD-LABEL: test_round_si64:
897 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rmm
900 ; RV32IZFINXZDINX-LABEL: test_round_si64:
901 ; RV32IZFINXZDINX: # %bb.0:
902 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
903 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
904 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
905 ; RV32IZFINXZDINX-NEXT: .cfi_offset ra, -4
906 ; RV32IZFINXZDINX-NEXT: call round
907 ; RV32IZFINXZDINX-NEXT: call __fixdfdi
908 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
909 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
910 ; RV32IZFINXZDINX-NEXT: ret
912 ; RV64IZFINXZDINX-LABEL: test_round_si64:
913 ; RV64IZFINXZDINX: # %bb.0:
914 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a0, a0, rmm
915 ; RV64IZFINXZDINX-NEXT: ret
916 %a = call double @llvm.round.f64(double %x)
917 %b = fptosi double %a to i64
921 define zeroext i8 @test_round_ui8(double %x) {
922 ; RV32IFD-LABEL: test_round_ui8:
924 ; RV32IFD-NEXT: fcvt.wu.d a0, fa0, rmm
927 ; RV64IFD-LABEL: test_round_ui8:
929 ; RV64IFD-NEXT: fcvt.lu.d a0, fa0, rmm
932 ; RV32IZFINXZDINX-LABEL: test_round_ui8:
933 ; RV32IZFINXZDINX: # %bb.0:
934 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
935 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
936 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
937 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
938 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
939 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
940 ; RV32IZFINXZDINX-NEXT: fcvt.wu.d a0, a0, rmm
941 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
942 ; RV32IZFINXZDINX-NEXT: ret
944 ; RV64IZFINXZDINX-LABEL: test_round_ui8:
945 ; RV64IZFINXZDINX: # %bb.0:
946 ; RV64IZFINXZDINX-NEXT: fcvt.lu.d a0, a0, rmm
947 ; RV64IZFINXZDINX-NEXT: ret
948 %a = call double @llvm.round.f64(double %x)
949 %b = fptoui double %a to i8
953 define zeroext i16 @test_round_ui16(double %x) {
954 ; RV32IFD-LABEL: test_round_ui16:
956 ; RV32IFD-NEXT: fcvt.wu.d a0, fa0, rmm
959 ; RV64IFD-LABEL: test_round_ui16:
961 ; RV64IFD-NEXT: fcvt.lu.d a0, fa0, rmm
964 ; RV32IZFINXZDINX-LABEL: test_round_ui16:
965 ; RV32IZFINXZDINX: # %bb.0:
966 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
967 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
968 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
969 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
970 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
971 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
972 ; RV32IZFINXZDINX-NEXT: fcvt.wu.d a0, a0, rmm
973 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
974 ; RV32IZFINXZDINX-NEXT: ret
976 ; RV64IZFINXZDINX-LABEL: test_round_ui16:
977 ; RV64IZFINXZDINX: # %bb.0:
978 ; RV64IZFINXZDINX-NEXT: fcvt.lu.d a0, a0, rmm
979 ; RV64IZFINXZDINX-NEXT: ret
980 %a = call double @llvm.round.f64(double %x)
981 %b = fptoui double %a to i16
985 define signext i32 @test_round_ui32(double %x) {
986 ; CHECKIFD-LABEL: test_round_ui32:
988 ; CHECKIFD-NEXT: fcvt.wu.d a0, fa0, rmm
991 ; RV32IZFINXZDINX-LABEL: test_round_ui32:
992 ; RV32IZFINXZDINX: # %bb.0:
993 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
994 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
995 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
996 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
997 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
998 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
999 ; RV32IZFINXZDINX-NEXT: fcvt.wu.d a0, a0, rmm
1000 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1001 ; RV32IZFINXZDINX-NEXT: ret
1003 ; RV64IZFINXZDINX-LABEL: test_round_ui32:
1004 ; RV64IZFINXZDINX: # %bb.0:
1005 ; RV64IZFINXZDINX-NEXT: fcvt.wu.d a0, a0, rmm
1006 ; RV64IZFINXZDINX-NEXT: ret
1007 %a = call double @llvm.round.f64(double %x)
1008 %b = fptoui double %a to i32
1012 define i64 @test_round_ui64(double %x) {
1013 ; RV32IFD-LABEL: test_round_ui64:
1015 ; RV32IFD-NEXT: addi sp, sp, -16
1016 ; RV32IFD-NEXT: .cfi_def_cfa_offset 16
1017 ; RV32IFD-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1018 ; RV32IFD-NEXT: .cfi_offset ra, -4
1019 ; RV32IFD-NEXT: call round
1020 ; RV32IFD-NEXT: call __fixunsdfdi
1021 ; RV32IFD-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1022 ; RV32IFD-NEXT: addi sp, sp, 16
1025 ; RV64IFD-LABEL: test_round_ui64:
1027 ; RV64IFD-NEXT: fcvt.lu.d a0, fa0, rmm
1030 ; RV32IZFINXZDINX-LABEL: test_round_ui64:
1031 ; RV32IZFINXZDINX: # %bb.0:
1032 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1033 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
1034 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1035 ; RV32IZFINXZDINX-NEXT: .cfi_offset ra, -4
1036 ; RV32IZFINXZDINX-NEXT: call round
1037 ; RV32IZFINXZDINX-NEXT: call __fixunsdfdi
1038 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1039 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1040 ; RV32IZFINXZDINX-NEXT: ret
1042 ; RV64IZFINXZDINX-LABEL: test_round_ui64:
1043 ; RV64IZFINXZDINX: # %bb.0:
1044 ; RV64IZFINXZDINX-NEXT: fcvt.lu.d a0, a0, rmm
1045 ; RV64IZFINXZDINX-NEXT: ret
1046 %a = call double @llvm.round.f64(double %x)
1047 %b = fptoui double %a to i64
1051 define signext i8 @test_roundeven_si8(double %x) {
1052 ; RV32IFD-LABEL: test_roundeven_si8:
1054 ; RV32IFD-NEXT: fcvt.w.d a0, fa0, rne
1057 ; RV64IFD-LABEL: test_roundeven_si8:
1059 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rne
1062 ; RV32IZFINXZDINX-LABEL: test_roundeven_si8:
1063 ; RV32IZFINXZDINX: # %bb.0:
1064 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1065 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
1066 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
1067 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
1068 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
1069 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
1070 ; RV32IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rne
1071 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1072 ; RV32IZFINXZDINX-NEXT: ret
1074 ; RV64IZFINXZDINX-LABEL: test_roundeven_si8:
1075 ; RV64IZFINXZDINX: # %bb.0:
1076 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a0, a0, rne
1077 ; RV64IZFINXZDINX-NEXT: ret
1078 %a = call double @llvm.roundeven.f64(double %x)
1079 %b = fptosi double %a to i8
1083 define signext i16 @test_roundeven_si16(double %x) {
1084 ; RV32IFD-LABEL: test_roundeven_si16:
1086 ; RV32IFD-NEXT: fcvt.w.d a0, fa0, rne
1089 ; RV64IFD-LABEL: test_roundeven_si16:
1091 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rne
1094 ; RV32IZFINXZDINX-LABEL: test_roundeven_si16:
1095 ; RV32IZFINXZDINX: # %bb.0:
1096 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1097 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
1098 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
1099 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
1100 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
1101 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
1102 ; RV32IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rne
1103 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1104 ; RV32IZFINXZDINX-NEXT: ret
1106 ; RV64IZFINXZDINX-LABEL: test_roundeven_si16:
1107 ; RV64IZFINXZDINX: # %bb.0:
1108 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a0, a0, rne
1109 ; RV64IZFINXZDINX-NEXT: ret
1110 %a = call double @llvm.roundeven.f64(double %x)
1111 %b = fptosi double %a to i16
1115 define signext i32 @test_roundeven_si32(double %x) {
1116 ; CHECKIFD-LABEL: test_roundeven_si32:
1117 ; CHECKIFD: # %bb.0:
1118 ; CHECKIFD-NEXT: fcvt.w.d a0, fa0, rne
1119 ; CHECKIFD-NEXT: ret
1121 ; RV32IZFINXZDINX-LABEL: test_roundeven_si32:
1122 ; RV32IZFINXZDINX: # %bb.0:
1123 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1124 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
1125 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
1126 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
1127 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
1128 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
1129 ; RV32IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rne
1130 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1131 ; RV32IZFINXZDINX-NEXT: ret
1133 ; RV64IZFINXZDINX-LABEL: test_roundeven_si32:
1134 ; RV64IZFINXZDINX: # %bb.0:
1135 ; RV64IZFINXZDINX-NEXT: fcvt.w.d a0, a0, rne
1136 ; RV64IZFINXZDINX-NEXT: ret
1137 %a = call double @llvm.roundeven.f64(double %x)
1138 %b = fptosi double %a to i32
1142 define i64 @test_roundeven_si64(double %x) {
1143 ; RV32IFD-LABEL: test_roundeven_si64:
1145 ; RV32IFD-NEXT: addi sp, sp, -16
1146 ; RV32IFD-NEXT: .cfi_def_cfa_offset 16
1147 ; RV32IFD-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1148 ; RV32IFD-NEXT: .cfi_offset ra, -4
1149 ; RV32IFD-NEXT: call roundeven
1150 ; RV32IFD-NEXT: call __fixdfdi
1151 ; RV32IFD-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1152 ; RV32IFD-NEXT: addi sp, sp, 16
1155 ; RV64IFD-LABEL: test_roundeven_si64:
1157 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rne
1160 ; RV32IZFINXZDINX-LABEL: test_roundeven_si64:
1161 ; RV32IZFINXZDINX: # %bb.0:
1162 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1163 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
1164 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1165 ; RV32IZFINXZDINX-NEXT: .cfi_offset ra, -4
1166 ; RV32IZFINXZDINX-NEXT: call roundeven
1167 ; RV32IZFINXZDINX-NEXT: call __fixdfdi
1168 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1169 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1170 ; RV32IZFINXZDINX-NEXT: ret
1172 ; RV64IZFINXZDINX-LABEL: test_roundeven_si64:
1173 ; RV64IZFINXZDINX: # %bb.0:
1174 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a0, a0, rne
1175 ; RV64IZFINXZDINX-NEXT: ret
1176 %a = call double @llvm.roundeven.f64(double %x)
1177 %b = fptosi double %a to i64
1181 define zeroext i8 @test_roundeven_ui8(double %x) {
1182 ; RV32IFD-LABEL: test_roundeven_ui8:
1184 ; RV32IFD-NEXT: fcvt.wu.d a0, fa0, rne
1187 ; RV64IFD-LABEL: test_roundeven_ui8:
1189 ; RV64IFD-NEXT: fcvt.lu.d a0, fa0, rne
1192 ; RV32IZFINXZDINX-LABEL: test_roundeven_ui8:
1193 ; RV32IZFINXZDINX: # %bb.0:
1194 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1195 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
1196 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
1197 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
1198 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
1199 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
1200 ; RV32IZFINXZDINX-NEXT: fcvt.wu.d a0, a0, rne
1201 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1202 ; RV32IZFINXZDINX-NEXT: ret
1204 ; RV64IZFINXZDINX-LABEL: test_roundeven_ui8:
1205 ; RV64IZFINXZDINX: # %bb.0:
1206 ; RV64IZFINXZDINX-NEXT: fcvt.lu.d a0, a0, rne
1207 ; RV64IZFINXZDINX-NEXT: ret
1208 %a = call double @llvm.roundeven.f64(double %x)
1209 %b = fptoui double %a to i8
1213 define zeroext i16 @test_roundeven_ui16(double %x) {
1214 ; RV32IFD-LABEL: test_roundeven_ui16:
1216 ; RV32IFD-NEXT: fcvt.wu.d a0, fa0, rne
1219 ; RV64IFD-LABEL: test_roundeven_ui16:
1221 ; RV64IFD-NEXT: fcvt.lu.d a0, fa0, rne
1224 ; RV32IZFINXZDINX-LABEL: test_roundeven_ui16:
1225 ; RV32IZFINXZDINX: # %bb.0:
1226 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1227 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
1228 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
1229 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
1230 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
1231 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
1232 ; RV32IZFINXZDINX-NEXT: fcvt.wu.d a0, a0, rne
1233 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1234 ; RV32IZFINXZDINX-NEXT: ret
1236 ; RV64IZFINXZDINX-LABEL: test_roundeven_ui16:
1237 ; RV64IZFINXZDINX: # %bb.0:
1238 ; RV64IZFINXZDINX-NEXT: fcvt.lu.d a0, a0, rne
1239 ; RV64IZFINXZDINX-NEXT: ret
1240 %a = call double @llvm.roundeven.f64(double %x)
1241 %b = fptoui double %a to i16
1245 define signext i32 @test_roundeven_ui32(double %x) {
1246 ; CHECKIFD-LABEL: test_roundeven_ui32:
1247 ; CHECKIFD: # %bb.0:
1248 ; CHECKIFD-NEXT: fcvt.wu.d a0, fa0, rne
1249 ; CHECKIFD-NEXT: ret
1251 ; RV32IZFINXZDINX-LABEL: test_roundeven_ui32:
1252 ; RV32IZFINXZDINX: # %bb.0:
1253 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1254 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
1255 ; RV32IZFINXZDINX-NEXT: sw a0, 8(sp)
1256 ; RV32IZFINXZDINX-NEXT: sw a1, 12(sp)
1257 ; RV32IZFINXZDINX-NEXT: lw a0, 8(sp)
1258 ; RV32IZFINXZDINX-NEXT: lw a1, 12(sp)
1259 ; RV32IZFINXZDINX-NEXT: fcvt.wu.d a0, a0, rne
1260 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1261 ; RV32IZFINXZDINX-NEXT: ret
1263 ; RV64IZFINXZDINX-LABEL: test_roundeven_ui32:
1264 ; RV64IZFINXZDINX: # %bb.0:
1265 ; RV64IZFINXZDINX-NEXT: fcvt.wu.d a0, a0, rne
1266 ; RV64IZFINXZDINX-NEXT: ret
1267 %a = call double @llvm.roundeven.f64(double %x)
1268 %b = fptoui double %a to i32
1272 define i64 @test_roundeven_ui64(double %x) {
1273 ; RV32IFD-LABEL: test_roundeven_ui64:
1275 ; RV32IFD-NEXT: addi sp, sp, -16
1276 ; RV32IFD-NEXT: .cfi_def_cfa_offset 16
1277 ; RV32IFD-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1278 ; RV32IFD-NEXT: .cfi_offset ra, -4
1279 ; RV32IFD-NEXT: call roundeven
1280 ; RV32IFD-NEXT: call __fixunsdfdi
1281 ; RV32IFD-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1282 ; RV32IFD-NEXT: addi sp, sp, 16
1285 ; RV64IFD-LABEL: test_roundeven_ui64:
1287 ; RV64IFD-NEXT: fcvt.lu.d a0, fa0, rne
1290 ; RV32IZFINXZDINX-LABEL: test_roundeven_ui64:
1291 ; RV32IZFINXZDINX: # %bb.0:
1292 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1293 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
1294 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1295 ; RV32IZFINXZDINX-NEXT: .cfi_offset ra, -4
1296 ; RV32IZFINXZDINX-NEXT: call roundeven
1297 ; RV32IZFINXZDINX-NEXT: call __fixunsdfdi
1298 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1299 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1300 ; RV32IZFINXZDINX-NEXT: ret
1302 ; RV64IZFINXZDINX-LABEL: test_roundeven_ui64:
1303 ; RV64IZFINXZDINX: # %bb.0:
1304 ; RV64IZFINXZDINX-NEXT: fcvt.lu.d a0, a0, rne
1305 ; RV64IZFINXZDINX-NEXT: ret
1306 %a = call double @llvm.roundeven.f64(double %x)
1307 %b = fptoui double %a to i64
1311 define double @test_floor_double(double %x) {
1312 ; RV32IFD-LABEL: test_floor_double:
1314 ; RV32IFD-NEXT: tail floor
1316 ; RV64IFD-LABEL: test_floor_double:
1318 ; RV64IFD-NEXT: lui a0, %hi(.LCPI40_0)
1319 ; RV64IFD-NEXT: fld fa5, %lo(.LCPI40_0)(a0)
1320 ; RV64IFD-NEXT: fabs.d fa4, fa0
1321 ; RV64IFD-NEXT: flt.d a0, fa4, fa5
1322 ; RV64IFD-NEXT: beqz a0, .LBB40_2
1323 ; RV64IFD-NEXT: # %bb.1:
1324 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rdn
1325 ; RV64IFD-NEXT: fcvt.d.l fa5, a0, rdn
1326 ; RV64IFD-NEXT: fsgnj.d fa0, fa5, fa0
1327 ; RV64IFD-NEXT: .LBB40_2:
1330 ; RV32IZFINXZDINX-LABEL: test_floor_double:
1331 ; RV32IZFINXZDINX: # %bb.0:
1332 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1333 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
1334 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1335 ; RV32IZFINXZDINX-NEXT: .cfi_offset ra, -4
1336 ; RV32IZFINXZDINX-NEXT: call floor
1337 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1338 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1339 ; RV32IZFINXZDINX-NEXT: ret
1341 ; RV64IZFINXZDINX-LABEL: test_floor_double:
1342 ; RV64IZFINXZDINX: # %bb.0:
1343 ; RV64IZFINXZDINX-NEXT: lui a1, %hi(.LCPI40_0)
1344 ; RV64IZFINXZDINX-NEXT: ld a1, %lo(.LCPI40_0)(a1)
1345 ; RV64IZFINXZDINX-NEXT: fabs.d a2, a0
1346 ; RV64IZFINXZDINX-NEXT: flt.d a1, a2, a1
1347 ; RV64IZFINXZDINX-NEXT: beqz a1, .LBB40_2
1348 ; RV64IZFINXZDINX-NEXT: # %bb.1:
1349 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a1, a0, rdn
1350 ; RV64IZFINXZDINX-NEXT: fcvt.d.l a1, a1, rdn
1351 ; RV64IZFINXZDINX-NEXT: fsgnj.d a0, a1, a0
1352 ; RV64IZFINXZDINX-NEXT: .LBB40_2:
1353 ; RV64IZFINXZDINX-NEXT: ret
1354 %a = call double @llvm.floor.f64(double %x)
1358 define double @test_ceil_double(double %x) {
1359 ; RV32IFD-LABEL: test_ceil_double:
1361 ; RV32IFD-NEXT: tail ceil
1363 ; RV64IFD-LABEL: test_ceil_double:
1365 ; RV64IFD-NEXT: lui a0, %hi(.LCPI41_0)
1366 ; RV64IFD-NEXT: fld fa5, %lo(.LCPI41_0)(a0)
1367 ; RV64IFD-NEXT: fabs.d fa4, fa0
1368 ; RV64IFD-NEXT: flt.d a0, fa4, fa5
1369 ; RV64IFD-NEXT: beqz a0, .LBB41_2
1370 ; RV64IFD-NEXT: # %bb.1:
1371 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rup
1372 ; RV64IFD-NEXT: fcvt.d.l fa5, a0, rup
1373 ; RV64IFD-NEXT: fsgnj.d fa0, fa5, fa0
1374 ; RV64IFD-NEXT: .LBB41_2:
1377 ; RV32IZFINXZDINX-LABEL: test_ceil_double:
1378 ; RV32IZFINXZDINX: # %bb.0:
1379 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1380 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
1381 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1382 ; RV32IZFINXZDINX-NEXT: .cfi_offset ra, -4
1383 ; RV32IZFINXZDINX-NEXT: call ceil
1384 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1385 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1386 ; RV32IZFINXZDINX-NEXT: ret
1388 ; RV64IZFINXZDINX-LABEL: test_ceil_double:
1389 ; RV64IZFINXZDINX: # %bb.0:
1390 ; RV64IZFINXZDINX-NEXT: lui a1, %hi(.LCPI41_0)
1391 ; RV64IZFINXZDINX-NEXT: ld a1, %lo(.LCPI41_0)(a1)
1392 ; RV64IZFINXZDINX-NEXT: fabs.d a2, a0
1393 ; RV64IZFINXZDINX-NEXT: flt.d a1, a2, a1
1394 ; RV64IZFINXZDINX-NEXT: beqz a1, .LBB41_2
1395 ; RV64IZFINXZDINX-NEXT: # %bb.1:
1396 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a1, a0, rup
1397 ; RV64IZFINXZDINX-NEXT: fcvt.d.l a1, a1, rup
1398 ; RV64IZFINXZDINX-NEXT: fsgnj.d a0, a1, a0
1399 ; RV64IZFINXZDINX-NEXT: .LBB41_2:
1400 ; RV64IZFINXZDINX-NEXT: ret
1401 %a = call double @llvm.ceil.f64(double %x)
1405 define double @test_trunc_double(double %x) {
1406 ; RV32IFD-LABEL: test_trunc_double:
1408 ; RV32IFD-NEXT: tail trunc
1410 ; RV64IFD-LABEL: test_trunc_double:
1412 ; RV64IFD-NEXT: lui a0, %hi(.LCPI42_0)
1413 ; RV64IFD-NEXT: fld fa5, %lo(.LCPI42_0)(a0)
1414 ; RV64IFD-NEXT: fabs.d fa4, fa0
1415 ; RV64IFD-NEXT: flt.d a0, fa4, fa5
1416 ; RV64IFD-NEXT: beqz a0, .LBB42_2
1417 ; RV64IFD-NEXT: # %bb.1:
1418 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rtz
1419 ; RV64IFD-NEXT: fcvt.d.l fa5, a0, rtz
1420 ; RV64IFD-NEXT: fsgnj.d fa0, fa5, fa0
1421 ; RV64IFD-NEXT: .LBB42_2:
1424 ; RV32IZFINXZDINX-LABEL: test_trunc_double:
1425 ; RV32IZFINXZDINX: # %bb.0:
1426 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1427 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
1428 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1429 ; RV32IZFINXZDINX-NEXT: .cfi_offset ra, -4
1430 ; RV32IZFINXZDINX-NEXT: call trunc
1431 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1432 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1433 ; RV32IZFINXZDINX-NEXT: ret
1435 ; RV64IZFINXZDINX-LABEL: test_trunc_double:
1436 ; RV64IZFINXZDINX: # %bb.0:
1437 ; RV64IZFINXZDINX-NEXT: lui a1, %hi(.LCPI42_0)
1438 ; RV64IZFINXZDINX-NEXT: ld a1, %lo(.LCPI42_0)(a1)
1439 ; RV64IZFINXZDINX-NEXT: fabs.d a2, a0
1440 ; RV64IZFINXZDINX-NEXT: flt.d a1, a2, a1
1441 ; RV64IZFINXZDINX-NEXT: beqz a1, .LBB42_2
1442 ; RV64IZFINXZDINX-NEXT: # %bb.1:
1443 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a1, a0, rtz
1444 ; RV64IZFINXZDINX-NEXT: fcvt.d.l a1, a1, rtz
1445 ; RV64IZFINXZDINX-NEXT: fsgnj.d a0, a1, a0
1446 ; RV64IZFINXZDINX-NEXT: .LBB42_2:
1447 ; RV64IZFINXZDINX-NEXT: ret
1448 %a = call double @llvm.trunc.f64(double %x)
1452 define double @test_round_double(double %x) {
1453 ; RV32IFD-LABEL: test_round_double:
1455 ; RV32IFD-NEXT: tail round
1457 ; RV64IFD-LABEL: test_round_double:
1459 ; RV64IFD-NEXT: lui a0, %hi(.LCPI43_0)
1460 ; RV64IFD-NEXT: fld fa5, %lo(.LCPI43_0)(a0)
1461 ; RV64IFD-NEXT: fabs.d fa4, fa0
1462 ; RV64IFD-NEXT: flt.d a0, fa4, fa5
1463 ; RV64IFD-NEXT: beqz a0, .LBB43_2
1464 ; RV64IFD-NEXT: # %bb.1:
1465 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rmm
1466 ; RV64IFD-NEXT: fcvt.d.l fa5, a0, rmm
1467 ; RV64IFD-NEXT: fsgnj.d fa0, fa5, fa0
1468 ; RV64IFD-NEXT: .LBB43_2:
1471 ; RV32IZFINXZDINX-LABEL: test_round_double:
1472 ; RV32IZFINXZDINX: # %bb.0:
1473 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1474 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
1475 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1476 ; RV32IZFINXZDINX-NEXT: .cfi_offset ra, -4
1477 ; RV32IZFINXZDINX-NEXT: call round
1478 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1479 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1480 ; RV32IZFINXZDINX-NEXT: ret
1482 ; RV64IZFINXZDINX-LABEL: test_round_double:
1483 ; RV64IZFINXZDINX: # %bb.0:
1484 ; RV64IZFINXZDINX-NEXT: lui a1, %hi(.LCPI43_0)
1485 ; RV64IZFINXZDINX-NEXT: ld a1, %lo(.LCPI43_0)(a1)
1486 ; RV64IZFINXZDINX-NEXT: fabs.d a2, a0
1487 ; RV64IZFINXZDINX-NEXT: flt.d a1, a2, a1
1488 ; RV64IZFINXZDINX-NEXT: beqz a1, .LBB43_2
1489 ; RV64IZFINXZDINX-NEXT: # %bb.1:
1490 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a1, a0, rmm
1491 ; RV64IZFINXZDINX-NEXT: fcvt.d.l a1, a1, rmm
1492 ; RV64IZFINXZDINX-NEXT: fsgnj.d a0, a1, a0
1493 ; RV64IZFINXZDINX-NEXT: .LBB43_2:
1494 ; RV64IZFINXZDINX-NEXT: ret
1495 %a = call double @llvm.round.f64(double %x)
1499 define double @test_roundeven_double(double %x) {
1500 ; RV32IFD-LABEL: test_roundeven_double:
1502 ; RV32IFD-NEXT: tail roundeven
1504 ; RV64IFD-LABEL: test_roundeven_double:
1506 ; RV64IFD-NEXT: lui a0, %hi(.LCPI44_0)
1507 ; RV64IFD-NEXT: fld fa5, %lo(.LCPI44_0)(a0)
1508 ; RV64IFD-NEXT: fabs.d fa4, fa0
1509 ; RV64IFD-NEXT: flt.d a0, fa4, fa5
1510 ; RV64IFD-NEXT: beqz a0, .LBB44_2
1511 ; RV64IFD-NEXT: # %bb.1:
1512 ; RV64IFD-NEXT: fcvt.l.d a0, fa0, rne
1513 ; RV64IFD-NEXT: fcvt.d.l fa5, a0, rne
1514 ; RV64IFD-NEXT: fsgnj.d fa0, fa5, fa0
1515 ; RV64IFD-NEXT: .LBB44_2:
1518 ; RV32IZFINXZDINX-LABEL: test_roundeven_double:
1519 ; RV32IZFINXZDINX: # %bb.0:
1520 ; RV32IZFINXZDINX-NEXT: addi sp, sp, -16
1521 ; RV32IZFINXZDINX-NEXT: .cfi_def_cfa_offset 16
1522 ; RV32IZFINXZDINX-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
1523 ; RV32IZFINXZDINX-NEXT: .cfi_offset ra, -4
1524 ; RV32IZFINXZDINX-NEXT: call roundeven
1525 ; RV32IZFINXZDINX-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
1526 ; RV32IZFINXZDINX-NEXT: addi sp, sp, 16
1527 ; RV32IZFINXZDINX-NEXT: ret
1529 ; RV64IZFINXZDINX-LABEL: test_roundeven_double:
1530 ; RV64IZFINXZDINX: # %bb.0:
1531 ; RV64IZFINXZDINX-NEXT: lui a1, %hi(.LCPI44_0)
1532 ; RV64IZFINXZDINX-NEXT: ld a1, %lo(.LCPI44_0)(a1)
1533 ; RV64IZFINXZDINX-NEXT: fabs.d a2, a0
1534 ; RV64IZFINXZDINX-NEXT: flt.d a1, a2, a1
1535 ; RV64IZFINXZDINX-NEXT: beqz a1, .LBB44_2
1536 ; RV64IZFINXZDINX-NEXT: # %bb.1:
1537 ; RV64IZFINXZDINX-NEXT: fcvt.l.d a1, a0, rne
1538 ; RV64IZFINXZDINX-NEXT: fcvt.d.l a1, a1, rne
1539 ; RV64IZFINXZDINX-NEXT: fsgnj.d a0, a1, a0
1540 ; RV64IZFINXZDINX-NEXT: .LBB44_2:
1541 ; RV64IZFINXZDINX-NEXT: ret
1542 %a = call double @llvm.roundeven.f64(double %x)
1546 declare double @llvm.floor.f64(double)
1547 declare double @llvm.ceil.f64(double)
1548 declare double @llvm.trunc.f64(double)
1549 declare double @llvm.round.f64(double)
1550 declare double @llvm.roundeven.f64(double)