blob: d3af2153588a1611a248bf510611d3d63fe514de [file] [log] [blame]
; 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
; FIXME: crash
; define ITy @test_lrint_ixx_f16(half %x) nounwind {
; %res = tail call ITy @llvm.lrint.ITy.f16(half %x)
; }
; define ITy @test_llrint_ixx_f16(half %x) nounwind {
; %res = tail call ITy @llvm.llrint.ITy.f16(half %x)
; }
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
}