; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 4 ; RUN: opt -codegenprepare -S -mtriple=riscv64 < %s | FileCheck %s define i1 @test_is_inf_or_nan(double %arg) { ; CHECK-LABEL: define i1 @test_is_inf_or_nan( ; CHECK-SAME: double [[ARG:%.*]]) { ; CHECK-NEXT: [[TMP1:%.*]] = call i1 @llvm.is.fpclass.f64(double [[ARG]], i32 519) ; CHECK-NEXT: ret i1 [[TMP1]] ; %abs = tail call double @llvm.fabs.f64(double %arg) %ret = fcmp ueq double %abs, 0x7FF0000000000000 ret i1 %ret } define i1 @test_is_not_inf_or_nan(double %arg) { ; CHECK-LABEL: define i1 @test_is_not_inf_or_nan( ; CHECK-SAME: double [[ARG:%.*]]) { ; CHECK-NEXT: [[TMP1:%.*]] = call i1 @llvm.is.fpclass.f64(double [[ARG]], i32 504) ; CHECK-NEXT: ret i1 [[TMP1]] ; %abs = tail call double @llvm.fabs.f64(double %arg) %ret = fcmp one double %abs, 0x7FF0000000000000 ret i1 %ret } define i1 @test_is_inf(double %arg) { ; CHECK-LABEL: define i1 @test_is_inf( ; CHECK-SAME: double [[ARG:%.*]]) { ; CHECK-NEXT: [[TMP1:%.*]] = call i1 @llvm.is.fpclass.f64(double [[ARG]], i32 516) ; CHECK-NEXT: ret i1 [[TMP1]] ; %abs = tail call double @llvm.fabs.f64(double %arg) %ret = fcmp oeq double %abs, 0x7FF0000000000000 ret i1 %ret } define i1 @test_is_not_inf(double %arg) { ; CHECK-LABEL: define i1 @test_is_not_inf( ; CHECK-SAME: double [[ARG:%.*]]) { ; CHECK-NEXT: [[TMP1:%.*]] = call i1 @llvm.is.fpclass.f64(double [[ARG]], i32 507) ; CHECK-NEXT: ret i1 [[TMP1]] ; %abs = tail call double @llvm.fabs.f64(double %arg) %ret = fcmp une double %abs, 0x7FF0000000000000 ret i1 %ret } define @test_vec_is_inf_or_nan( %arg) { ; CHECK-LABEL: define @test_vec_is_inf_or_nan( ; CHECK-SAME: [[ARG:%.*]]) { ; CHECK-NEXT: [[TMP1:%.*]] = call @llvm.is.fpclass.nxv4f64( [[ARG]], i32 519) ; CHECK-NEXT: ret [[TMP1]] ; %abs = tail call @llvm.fabs.nxv4f64( %arg) %ret = fcmp ueq %abs, splat (double 0x7FF0000000000000) ret %ret } define @test_vec_is_not_inf_or_nan( %arg) { ; CHECK-LABEL: define @test_vec_is_not_inf_or_nan( ; CHECK-SAME: [[ARG:%.*]]) { ; CHECK-NEXT: [[TMP1:%.*]] = call @llvm.is.fpclass.nxv4f64( [[ARG]], i32 504) ; CHECK-NEXT: ret [[TMP1]] ; %abs = tail call @llvm.fabs.nxv4f64( %arg) %ret = fcmp one %abs, splat (double 0x7FF0000000000000) ret %ret } define @test_vec_is_inf( %arg) { ; CHECK-LABEL: define @test_vec_is_inf( ; CHECK-SAME: [[ARG:%.*]]) { ; CHECK-NEXT: [[TMP1:%.*]] = call @llvm.is.fpclass.nxv4f64( [[ARG]], i32 516) ; CHECK-NEXT: ret [[TMP1]] ; %abs = tail call @llvm.fabs.nxv4f64( %arg) %ret = fcmp oeq %abs, splat (double 0x7FF0000000000000) ret %ret } define @test_vec_is_not_inf( %arg) { ; CHECK-LABEL: define @test_vec_is_not_inf( ; CHECK-SAME: [[ARG:%.*]]) { ; CHECK-NEXT: [[TMP1:%.*]] = call @llvm.is.fpclass.nxv4f64( [[ARG]], i32 507) ; CHECK-NEXT: ret [[TMP1]] ; %abs = tail call @llvm.fabs.nxv4f64( %arg) %ret = fcmp une %abs, splat (double 0x7FF0000000000000) ret %ret } define i1 @test_fp128_is_inf_or_nan(fp128 %arg) { ; CHECK-LABEL: define i1 @test_fp128_is_inf_or_nan( ; CHECK-SAME: fp128 [[ARG:%.*]]) { ; CHECK-NEXT: [[TMP1:%.*]] = call i1 @llvm.is.fpclass.f128(fp128 [[ARG]], i32 519) ; CHECK-NEXT: ret i1 [[TMP1]] ; %abs = tail call fp128 @llvm.fabs.f128(fp128 %arg) %ret = fcmp ueq fp128 %abs, 0xL00000000000000007FFF000000000000 ret i1 %ret } define i1 @test_fp128_is_not_inf_or_nan(fp128 %arg) { ; CHECK-LABEL: define i1 @test_fp128_is_not_inf_or_nan( ; CHECK-SAME: fp128 [[ARG:%.*]]) { ; CHECK-NEXT: [[TMP1:%.*]] = call i1 @llvm.is.fpclass.f128(fp128 [[ARG]], i32 504) ; CHECK-NEXT: ret i1 [[TMP1]] ; %abs = tail call fp128 @llvm.fabs.f128(fp128 %arg) %ret = fcmp one fp128 %abs, 0xL00000000000000007FFF000000000000 ret i1 %ret } define i1 @test_fp128_is_inf(fp128 %arg) { ; CHECK-LABEL: define i1 @test_fp128_is_inf( ; CHECK-SAME: fp128 [[ARG:%.*]]) { ; CHECK-NEXT: [[TMP1:%.*]] = call i1 @llvm.is.fpclass.f128(fp128 [[ARG]], i32 516) ; CHECK-NEXT: ret i1 [[TMP1]] ; %abs = tail call fp128 @llvm.fabs.f128(fp128 %arg) %ret = fcmp oeq fp128 %abs, 0xL00000000000000007FFF000000000000 ret i1 %ret } define i1 @test_fp128_is_not_inf(fp128 %arg) { ; CHECK-LABEL: define i1 @test_fp128_is_not_inf( ; CHECK-SAME: fp128 [[ARG:%.*]]) { ; CHECK-NEXT: [[TMP1:%.*]] = call i1 @llvm.is.fpclass.f128(fp128 [[ARG]], i32 507) ; CHECK-NEXT: ret i1 [[TMP1]] ; %abs = tail call fp128 @llvm.fabs.f128(fp128 %arg) %ret = fcmp une fp128 %abs, 0xL00000000000000007FFF000000000000 ret i1 %ret }