blob: 928535d79f02cbee55c355c48ac4c44c96e08cbe [file] [log] [blame]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc -mtriple=riscv32 -target-abi ilp32f -mattr=+zfa,+zfh < %s \
; RUN: | FileCheck %s
; RUN: llc -mtriple=riscv64 -target-abi lp64f -mattr=+zfa,+zfh < %s \
; RUN: | FileCheck %s
; RUN: llc -mtriple=riscv32 -target-abi ilp32f -mattr=+zfa,+zfhmin < %s \
; RUN: | FileCheck %s --check-prefix=ZFHMIN
; RUN: llc -mtriple=riscv64 -target-abi lp64f -mattr=+zfa,+zfhmin < %s \
; RUN: | FileCheck %s --check-prefix=ZFHMIN
define half @loadfpimm1() {
; CHECK-LABEL: loadfpimm1:
; CHECK: # %bb.0:
; CHECK-NEXT: fli.h fa0, 0.0625
; CHECK-NEXT: ret
;
; ZFHMIN-LABEL: loadfpimm1:
; ZFHMIN: # %bb.0:
; ZFHMIN-NEXT: li a0, 11
; ZFHMIN-NEXT: slli a0, a0, 10
; ZFHMIN-NEXT: fmv.h.x fa0, a0
; ZFHMIN-NEXT: ret
ret half 0.0625
}
define half @loadfpimm2() {
; CHECK-LABEL: loadfpimm2:
; CHECK: # %bb.0:
; CHECK-NEXT: fli.h fa0, 0.75
; CHECK-NEXT: ret
;
; ZFHMIN-LABEL: loadfpimm2:
; ZFHMIN: # %bb.0:
; ZFHMIN-NEXT: li a0, 29
; ZFHMIN-NEXT: slli a0, a0, 9
; ZFHMIN-NEXT: fmv.h.x fa0, a0
; ZFHMIN-NEXT: ret
ret half 0.75
}
define half @loadfpimm3() {
; CHECK-LABEL: loadfpimm3:
; CHECK: # %bb.0:
; CHECK-NEXT: fli.h fa0, 1.25
; CHECK-NEXT: ret
;
; ZFHMIN-LABEL: loadfpimm3:
; ZFHMIN: # %bb.0:
; ZFHMIN-NEXT: lui a0, 4
; ZFHMIN-NEXT: addi a0, a0, -768
; ZFHMIN-NEXT: fmv.h.x fa0, a0
; ZFHMIN-NEXT: ret
ret half 1.25
}
define half @loadfpimm4() {
; CHECK-LABEL: loadfpimm4:
; CHECK: # %bb.0:
; CHECK-NEXT: fli.h fa0, 3.0
; CHECK-NEXT: ret
;
; ZFHMIN-LABEL: loadfpimm4:
; ZFHMIN: # %bb.0:
; ZFHMIN-NEXT: lui a0, 4
; ZFHMIN-NEXT: addi a0, a0, 512
; ZFHMIN-NEXT: fmv.h.x fa0, a0
; ZFHMIN-NEXT: ret
ret half 3.0
}
define half @loadfpimm5() {
; CHECK-LABEL: loadfpimm5:
; CHECK: # %bb.0:
; CHECK-NEXT: fli.h fa0, 256.0
; CHECK-NEXT: ret
;
; ZFHMIN-LABEL: loadfpimm5:
; ZFHMIN: # %bb.0:
; ZFHMIN-NEXT: li a0, 23
; ZFHMIN-NEXT: slli a0, a0, 10
; ZFHMIN-NEXT: fmv.h.x fa0, a0
; ZFHMIN-NEXT: ret
ret half 256.0
}
define half @loadfpimm6() {
; CHECK-LABEL: loadfpimm6:
; CHECK: # %bb.0:
; CHECK-NEXT: fli.h fa0, inf
; CHECK-NEXT: ret
;
; ZFHMIN-LABEL: loadfpimm6:
; ZFHMIN: # %bb.0:
; ZFHMIN-NEXT: li a0, 31
; ZFHMIN-NEXT: slli a0, a0, 10
; ZFHMIN-NEXT: fmv.h.x fa0, a0
; ZFHMIN-NEXT: ret
ret half 0xH7C00
}
define half @loadfpimm7() {
; CHECK-LABEL: loadfpimm7:
; CHECK: # %bb.0:
; CHECK-NEXT: fli.h fa0, nan
; CHECK-NEXT: ret
;
; ZFHMIN-LABEL: loadfpimm7:
; ZFHMIN: # %bb.0:
; ZFHMIN-NEXT: lui a0, 8
; ZFHMIN-NEXT: addi a0, a0, -512
; ZFHMIN-NEXT: fmv.h.x fa0, a0
; ZFHMIN-NEXT: ret
ret half 0xH7E00
}
define half @loadfpimm8() {
; CHECK-LABEL: loadfpimm8:
; CHECK: # %bb.0:
; CHECK-NEXT: fli.h fa0, min
; CHECK-NEXT: ret
;
; ZFHMIN-LABEL: loadfpimm8:
; ZFHMIN: # %bb.0:
; ZFHMIN-NEXT: li a0, 1024
; ZFHMIN-NEXT: fmv.h.x fa0, a0
; ZFHMIN-NEXT: ret
ret half 0xH0400
}
define half @loadfpimm9() {
; CHECK-LABEL: loadfpimm9:
; CHECK: # %bb.0:
; CHECK-NEXT: lui a0, 6
; CHECK-NEXT: addi a0, a0, -1032
; CHECK-NEXT: fmv.h.x fa0, a0
; CHECK-NEXT: ret
;
; ZFHMIN-LABEL: loadfpimm9:
; ZFHMIN: # %bb.0:
; ZFHMIN-NEXT: lui a0, 6
; ZFHMIN-NEXT: addi a0, a0, -1032
; ZFHMIN-NEXT: fmv.h.x fa0, a0
; ZFHMIN-NEXT: ret
ret half 255.0
}
; This is 1 * 2^-16
define half @loadfpimm10() {
; CHECK-LABEL: loadfpimm10:
; CHECK: # %bb.0:
; CHECK-NEXT: fli.h fa0, 1.52587890625e-05
; CHECK-NEXT: ret
;
; ZFHMIN-LABEL: loadfpimm10:
; ZFHMIN: # %bb.0:
; ZFHMIN-NEXT: li a0, 256
; ZFHMIN-NEXT: fmv.h.x fa0, a0
; ZFHMIN-NEXT: ret
ret half 0xH0100
}
; This is 1 * 2^-15
define half @loadfpimm11() {
; CHECK-LABEL: loadfpimm11:
; CHECK: # %bb.0:
; CHECK-NEXT: fli.h fa0, 3.0517578125e-05
; CHECK-NEXT: ret
;
; ZFHMIN-LABEL: loadfpimm11:
; ZFHMIN: # %bb.0:
; ZFHMIN-NEXT: li a0, 512
; ZFHMIN-NEXT: fmv.h.x fa0, a0
; ZFHMIN-NEXT: ret
ret half 0xH0200
}
; Negative test. This is an snan with payload of 1.
define half @loadfpimm12() {
; CHECK-LABEL: loadfpimm12:
; CHECK: # %bb.0:
; CHECK-NEXT: lui a0, 8
; CHECK-NEXT: addi a0, a0, -1023
; CHECK-NEXT: fmv.h.x fa0, a0
; CHECK-NEXT: ret
;
; ZFHMIN-LABEL: loadfpimm12:
; ZFHMIN: # %bb.0:
; ZFHMIN-NEXT: lui a0, 8
; ZFHMIN-NEXT: addi a0, a0, -1023
; ZFHMIN-NEXT: fmv.h.x fa0, a0
; ZFHMIN-NEXT: ret
ret half 0xH7c01
}
define half @loadfpimm13() {
; CHECK-LABEL: loadfpimm13:
; CHECK: # %bb.0:
; CHECK-NEXT: fli.h fa0, -1.0
; CHECK-NEXT: ret
;
; ZFHMIN-LABEL: loadfpimm13:
; ZFHMIN: # %bb.0:
; ZFHMIN-NEXT: li a0, -17
; ZFHMIN-NEXT: slli a0, a0, 10
; ZFHMIN-NEXT: fmv.h.x fa0, a0
; ZFHMIN-NEXT: ret
ret half -1.0
}
; Ensure fli isn't directly used for negated versions of numbers in the fli
; table.
define half @loadfpimm14() {
; CHECK-LABEL: loadfpimm14:
; CHECK: # %bb.0:
; CHECK-NEXT: fli.h fa5, 2.0
; CHECK-NEXT: fneg.h fa0, fa5
; CHECK-NEXT: ret
;
; ZFHMIN-LABEL: loadfpimm14:
; ZFHMIN: # %bb.0:
; ZFHMIN-NEXT: lui a0, 1048572
; ZFHMIN-NEXT: fmv.h.x fa0, a0
; ZFHMIN-NEXT: ret
ret half -2.0
}
; Ensure fli isn't directly used for negative min normal value.
define half @loadfpimm15() {
; CHECK-LABEL: loadfpimm15:
; CHECK: # %bb.0:
; CHECK-NEXT: fli.h fa5, min
; CHECK-NEXT: fneg.h fa0, fa5
; CHECK-NEXT: ret
;
; ZFHMIN-LABEL: loadfpimm15:
; ZFHMIN: # %bb.0:
; ZFHMIN-NEXT: li a0, -31
; ZFHMIN-NEXT: slli a0, a0, 10
; ZFHMIN-NEXT: fmv.h.x fa0, a0
; ZFHMIN-NEXT: ret
ret half 0xH8400
}