summaryrefslogtreecommitdiffstats
path: root/llvm/test/CodeGen/RISCV
diff options
context:
space:
mode:
Diffstat (limited to 'llvm/test/CodeGen/RISCV')
-rw-r--r--llvm/test/CodeGen/RISCV/fp16-promote.ll142
1 files changed, 142 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/RISCV/fp16-promote.ll b/llvm/test/CodeGen/RISCV/fp16-promote.ll
new file mode 100644
index 00000000000..c99fc1245aa
--- /dev/null
+++ b/llvm/test/CodeGen/RISCV/fp16-promote.ll
@@ -0,0 +1,142 @@
+; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
+; RUN: llc -mtriple=riscv32 -mattr +d -target-abi ilp32d < %s | FileCheck %s
+
+define void @test_load_store(half* %p, half* %q) nounwind {
+; CHECK-LABEL: test_load_store:
+; CHECK: # %bb.0:
+; CHECK-NEXT: lh a0, 0(a0)
+; CHECK-NEXT: sh a0, 0(a1)
+; CHECK-NEXT: ret
+ %a = load half, half* %p
+ store half %a, half* %q
+ ret void
+}
+
+define float @test_fpextend_float(half* %p) nounwind {
+; CHECK-LABEL: test_fpextend_float:
+; CHECK: # %bb.0:
+; CHECK-NEXT: addi sp, sp, -16
+; CHECK-NEXT: sw ra, 12(sp)
+; CHECK-NEXT: lhu a0, 0(a0)
+; CHECK-NEXT: call __gnu_h2f_ieee
+; CHECK-NEXT: lw ra, 12(sp)
+; CHECK-NEXT: addi sp, sp, 16
+; CHECK-NEXT: ret
+ %a = load half, half* %p
+ %r = fpext half %a to float
+ ret float %r
+}
+
+define double @test_fpextend_double(half* %p) nounwind {
+; CHECK-LABEL: test_fpextend_double:
+; CHECK: # %bb.0:
+; CHECK-NEXT: addi sp, sp, -16
+; CHECK-NEXT: sw ra, 12(sp)
+; CHECK-NEXT: lhu a0, 0(a0)
+; CHECK-NEXT: call __gnu_h2f_ieee
+; CHECK-NEXT: fcvt.d.s fa0, fa0
+; CHECK-NEXT: lw ra, 12(sp)
+; CHECK-NEXT: addi sp, sp, 16
+; CHECK-NEXT: ret
+ %a = load half, half* %p
+ %r = fpext half %a to double
+ ret double %r
+}
+
+define void @test_fptrunc_float(float %f, half* %p) nounwind {
+; CHECK-LABEL: test_fptrunc_float:
+; CHECK: # %bb.0:
+; CHECK-NEXT: addi sp, sp, -16
+; CHECK-NEXT: sw ra, 12(sp)
+; CHECK-NEXT: sw s0, 8(sp)
+; CHECK-NEXT: mv s0, a0
+; CHECK-NEXT: call __gnu_f2h_ieee
+; CHECK-NEXT: sh a0, 0(s0)
+; CHECK-NEXT: lw s0, 8(sp)
+; CHECK-NEXT: lw ra, 12(sp)
+; CHECK-NEXT: addi sp, sp, 16
+; CHECK-NEXT: ret
+ %a = fptrunc float %f to half
+ store half %a, half* %p
+ ret void
+}
+
+define void @test_fptrunc_double(double %d, half* %p) nounwind {
+; CHECK-LABEL: test_fptrunc_double:
+; CHECK: # %bb.0:
+; CHECK-NEXT: addi sp, sp, -16
+; CHECK-NEXT: sw ra, 12(sp)
+; CHECK-NEXT: sw s0, 8(sp)
+; CHECK-NEXT: mv s0, a0
+; CHECK-NEXT: call __truncdfhf2
+; CHECK-NEXT: sh a0, 0(s0)
+; CHECK-NEXT: lw s0, 8(sp)
+; CHECK-NEXT: lw ra, 12(sp)
+; CHECK-NEXT: addi sp, sp, 16
+; CHECK-NEXT: ret
+ %a = fptrunc double %d to half
+ store half %a, half* %p
+ ret void
+}
+
+define void @test_fadd(half* %p, half* %q) nounwind {
+; CHECK-LABEL: test_fadd:
+; CHECK: # %bb.0:
+; CHECK-NEXT: addi sp, sp, -32
+; CHECK-NEXT: sw ra, 28(sp)
+; CHECK-NEXT: sw s0, 24(sp)
+; CHECK-NEXT: sw s1, 20(sp)
+; CHECK-NEXT: fsd fs0, 8(sp)
+; CHECK-NEXT: mv s0, a1
+; CHECK-NEXT: mv s1, a0
+; CHECK-NEXT: lhu a0, 0(a0)
+; CHECK-NEXT: call __gnu_h2f_ieee
+; CHECK-NEXT: fmv.s fs0, fa0
+; CHECK-NEXT: lhu a0, 0(s0)
+; CHECK-NEXT: call __gnu_h2f_ieee
+; CHECK-NEXT: fadd.s fa0, fs0, fa0
+; CHECK-NEXT: call __gnu_f2h_ieee
+; CHECK-NEXT: sh a0, 0(s1)
+; CHECK-NEXT: fld fs0, 8(sp)
+; CHECK-NEXT: lw s1, 20(sp)
+; CHECK-NEXT: lw s0, 24(sp)
+; CHECK-NEXT: lw ra, 28(sp)
+; CHECK-NEXT: addi sp, sp, 32
+; CHECK-NEXT: ret
+ %a = load half, half* %p
+ %b = load half, half* %q
+ %r = fadd half %a, %b
+ store half %r, half* %p
+ ret void
+}
+
+define void @test_fmul(half* %p, half* %q) nounwind {
+; CHECK-LABEL: test_fmul:
+; CHECK: # %bb.0:
+; CHECK-NEXT: addi sp, sp, -32
+; CHECK-NEXT: sw ra, 28(sp)
+; CHECK-NEXT: sw s0, 24(sp)
+; CHECK-NEXT: sw s1, 20(sp)
+; CHECK-NEXT: fsd fs0, 8(sp)
+; CHECK-NEXT: mv s0, a1
+; CHECK-NEXT: mv s1, a0
+; CHECK-NEXT: lhu a0, 0(a0)
+; CHECK-NEXT: call __gnu_h2f_ieee
+; CHECK-NEXT: fmv.s fs0, fa0
+; CHECK-NEXT: lhu a0, 0(s0)
+; CHECK-NEXT: call __gnu_h2f_ieee
+; CHECK-NEXT: fmul.s fa0, fs0, fa0
+; CHECK-NEXT: call __gnu_f2h_ieee
+; CHECK-NEXT: sh a0, 0(s1)
+; CHECK-NEXT: fld fs0, 8(sp)
+; CHECK-NEXT: lw s1, 20(sp)
+; CHECK-NEXT: lw s0, 24(sp)
+; CHECK-NEXT: lw ra, 28(sp)
+; CHECK-NEXT: addi sp, sp, 32
+; CHECK-NEXT: ret
+ %a = load half, half* %p
+ %b = load half, half* %q
+ %r = fmul half %a, %b
+ store half %r, half* %p
+ ret void
+}
OpenPOWER on IntegriCloud