mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-04-04 22:41:34 +08:00
builtins.def (BUILT_IN_FABSD32): New DFP ABS builtin.
gcc/ * builtins.def (BUILT_IN_FABSD32): New DFP ABS builtin. (BUILT_IN_FABSD64): Likewise. (BUILT_IN_FABSD128): Likewise. * builtins.c (expand_builtin): Add support for new DFP ABS builtins. (fold_builtin_1): Likewise. * config/rs6000/dfp.md (*negtd2_fpr): Handle non-overlapping destination and source operands. (*abstd2_fpr): Likewise. (*nabstd2_fpr): Likewise. gcc/testsuite/ * gcc.target/powerpc/dfp-dd-2.c: New test. * gcc.target/powerpc/dfp-td-2.c: Likewise. * gcc.target/powerpc/dfp-td-3.c: Likewise. Co-Authored-By: Jakub Jelinek <jakub@redhat.com> From-SVN: r201849
This commit is contained in:
parent
7a3def9768
commit
e2323f5b33
@ -1,3 +1,16 @@
|
||||
2013-08-19 Peter Bergner <bergner@vnet.ibm.com>
|
||||
Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
* builtins.def (BUILT_IN_FABSD32): New DFP ABS builtin.
|
||||
(BUILT_IN_FABSD64): Likewise.
|
||||
(BUILT_IN_FABSD128): Likewise.
|
||||
* builtins.c (expand_builtin): Add support for new DFP ABS builtins.
|
||||
(fold_builtin_1): Likewise.
|
||||
* config/rs6000/dfp.md (*negtd2_fpr): Handle non-overlapping destination
|
||||
and source operands.
|
||||
(*abstd2_fpr): Likewise.
|
||||
(*nabstd2_fpr): Likewise.
|
||||
|
||||
2013-08-19 Richard Sandiford <rdsandiford@googlemail.com>
|
||||
|
||||
* config/mips/mips.c (mips_adjust_insn_length): Add checks for
|
||||
|
@ -5889,6 +5889,9 @@ expand_builtin (tree exp, rtx target, rtx subtarget, enum machine_mode mode,
|
||||
switch (fcode)
|
||||
{
|
||||
CASE_FLT_FN (BUILT_IN_FABS):
|
||||
case BUILT_IN_FABSD32:
|
||||
case BUILT_IN_FABSD64:
|
||||
case BUILT_IN_FABSD128:
|
||||
target = expand_builtin_fabs (exp, target, subtarget);
|
||||
if (target)
|
||||
return target;
|
||||
@ -10338,6 +10341,9 @@ fold_builtin_1 (location_t loc, tree fndecl, tree arg0, bool ignore)
|
||||
return fold_builtin_strlen (loc, type, arg0);
|
||||
|
||||
CASE_FLT_FN (BUILT_IN_FABS):
|
||||
case BUILT_IN_FABSD32:
|
||||
case BUILT_IN_FABSD64:
|
||||
case BUILT_IN_FABSD128:
|
||||
return fold_builtin_fabs (loc, arg0, type);
|
||||
|
||||
case BUILT_IN_ABS:
|
||||
|
@ -263,6 +263,9 @@ DEF_C99_BUILTIN (BUILT_IN_EXPM1L, "expm1l", BT_FN_LONGDOUBLE_LONGDOUBLE,
|
||||
DEF_LIB_BUILTIN (BUILT_IN_FABS, "fabs", BT_FN_DOUBLE_DOUBLE, ATTR_CONST_NOTHROW_LEAF_LIST)
|
||||
DEF_C99_C90RES_BUILTIN (BUILT_IN_FABSF, "fabsf", BT_FN_FLOAT_FLOAT, ATTR_CONST_NOTHROW_LEAF_LIST)
|
||||
DEF_C99_C90RES_BUILTIN (BUILT_IN_FABSL, "fabsl", BT_FN_LONGDOUBLE_LONGDOUBLE, ATTR_CONST_NOTHROW_LEAF_LIST)
|
||||
DEF_GCC_BUILTIN (BUILT_IN_FABSD32, "fabsd32", BT_FN_DFLOAT32_DFLOAT32, ATTR_CONST_NOTHROW_LEAF_LIST)
|
||||
DEF_GCC_BUILTIN (BUILT_IN_FABSD64, "fabsd64", BT_FN_DFLOAT64_DFLOAT64, ATTR_CONST_NOTHROW_LEAF_LIST)
|
||||
DEF_GCC_BUILTIN (BUILT_IN_FABSD128, "fabsd128", BT_FN_DFLOAT128_DFLOAT128, ATTR_CONST_NOTHROW_LEAF_LIST)
|
||||
DEF_C99_BUILTIN (BUILT_IN_FDIM, "fdim", BT_FN_DOUBLE_DOUBLE_DOUBLE, ATTR_MATHFN_FPROUNDING_ERRNO)
|
||||
DEF_C99_BUILTIN (BUILT_IN_FDIMF, "fdimf", BT_FN_FLOAT_FLOAT_FLOAT, ATTR_MATHFN_FPROUNDING_ERRNO)
|
||||
DEF_C99_BUILTIN (BUILT_IN_FDIML, "fdiml", BT_FN_LONGDOUBLE_LONGDOUBLE_LONGDOUBLE, ATTR_MATHFN_FPROUNDING_ERRNO)
|
||||
|
@ -132,11 +132,14 @@
|
||||
"")
|
||||
|
||||
(define_insn "*negtd2_fpr"
|
||||
[(set (match_operand:TD 0 "gpc_reg_operand" "=d")
|
||||
(neg:TD (match_operand:TD 1 "gpc_reg_operand" "d")))]
|
||||
[(set (match_operand:TD 0 "gpc_reg_operand" "=d,d")
|
||||
(neg:TD (match_operand:TD 1 "gpc_reg_operand" "0,d")))]
|
||||
"TARGET_HARD_FLOAT && TARGET_FPRS"
|
||||
"fneg %0,%1"
|
||||
[(set_attr "type" "fp")])
|
||||
"@
|
||||
fneg %0,%1
|
||||
fneg %0,%1\;fmr %L0,%L1"
|
||||
[(set_attr "type" "fp")
|
||||
(set_attr "length" "4,8")])
|
||||
|
||||
(define_expand "abstd2"
|
||||
[(set (match_operand:TD 0 "gpc_reg_operand" "")
|
||||
@ -145,18 +148,24 @@
|
||||
"")
|
||||
|
||||
(define_insn "*abstd2_fpr"
|
||||
[(set (match_operand:TD 0 "gpc_reg_operand" "=d")
|
||||
(abs:TD (match_operand:TD 1 "gpc_reg_operand" "d")))]
|
||||
[(set (match_operand:TD 0 "gpc_reg_operand" "=d,d")
|
||||
(abs:TD (match_operand:TD 1 "gpc_reg_operand" "0,d")))]
|
||||
"TARGET_HARD_FLOAT && TARGET_FPRS"
|
||||
"fabs %0,%1"
|
||||
[(set_attr "type" "fp")])
|
||||
"@
|
||||
fabs %0,%1
|
||||
fabs %0,%1\;fmr %L0,%L1"
|
||||
[(set_attr "type" "fp")
|
||||
(set_attr "length" "4,8")])
|
||||
|
||||
(define_insn "*nabstd2_fpr"
|
||||
[(set (match_operand:TD 0 "gpc_reg_operand" "=d")
|
||||
(neg:TD (abs:TD (match_operand:TD 1 "gpc_reg_operand" "d"))))]
|
||||
[(set (match_operand:TD 0 "gpc_reg_operand" "=d,d")
|
||||
(neg:TD (abs:TD (match_operand:TD 1 "gpc_reg_operand" "0,d"))))]
|
||||
"TARGET_HARD_FLOAT && TARGET_FPRS"
|
||||
"fnabs %0,%1"
|
||||
[(set_attr "type" "fp")])
|
||||
"@
|
||||
fnabs %0,%1
|
||||
fnabs %0,%1\;fmr %L0,%L1"
|
||||
[(set_attr "type" "fp")
|
||||
(set_attr "length" "4,8")])
|
||||
|
||||
;; Hardware support for decimal floating point operations.
|
||||
|
||||
|
@ -1,3 +1,9 @@
|
||||
2013-08-19 Peter Bergner <bergner@vnet.ibm.com>
|
||||
|
||||
* gcc.target/powerpc/dfp-dd-2.c: New test.
|
||||
* gcc.target/powerpc/dfp-td-2.c: Likewise.
|
||||
* gcc.target/powerpc/dfp-td-3.c: Likewise.
|
||||
|
||||
2013-08-19 Richard Sandiford <rdsandiford@googlemail.com>
|
||||
|
||||
* gcc.target/mips/mulsize-1.c: Check for SLL as well as SUBU.
|
||||
|
26
gcc/testsuite/gcc.target/powerpc/dfp-dd-2.c
Normal file
26
gcc/testsuite/gcc.target/powerpc/dfp-dd-2.c
Normal file
@ -0,0 +1,26 @@
|
||||
/* Test generation of DFP instructions for POWER6. */
|
||||
/* { dg-do compile { target { powerpc*-*-linux* && powerpc_fprs } } } */
|
||||
/* { dg-options "-std=gnu99 -O1 -mcpu=power6" } */
|
||||
|
||||
/* { dg-final { scan-assembler-times "fneg" 1 } } */
|
||||
/* { dg-final { scan-assembler-times "fabs" 1 } } */
|
||||
/* { dg-final { scan-assembler-times "fnabs" 1 } } */
|
||||
/* { dg-final { scan-assembler-times "fmr" 0 } } */
|
||||
|
||||
_Decimal64
|
||||
func1 (_Decimal64 a, _Decimal64 b)
|
||||
{
|
||||
return -b;
|
||||
}
|
||||
|
||||
_Decimal64
|
||||
func2 (_Decimal64 a, _Decimal64 b)
|
||||
{
|
||||
return __builtin_fabsd64 (b);
|
||||
}
|
||||
|
||||
_Decimal64
|
||||
func3 (_Decimal64 a, _Decimal64 b)
|
||||
{
|
||||
return - __builtin_fabsd64 (b);
|
||||
}
|
29
gcc/testsuite/gcc.target/powerpc/dfp-td-2.c
Normal file
29
gcc/testsuite/gcc.target/powerpc/dfp-td-2.c
Normal file
@ -0,0 +1,29 @@
|
||||
/* Test generation of DFP instructions for POWER6. */
|
||||
/* { dg-do compile { target { powerpc*-*-linux* && powerpc_fprs } } } */
|
||||
/* { dg-options "-std=gnu99 -O1 -mcpu=power6" } */
|
||||
|
||||
/* { dg-final { scan-assembler-times "fneg" 1 } } */
|
||||
/* { dg-final { scan-assembler-times "fabs" 1 } } */
|
||||
/* { dg-final { scan-assembler-times "fnabs" 1 } } */
|
||||
/* { dg-final { scan-assembler-times "fmr" 0 } } */
|
||||
|
||||
/* These tests verify we only generate fneg, fabs and fnabs
|
||||
instructions and no fmr's since these are done in place. */
|
||||
|
||||
_Decimal128
|
||||
func1 (_Decimal128 a)
|
||||
{
|
||||
return -a;
|
||||
}
|
||||
|
||||
_Decimal128
|
||||
func2 (_Decimal128 a)
|
||||
{
|
||||
return __builtin_fabsd128 (a);
|
||||
}
|
||||
|
||||
_Decimal128
|
||||
func3 (_Decimal128 a)
|
||||
{
|
||||
return - __builtin_fabsd128 (a);
|
||||
}
|
29
gcc/testsuite/gcc.target/powerpc/dfp-td-3.c
Normal file
29
gcc/testsuite/gcc.target/powerpc/dfp-td-3.c
Normal file
@ -0,0 +1,29 @@
|
||||
/* Test generation of DFP instructions for POWER6. */
|
||||
/* { dg-do compile { target { powerpc*-*-linux* && powerpc_fprs } } } */
|
||||
/* { dg-options "-std=gnu99 -O1 -mcpu=power6" } */
|
||||
|
||||
/* { dg-final { scan-assembler-times "fneg" 1 } } */
|
||||
/* { dg-final { scan-assembler-times "fabs" 1 } } */
|
||||
/* { dg-final { scan-assembler-times "fnabs" 1 } } */
|
||||
/* { dg-final { scan-assembler-times "fmr" 3 } } */
|
||||
|
||||
/* These tests verify we generate fneg, fabs and fnabs and
|
||||
associated fmr's since these are not done in place. */
|
||||
|
||||
_Decimal128
|
||||
func1 (_Decimal128 a, _Decimal128 b)
|
||||
{
|
||||
return -b;
|
||||
}
|
||||
|
||||
_Decimal128
|
||||
func2 (_Decimal128 a, _Decimal128 b)
|
||||
{
|
||||
return __builtin_fabsd128 (b);
|
||||
}
|
||||
|
||||
_Decimal128
|
||||
func3 (_Decimal128 a, _Decimal128 b)
|
||||
{
|
||||
return - __builtin_fabsd128 (b);
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user