optabs.h (enum optab_index): Add new OTI_tan and OTI_atan.
* optabs.h (enum optab_index): Add new OTI_tan and OTI_atan. (tan_optab, atan_optab): Define corresponding macros. * optabs.c (init_optabs): Initialize tan_optab and atan_optab. * genopinit.c (optabs): Implement tan_optab and atan_optab using tan?f2 and atan?f2 patterns. * builtins.c (expand_builtin_mathfn): Handle BUILT_IN_TAN{,F,L} using tan_optab, and BUILT_IN_ATAN{,F,L} using atan_optab. Change the default value of errno_set to false. (expand_builtin): Expand BUILT_IN_TAN{,F,L} and BUILT_IN_ATAN{,F,L} using expand_builtin_mathfn. * config/i386/i386.md (atansf2, atandf2, atanxf2, atantf2): New expander patterns implemented using existing atan2?f3 patterns. * gcc.dg/i386-387-5.c: New test case. * gcc.dg/i386-387-6.c: New test case. * gcc.dg/builtins-23.c: New test case. From-SVN: r68013
This commit is contained in:
parent
c6547c920b
commit
82d397c794
|
@ -1,3 +1,19 @@
|
|||
2003-06-16 Roger Sayle <roger@eyesopen.com>
|
||||
|
||||
* optabs.h (enum optab_index): Add new OTI_tan and OTI_atan.
|
||||
(tan_optab, atan_optab): Define corresponding macros.
|
||||
* optabs.c (init_optabs): Initialize tan_optab and atan_optab.
|
||||
* genopinit.c (optabs): Implement tan_optab and atan_optab
|
||||
using tan?f2 and atan?f2 patterns.
|
||||
* builtins.c (expand_builtin_mathfn): Handle BUILT_IN_TAN{,F,L}
|
||||
using tan_optab, and BUILT_IN_ATAN{,F,L} using atan_optab.
|
||||
Change the default value of errno_set to false.
|
||||
(expand_builtin): Expand BUILT_IN_TAN{,F,L} and BUILT_IN_ATAN{,F,L}
|
||||
using expand_builtin_mathfn.
|
||||
|
||||
* config/i386/i386.md (atansf2, atandf2, atanxf2, atantf2): New
|
||||
expander patterns implemented using existing atan2?f3 patterns.
|
||||
|
||||
2003-06-16 Roger Sayle <roger@eyesopen.com>
|
||||
|
||||
* expr.c (expand_expr <PLUS_EXPR>): If operand_equal_p considers
|
||||
|
|
|
@ -1702,7 +1702,7 @@ expand_builtin_mathfn (tree exp, rtx target, rtx subtarget)
|
|||
tree fndecl = TREE_OPERAND (TREE_OPERAND (exp, 0), 0);
|
||||
tree arglist = TREE_OPERAND (exp, 1);
|
||||
enum machine_mode argmode;
|
||||
bool errno_set = true;
|
||||
bool errno_set = false;
|
||||
|
||||
if (!validate_arglist (arglist, REAL_TYPE, VOID_TYPE))
|
||||
return 0;
|
||||
|
@ -1744,35 +1744,43 @@ expand_builtin_mathfn (tree exp, rtx target, rtx subtarget)
|
|||
case BUILT_IN_SQRT:
|
||||
case BUILT_IN_SQRTF:
|
||||
case BUILT_IN_SQRTL:
|
||||
builtin_optab = sqrt_optab; break;
|
||||
errno_set = true; builtin_optab = sqrt_optab; break;
|
||||
case BUILT_IN_EXP:
|
||||
case BUILT_IN_EXPF:
|
||||
case BUILT_IN_EXPL:
|
||||
builtin_optab = exp_optab; break;
|
||||
errno_set = true; builtin_optab = exp_optab; break;
|
||||
case BUILT_IN_LOG:
|
||||
case BUILT_IN_LOGF:
|
||||
case BUILT_IN_LOGL:
|
||||
builtin_optab = log_optab; break;
|
||||
errno_set = true; builtin_optab = log_optab; break;
|
||||
case BUILT_IN_TAN:
|
||||
case BUILT_IN_TANF:
|
||||
case BUILT_IN_TANL:
|
||||
builtin_optab = tan_optab; break;
|
||||
case BUILT_IN_ATAN:
|
||||
case BUILT_IN_ATANF:
|
||||
case BUILT_IN_ATANL:
|
||||
builtin_optab = atan_optab; break;
|
||||
case BUILT_IN_FLOOR:
|
||||
case BUILT_IN_FLOORF:
|
||||
case BUILT_IN_FLOORL:
|
||||
errno_set = false ; builtin_optab = floor_optab; break;
|
||||
builtin_optab = floor_optab; break;
|
||||
case BUILT_IN_CEIL:
|
||||
case BUILT_IN_CEILF:
|
||||
case BUILT_IN_CEILL:
|
||||
errno_set = false ; builtin_optab = ceil_optab; break;
|
||||
builtin_optab = ceil_optab; break;
|
||||
case BUILT_IN_TRUNC:
|
||||
case BUILT_IN_TRUNCF:
|
||||
case BUILT_IN_TRUNCL:
|
||||
errno_set = false ; builtin_optab = trunc_optab; break;
|
||||
builtin_optab = trunc_optab; break;
|
||||
case BUILT_IN_ROUND:
|
||||
case BUILT_IN_ROUNDF:
|
||||
case BUILT_IN_ROUNDL:
|
||||
errno_set = false ; builtin_optab = round_optab; break;
|
||||
builtin_optab = round_optab; break;
|
||||
case BUILT_IN_NEARBYINT:
|
||||
case BUILT_IN_NEARBYINTF:
|
||||
case BUILT_IN_NEARBYINTL:
|
||||
errno_set = false ; builtin_optab = nearbyint_optab; break;
|
||||
builtin_optab = nearbyint_optab; break;
|
||||
default:
|
||||
abort ();
|
||||
}
|
||||
|
@ -4416,6 +4424,12 @@ expand_builtin (tree exp, rtx target, rtx subtarget, enum machine_mode mode,
|
|||
case BUILT_IN_LOG:
|
||||
case BUILT_IN_LOGF:
|
||||
case BUILT_IN_LOGL:
|
||||
case BUILT_IN_TAN:
|
||||
case BUILT_IN_TANF:
|
||||
case BUILT_IN_TANL:
|
||||
case BUILT_IN_ATAN:
|
||||
case BUILT_IN_ATANF:
|
||||
case BUILT_IN_ATANL:
|
||||
/* Treat these like sqrt only if unsafe math optimizations are allowed,
|
||||
because of possible accuracy problems. */
|
||||
if (! flag_unsafe_math_optimizations)
|
||||
|
|
|
@ -15855,6 +15855,58 @@
|
|||
emit_move_insn (operands[2], temp);
|
||||
emit_move_insn (operands[7], CONST1_RTX (XFmode)); /* fld1 */
|
||||
})
|
||||
|
||||
(define_expand "atansf2"
|
||||
[(parallel [(set (match_operand:SF 0 "register_operand" "")
|
||||
(unspec:SF [(match_dup 2)
|
||||
(match_operand:SF 1 "register_operand" "")]
|
||||
UNSPEC_FPATAN))
|
||||
(clobber (match_dup 1))])]
|
||||
"! TARGET_NO_FANCY_MATH_387 && TARGET_80387
|
||||
&& flag_unsafe_math_optimizations"
|
||||
{
|
||||
operands[2] = gen_reg_rtx (SFmode);
|
||||
emit_move_insn (operands[2], CONST1_RTX (SFmode)); /* fld1 */
|
||||
})
|
||||
|
||||
(define_expand "atandf2"
|
||||
[(parallel [(set (match_operand:DF 0 "register_operand" "")
|
||||
(unspec:DF [(match_dup 2)
|
||||
(match_operand:DF 1 "register_operand" "")]
|
||||
UNSPEC_FPATAN))
|
||||
(clobber (match_dup 1))])]
|
||||
"! TARGET_NO_FANCY_MATH_387 && TARGET_80387
|
||||
&& flag_unsafe_math_optimizations"
|
||||
{
|
||||
operands[2] = gen_reg_rtx (DFmode);
|
||||
emit_move_insn (operands[2], CONST1_RTX (DFmode)); /* fld1 */
|
||||
})
|
||||
|
||||
(define_expand "atanxf2"
|
||||
[(parallel [(set (match_operand:XF 0 "register_operand" "")
|
||||
(unspec:XF [(match_dup 2)
|
||||
(match_operand:XF 1 "register_operand" "")]
|
||||
UNSPEC_FPATAN))
|
||||
(clobber (match_dup 1))])]
|
||||
"! TARGET_NO_FANCY_MATH_387 && TARGET_80387
|
||||
&& flag_unsafe_math_optimizations"
|
||||
{
|
||||
operands[2] = gen_reg_rtx (XFmode);
|
||||
emit_move_insn (operands[2], CONST1_RTX (XFmode)); /* fld1 */
|
||||
})
|
||||
|
||||
(define_expand "atantf2"
|
||||
[(parallel [(set (match_operand:TF 0 "register_operand" "")
|
||||
(unspec:TF [(match_dup 2)
|
||||
(match_operand:TF 1 "register_operand" "")]
|
||||
UNSPEC_FPATAN))
|
||||
(clobber (match_dup 1))])]
|
||||
"! TARGET_NO_FANCY_MATH_387 && TARGET_80387
|
||||
&& flag_unsafe_math_optimizations"
|
||||
{
|
||||
operands[2] = gen_reg_rtx (TFmode);
|
||||
emit_move_insn (operands[2], CONST1_RTX (TFmode)); /* fld1 */
|
||||
})
|
||||
|
||||
;; Block operation instructions
|
||||
|
||||
|
|
|
@ -125,6 +125,8 @@ static const char * const optabs[] =
|
|||
"cos_optab->handlers[$A].insn_code = CODE_FOR_$(cos$a2$)",
|
||||
"exp_optab->handlers[$A].insn_code = CODE_FOR_$(exp$a2$)",
|
||||
"log_optab->handlers[$A].insn_code = CODE_FOR_$(log$a2$)",
|
||||
"tan_optab->handlers[$A].insn_code = CODE_FOR_$(tan$a2$)",
|
||||
"atan_optab->handlers[$A].insn_code = CODE_FOR_$(atan$a2$)",
|
||||
"strlen_optab->handlers[$A].insn_code = CODE_FOR_$(strlen$a$)",
|
||||
"one_cmpl_optab->handlers[$A].insn_code = CODE_FOR_$(one_cmpl$a2$)",
|
||||
"ffs_optab->handlers[$A].insn_code = CODE_FOR_$(ffs$a2$)",
|
||||
|
|
|
@ -5557,6 +5557,8 @@ init_optabs ()
|
|||
cos_optab = init_optab (UNKNOWN);
|
||||
exp_optab = init_optab (UNKNOWN);
|
||||
log_optab = init_optab (UNKNOWN);
|
||||
tan_optab = init_optab (UNKNOWN);
|
||||
atan_optab = init_optab (UNKNOWN);
|
||||
strlen_optab = init_optab (UNKNOWN);
|
||||
cbranch_optab = init_optab (UNKNOWN);
|
||||
cmov_optab = init_optab (UNKNOWN);
|
||||
|
|
|
@ -149,6 +149,10 @@ enum optab_index
|
|||
OTI_trunc,
|
||||
OTI_round,
|
||||
OTI_nearbyint,
|
||||
/* Tangent */
|
||||
OTI_tan,
|
||||
/* Inverse tangent */
|
||||
OTI_atan,
|
||||
|
||||
/* Compare insn; two operands. */
|
||||
OTI_cmp,
|
||||
|
@ -232,6 +236,8 @@ extern GTY(()) optab optab_table[OTI_MAX];
|
|||
#define trunc_optab (optab_table[OTI_trunc])
|
||||
#define round_optab (optab_table[OTI_round])
|
||||
#define nearbyint_optab (optab_table[OTI_nearbyint])
|
||||
#define tan_optab (optab_table[OTI_tan])
|
||||
#define atan_optab (optab_table[OTI_atan])
|
||||
|
||||
#define cmp_optab (optab_table[OTI_cmp])
|
||||
#define ucmp_optab (optab_table[OTI_ucmp])
|
||||
|
|
|
@ -1,3 +1,9 @@
|
|||
2003-06-16 Roger Sayle <roger@eyesopen.com>
|
||||
|
||||
* gcc.dg/i386-387-5.c: New test case.
|
||||
* gcc.dg/i386-387-6.c: New test case.
|
||||
* gcc.dg/builtins-23.c: New test case.
|
||||
|
||||
2003-06-15 Roger Sayle <roger@eyesopen.com>
|
||||
|
||||
* gcc.dg/builtins-22.c: New test case.
|
||||
|
|
|
@ -0,0 +1,12 @@
|
|||
/* Related to PR optimization/10764 */
|
||||
|
||||
/* { dg-do compile } */
|
||||
/* { dg-options "-O2 -ffast-math" } */
|
||||
|
||||
double atan(double x);
|
||||
|
||||
double foo(double x)
|
||||
{
|
||||
return atan(atan(x));
|
||||
}
|
||||
|
|
@ -0,0 +1,7 @@
|
|||
/* Verify that -mno-fancy-math-387 works. */
|
||||
/* { dg-do compile { target "i?86-*-*" } } */
|
||||
/* { dg-options "-O -ffast-math -mfpmath=387 -mno-fancy-math-387" } */
|
||||
/* { dg-final { scan-assembler "call\t_?atan" } } */
|
||||
|
||||
double f1(double x) { return __builtin_atan(x); }
|
||||
|
|
@ -0,0 +1,6 @@
|
|||
/* Verify that -march overrides -mno-fancy-math-387. */
|
||||
/* { dg-do compile { target "i?86-*-*" } } */
|
||||
/* { dg-options "-O -ffast-math -mfpmath=387 -march=i686 -mno-fancy-math-387" } */
|
||||
/* { dg-final { scan-assembler "fpatan" } } */
|
||||
|
||||
double f1(double x) { return __builtin_atan(x); }
|
Loading…
Reference in New Issue