blob: 48786992265824a0d0479f9af6ffabad10adbb42 [file] [edit]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
; RUN: llc -mtriple=riscv32 -mattr=+zfa,d -global-isel < %s \
; RUN: | FileCheck %s --check-prefixes=CHECK,RV32IDZFA
; RUN: llc -mtriple=riscv64 -mattr=+zfa,d -global-isel < %s \
; RUN: | FileCheck %s --check-prefixes=CHECK,RV64DZFA
define double @fceil(double %a) {
; CHECK-LABEL: fceil:
; CHECK: # %bb.0:
; CHECK-NEXT: fround.d fa0, fa0, rup
; CHECK-NEXT: ret
%b = call double @llvm.ceil.f64(double %a)
ret double %b
}
define double @ffloor(double %a) {
; CHECK-LABEL: ffloor:
; CHECK: # %bb.0:
; CHECK-NEXT: fround.d fa0, fa0, rdn
; CHECK-NEXT: ret
%b = call double @llvm.floor.f64(double %a)
ret double %b
}
define double @frint(double %a) {
; CHECK-LABEL: frint:
; CHECK: # %bb.0:
; CHECK-NEXT: froundnx.d fa0, fa0
; CHECK-NEXT: ret
%b = call double @llvm.rint.f64(double %a)
ret double %b
}
define double @fnearbyint(double %a) {
; CHECK-LABEL: fnearbyint:
; CHECK: # %bb.0:
; CHECK-NEXT: fround.d fa0, fa0
; CHECK-NEXT: ret
%b = call double @llvm.nearbyint.f64(double %a)
ret double %b
}
define double @fround(double %a) {
; CHECK-LABEL: fround:
; CHECK: # %bb.0:
; CHECK-NEXT: fround.d fa0, fa0, rmm
; CHECK-NEXT: ret
%b = call double @llvm.round.f64(double %a)
ret double %b
}
define double @froundeven(double %a) {
; CHECK-LABEL: froundeven:
; CHECK: # %bb.0:
; CHECK-NEXT: fround.d fa0, fa0, rne
; CHECK-NEXT: ret
%b = call double @llvm.roundeven.f64(double %a)
ret double %b
}
define double @ftrunc(double %a) {
; CHECK-LABEL: ftrunc:
; CHECK: # %bb.0:
; CHECK-NEXT: fround.d fa0, fa0, rtz
; CHECK-NEXT: ret
%b = call double @llvm.trunc.f64(double %a)
ret double %b
}
define double @fmaximum(double %a, double %b) {
; CHECK-LABEL: fmaximum:
; CHECK: # %bb.0:
; CHECK-NEXT: fmaxm.d fa0, fa0, fa1
; CHECK-NEXT: ret
%c = call double @llvm.maximum.f64(double %a, double %b)
ret double %c
}
define double @fminimum(double %a, double %b) {
; CHECK-LABEL: fminimum:
; CHECK: # %bb.0:
; CHECK-NEXT: fminm.d fa0, fa0, fa1
; CHECK-NEXT: ret
%c = call double @llvm.minimum.f64(double %a, double %b)
ret double %c
}
define i64 @fmvh_x_d(double %fa) {
; RV32IDZFA-LABEL: fmvh_x_d:
; RV32IDZFA: # %bb.0:
; RV32IDZFA-NEXT: fmv.x.w a0, fa0
; RV32IDZFA-NEXT: fmvh.x.d a1, fa0
; RV32IDZFA-NEXT: ret
;
; RV64DZFA-LABEL: fmvh_x_d:
; RV64DZFA: # %bb.0:
; RV64DZFA-NEXT: fmv.x.d a0, fa0
; RV64DZFA-NEXT: ret
%i = bitcast double %fa to i64
ret i64 %i
}
define double @fmvp_d_x(i64 %a) {
; RV32IDZFA-LABEL: fmvp_d_x:
; RV32IDZFA: # %bb.0:
; RV32IDZFA-NEXT: fmvp.d.x fa0, a0, a1
; RV32IDZFA-NEXT: ret
;
; RV64DZFA-LABEL: fmvp_d_x:
; RV64DZFA: # %bb.0:
; RV64DZFA-NEXT: fmv.d.x fa0, a0
; RV64DZFA-NEXT: ret
%or = bitcast i64 %a to double
ret double %or
}