| ; Tests for lrint and llrint, with both i32 and i64 checked. |
| |
| ; RUN: sed 's/ITy/i32/g' %s | llc -mtriple=loongarch32 | FileCheck %s --check-prefixes=LA32 |
| ; RUN: sed 's/ITy/i64/g' %s | llc -mtriple=loongarch32 | FileCheck %s --check-prefixes=LA32 |
| ; RUN: sed 's/ITy/i32/g' %s | llc -mtriple=loongarch64 | FileCheck %s --check-prefixes=LA64-I32 |
| ; RUN: sed 's/ITy/i64/g' %s | llc -mtriple=loongarch64 | FileCheck %s --check-prefixes=LA64-I64 |
| |
| ; FIXME: crash |
| ; define ITy @test_lrint_ixx_f16(half %x) nounwind { |
| ; %res = tail call ITy @llvm.lrint.ITy.f16(half %x) |
| ; ret ITy %res |
| ; } |
| |
| ; define ITy @test_llrint_ixx_f16(half %x) nounwind { |
| ; %res = tail call ITy @llvm.llrint.ITy.f16(half %x) |
| ; ret ITy %res |
| ; } |
| |
| define ITy @test_lrint_ixx_f32(float %x) nounwind { |
| ; LA32-LABEL: test_lrint_ixx_f32: |
| ; LA32: bl lrintf |
| ; |
| ; LA64-I32-LABEL: test_lrint_ixx_f32: |
| ; LA64-I32: pcaddu18i $ra, %call36(lrintf) |
| ; |
| ; LA64-I64-LABEL: test_lrint_ixx_f32: |
| ; LA64-I64: pcaddu18i $t8, %call36(lrintf) |
| %res = tail call ITy @llvm.lrint.ITy.f32(float %x) |
| ret ITy %res |
| } |
| |
| define ITy @test_llrint_ixx_f32(float %x) nounwind { |
| ; LA32-LABEL: test_llrint_ixx_f32: |
| ; LA32: bl llrintf |
| ; |
| ; LA64-I32-LABEL: test_llrint_ixx_f32: |
| ; LA64-I32: pcaddu18i $ra, %call36(llrintf) |
| ; |
| ; LA64-I64-LABEL: test_llrint_ixx_f32: |
| ; LA64-I64: pcaddu18i $t8, %call36(llrintf) |
| %res = tail call ITy @llvm.llrint.ITy.f32(float %x) |
| ret ITy %res |
| } |
| |
| define ITy @test_lrint_ixx_f64(double %x) nounwind { |
| ; LA32-LABEL: test_lrint_ixx_f64: |
| ; LA32: bl lrint |
| ; |
| ; LA64-I32-LABEL: test_lrint_ixx_f64: |
| ; LA64-I32: pcaddu18i $ra, %call36(lrint) |
| ; |
| ; LA64-I64-LABEL: test_lrint_ixx_f64: |
| ; LA64-I64: pcaddu18i $t8, %call36(lrint) |
| %res = tail call ITy @llvm.lrint.ITy.f64(double %x) |
| ret ITy %res |
| } |
| |
| define ITy @test_llrint_ixx_f64(double %x) nounwind { |
| ; LA32-LABEL: test_llrint_ixx_f64: |
| ; LA32: bl llrint |
| ; |
| ; LA64-I32-LABEL: test_llrint_ixx_f64: |
| ; LA64-I32: pcaddu18i $ra, %call36(llrint) |
| ; |
| ; LA64-I64-LABEL: test_llrint_ixx_f64: |
| ; LA64-I64: pcaddu18i $t8, %call36(llrint) |
| %res = tail call ITy @llvm.llrint.ITy.f64(double %x) |
| ret ITy %res |
| } |
| |
| ; FIXME(#44744): incorrect libcall on loongarch32 |
| define ITy @test_lrint_ixx_f128(fp128 %x) nounwind { |
| ; LA32-LABEL: test_lrint_ixx_f128: |
| ; LA32: bl lrintl |
| ; |
| ; LA64-I32-LABEL: test_lrint_ixx_f128: |
| ; LA64-I32: pcaddu18i $ra, %call36(lrintl) |
| ; |
| ; LA64-I64-LABEL: test_lrint_ixx_f128: |
| ; LA64-I64: pcaddu18i $ra, %call36(lrintl) |
| %res = tail call ITy @llvm.lrint.ITy.f128(fp128 %x) |
| ret ITy %res |
| } |
| |
| define ITy @test_llrint_ixx_f128(fp128 %x) nounwind { |
| ; LA32-LABEL: test_llrint_ixx_f128: |
| ; LA32: bl llrintl |
| ; |
| ; LA64-I32-LABEL: test_llrint_ixx_f128: |
| ; LA64-I32: pcaddu18i $ra, %call36(llrintl) |
| ; |
| ; LA64-I64-LABEL: test_llrint_ixx_f128: |
| ; LA64-I64: pcaddu18i $ra, %call36(llrintl) |
| %res = tail call ITy @llvm.llrint.ITy.f128(fp128 %x) |
| ret ITy %res |
| } |