blob: ecb6bd0932ef36d6459b907c28b719c238232785 [file] [edit]
; Tests for lrint and llrint, with both i32 and i64 checked.
; RUN: sed 's/ITy/i32/g' %s | llc -mtriple=riscv32 | FileCheck %s --check-prefixes=RV32
; RUN: sed 's/ITy/i64/g' %s | llc -mtriple=riscv32 | FileCheck %s --check-prefixes=RV32
; RUN: sed 's/ITy/i32/g' %s | llc -mtriple=riscv64 | FileCheck %s --check-prefixes=RV64
; RUN: sed 's/ITy/i64/g' %s | llc -mtriple=riscv64 | FileCheck %s --check-prefixes=RV64
define ITy @test_lrint_ixx_f16(half %x) nounwind {
; RV32-LABEL: test_lrint_ixx_f16:
; RV32: call lrintf
;
; RV64-LABEL: test_lrint_ixx_f16:
; RV64: call lrintf
%res = tail call ITy @llvm.lrint.ITy.f16(half %x)
ret ITy %res
}
define ITy @test_llrint_ixx_f16(half %x) nounwind {
; RV32-LABEL: test_llrint_ixx_f16:
; RV32: call llrintf
;
; RV64-LABEL: test_llrint_ixx_f16:
; RV64: call llrintf
%res = tail call ITy @llvm.llrint.ITy.f16(half %x)
ret ITy %res
}
define ITy @test_lrint_ixx_f32(float %x) nounwind {
; RV32-LABEL: test_lrint_ixx_f32:
; RV32: call lrintf
;
; RV64-LABEL: test_lrint_ixx_f32:
; RV64: call lrintf
%res = tail call ITy @llvm.lrint.ITy.f32(float %x)
ret ITy %res
}
define ITy @test_llrint_ixx_f32(float %x) nounwind {
; RV32-LABEL: test_llrint_ixx_f32:
; RV32: call llrintf
;
; RV64-LABEL: test_llrint_ixx_f32:
; RV64: call llrintf
%res = tail call ITy @llvm.llrint.ITy.f32(float %x)
ret ITy %res
}
define ITy @test_lrint_ixx_f64(double %x) nounwind {
; RV32-LABEL: test_lrint_ixx_f64:
; RV32: call lrint
;
; RV64-LABEL: test_lrint_ixx_f64:
; RV64: call lrint
%res = tail call ITy @llvm.lrint.ITy.f64(double %x)
ret ITy %res
}
define ITy @test_llrint_ixx_f64(double %x) nounwind {
; RV32-LABEL: test_llrint_ixx_f64:
; RV32: call llrint
;
; RV64-LABEL: test_llrint_ixx_f64:
; RV64: call llrint
%res = tail call ITy @llvm.llrint.ITy.f64(double %x)
ret ITy %res
}
; FIXME(#44744): incorrect libcall on riscv32
define ITy @test_lrint_ixx_f128(fp128 %x) nounwind {
; RV32-LABEL: test_lrint_ixx_f128:
; RV32: call lrintl
;
; RV64-LABEL: test_lrint_ixx_f128:
; RV64: call lrintl
%res = tail call ITy @llvm.lrint.ITy.f128(fp128 %x)
ret ITy %res
}
define ITy @test_llrint_ixx_f128(fp128 %x) nounwind {
; RV32-LABEL: test_llrint_ixx_f128:
; RV32: call llrintl
;
; RV64-LABEL: test_llrint_ixx_f128:
; RV64: call llrintl
%res = tail call ITy @llvm.llrint.ITy.f128(fp128 %x)
ret ITy %res
}