fp16-promote.ll 3.95 KB
; 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
}