
The change implements custom lowering of `get_fpmode`, `set_fpmode` and `reset_fpmode` for RISCV target. The implementation is aligned with the functions `fegetmode` and `fesetmode` in GLIBC.
72 lines
2.1 KiB
LLVM
72 lines
2.1 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
|
|
; RUN: sed 's/iXLen/i32/g' %s | llc -mtriple=riscv32 -mattr=+f -verify-machineinstrs | FileCheck %s
|
|
; RUN: sed 's/iXLen/i64/g' %s | llc -mtriple=riscv64 -mattr=+f -verify-machineinstrs | FileCheck %s
|
|
; RUN: sed 's/iXLen/i32/g' %s | llc -mtriple=riscv32 -mattr=+zfinx -verify-machineinstrs | FileCheck %s
|
|
; RUN: sed 's/iXLen/i64/g' %s | llc -mtriple=riscv64 -mattr=+zfinx -verify-machineinstrs | FileCheck %s
|
|
; RUN: sed 's/iXLen/i32/g' %s | llc -mtriple=riscv32 -mattr=+f -verify-machineinstrs -O0 | FileCheck %s
|
|
; RUN: sed 's/iXLen/i64/g' %s | llc -mtriple=riscv64 -mattr=+f -verify-machineinstrs -O0 | FileCheck %s
|
|
|
|
define iXLen @func_get_fpenv() {
|
|
; CHECK-LABEL: func_get_fpenv:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: frcsr a0
|
|
; CHECK-NEXT: ret
|
|
entry:
|
|
%fpenv = call iXLen @llvm.get.fpenv.iXLen()
|
|
ret iXLen %fpenv
|
|
}
|
|
|
|
define void @func_set_fpenv(iXLen %fpenv) {
|
|
; CHECK-LABEL: func_set_fpenv:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: fscsr a0
|
|
; CHECK-NEXT: ret
|
|
entry:
|
|
call void @llvm.set.fpenv.iXLen(iXLen %fpenv)
|
|
ret void
|
|
}
|
|
|
|
define void @func_reset_fpenv() {
|
|
; CHECK-LABEL: func_reset_fpenv:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: fscsr zero
|
|
; CHECK-NEXT: ret
|
|
entry:
|
|
call void @llvm.reset.fpenv()
|
|
ret void
|
|
}
|
|
|
|
define iXLen @func_get_fpmode() {
|
|
; CHECK-LABEL: func_get_fpmode:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: frcsr a0
|
|
; CHECK-NEXT: ret
|
|
entry:
|
|
%fpenv = call iXLen @llvm.get.fpmode.iXLen()
|
|
ret iXLen %fpenv
|
|
}
|
|
|
|
define void @func_set_fpmode(iXLen %fpmode) {
|
|
; CHECK-LABEL: func_set_fpmode:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: li a1, -32
|
|
; CHECK-NEXT: csrc fcsr, a1
|
|
; CHECK-NEXT: andi a0, a0, -32
|
|
; CHECK-NEXT: csrs fcsr, a0
|
|
; CHECK-NEXT: ret
|
|
entry:
|
|
call void @llvm.set.fpmode.iXLen(iXLen %fpmode)
|
|
ret void
|
|
}
|
|
|
|
define void @func_reset_fpmode() {
|
|
; CHECK-LABEL: func_reset_fpmode:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: li a0, -32
|
|
; CHECK-NEXT: csrc fcsr, a0
|
|
; CHECK-NEXT: ret
|
|
entry:
|
|
call void @llvm.reset.fpmode()
|
|
ret void
|
|
}
|