Hi, This patch folds builtin_isfinite on IBM long double to builtin_isfinite on double type. The former patch https://gcc.gnu.org/pipermail/gcc-patches/2024-April/649346.html implemented the DFmode isfinite_optab.
Bootstrapped and tested on powerpc64-linux BE and LE with no regressions. Is it OK for next stage 1? Thanks Gui Haochen ChangeLog Builtin: Fold builtin_isfinite on IBM long double to builtin_isfinite on double For IBM long double, INF and NAN is encoded in the high-order double value only. So the builtin_isfinite on IBM long double can be folded to builtin_isfinite on double type. As former patch implemented DFmode isfinite_optab, this patch converts builtin_isfinite on IBM long double to builtin_isfinite on double type if the DFmode isfinite_optab exists. gcc/ PR target/97786 * builtins.cc (fold_builtin_interclass_mathfn): Fold IBM long double isfinite call to double isfinite call when DFmode isfinite_optab exists. gcc/testsuite/ PR target/97786 * gcc.target/powerpc/pr97786-6.c: New test. patch.diff diff --git a/gcc/builtins.cc b/gcc/builtins.cc index 5262aa01660..3174f52ebe8 100644 --- a/gcc/builtins.cc +++ b/gcc/builtins.cc @@ -9605,6 +9605,12 @@ fold_builtin_interclass_mathfn (location_t loc, tree fndecl, tree arg) type = double_type_node; mode = DFmode; arg = fold_build1_loc (loc, NOP_EXPR, type, arg); + tree const isfinite_fn = builtin_decl_explicit (BUILT_IN_ISFINITE); + if (interclass_mathfn_icode (arg, isfinite_fn) != CODE_FOR_nothing) + { + result = build_call_expr (isfinite_fn, 1, arg); + return result; + } } get_max_float (REAL_MODE_FORMAT (mode), buf, sizeof (buf), false); real_from_string (&r, buf); diff --git a/gcc/testsuite/gcc.target/powerpc/pr97786-6.c b/gcc/testsuite/gcc.target/powerpc/pr97786-6.c new file mode 100644 index 00000000000..c86c765651d --- /dev/null +++ b/gcc/testsuite/gcc.target/powerpc/pr97786-6.c @@ -0,0 +1,12 @@ +/* { dg-do compile { target lp64 } } */ +/* { dg-require-effective-target ppc_float128_sw } */ +/* { dg-require-effective-target powerpc_vsx_ok } */ +/* { dg-options "-O2 -mdejagnu-cpu=power9 -mvsx -mabi=ibmlongdouble -Wno-psabi" } */ + +int test1 (long double x) +{ + return __builtin_isfinite (x); +} + +/* { dg-final { scan-assembler-not {\mfcmpu\M} } } */ +/* { dg-final { scan-assembler {\mxststdcdp\M} } } */