Clean an inconsistency with -ffinite-math-only.
Backported from the gcc-4_3-branch, revision 118001, under the GPLv2. This issue was also fixed in Apple's gcc. PR: 157025 Reviewed by: mm Approved by: jhb (mentor) MFC: 2 weeks
This commit is contained in:
parent
855291741d
commit
4ee8547efb
@ -96,6 +96,14 @@
|
|||||||
|
|
||||||
* doc/invoke.texi: Add entry about geode processor.
|
* doc/invoke.texi: Add entry about geode processor.
|
||||||
|
|
||||||
|
2006-10-24 Richard Guenther <rguenther@suse.de>
|
||||||
|
|
||||||
|
PR middle-end/28796
|
||||||
|
* builtins.c (fold_builtin_classify): Use HONOR_INFINITIES
|
||||||
|
and HONOR_NANS instead of MODE_HAS_INFINITIES and MODE_HAS_NANS
|
||||||
|
for deciding optimizations in consistency with fold-const.c
|
||||||
|
(fold_builtin_unordered_cmp): Likewise.
|
||||||
|
|
||||||
2006-10-22 H.J. Lu <hongjiu.lu@intel.com> (r117958)
|
2006-10-22 H.J. Lu <hongjiu.lu@intel.com> (r117958)
|
||||||
|
|
||||||
* config.gcc (i[34567]86-*-*): Add tmmintrin.h to extra_headers.
|
* config.gcc (i[34567]86-*-*): Add tmmintrin.h to extra_headers.
|
||||||
|
@ -8720,7 +8720,7 @@ fold_builtin_classify (tree fndecl, tree arglist, int builtin_index)
|
|||||||
switch (builtin_index)
|
switch (builtin_index)
|
||||||
{
|
{
|
||||||
case BUILT_IN_ISINF:
|
case BUILT_IN_ISINF:
|
||||||
if (!MODE_HAS_INFINITIES (TYPE_MODE (TREE_TYPE (arg))))
|
if (!HONOR_INFINITIES (TYPE_MODE (TREE_TYPE (arg))))
|
||||||
return omit_one_operand (type, integer_zero_node, arg);
|
return omit_one_operand (type, integer_zero_node, arg);
|
||||||
|
|
||||||
if (TREE_CODE (arg) == REAL_CST)
|
if (TREE_CODE (arg) == REAL_CST)
|
||||||
@ -8736,8 +8736,8 @@ fold_builtin_classify (tree fndecl, tree arglist, int builtin_index)
|
|||||||
return NULL_TREE;
|
return NULL_TREE;
|
||||||
|
|
||||||
case BUILT_IN_FINITE:
|
case BUILT_IN_FINITE:
|
||||||
if (!MODE_HAS_NANS (TYPE_MODE (TREE_TYPE (arg)))
|
if (!HONOR_NANS (TYPE_MODE (TREE_TYPE (arg)))
|
||||||
&& !MODE_HAS_INFINITIES (TYPE_MODE (TREE_TYPE (arg))))
|
&& !HONOR_INFINITIES (TYPE_MODE (TREE_TYPE (arg))))
|
||||||
return omit_one_operand (type, integer_zero_node, arg);
|
return omit_one_operand (type, integer_zero_node, arg);
|
||||||
|
|
||||||
if (TREE_CODE (arg) == REAL_CST)
|
if (TREE_CODE (arg) == REAL_CST)
|
||||||
@ -8750,7 +8750,7 @@ fold_builtin_classify (tree fndecl, tree arglist, int builtin_index)
|
|||||||
return NULL_TREE;
|
return NULL_TREE;
|
||||||
|
|
||||||
case BUILT_IN_ISNAN:
|
case BUILT_IN_ISNAN:
|
||||||
if (!MODE_HAS_NANS (TYPE_MODE (TREE_TYPE (arg))))
|
if (!HONOR_NANS (TYPE_MODE (TREE_TYPE (arg))))
|
||||||
return omit_one_operand (type, integer_zero_node, arg);
|
return omit_one_operand (type, integer_zero_node, arg);
|
||||||
|
|
||||||
if (TREE_CODE (arg) == REAL_CST)
|
if (TREE_CODE (arg) == REAL_CST)
|
||||||
@ -8833,13 +8833,13 @@ fold_builtin_unordered_cmp (tree fndecl, tree arglist,
|
|||||||
|
|
||||||
if (unordered_code == UNORDERED_EXPR)
|
if (unordered_code == UNORDERED_EXPR)
|
||||||
{
|
{
|
||||||
if (!MODE_HAS_NANS (TYPE_MODE (TREE_TYPE (arg0))))
|
if (!HONOR_NANS (TYPE_MODE (TREE_TYPE (arg0))))
|
||||||
return omit_two_operands (type, integer_zero_node, arg0, arg1);
|
return omit_two_operands (type, integer_zero_node, arg0, arg1);
|
||||||
return fold_build2 (UNORDERED_EXPR, type, arg0, arg1);
|
return fold_build2 (UNORDERED_EXPR, type, arg0, arg1);
|
||||||
}
|
}
|
||||||
|
|
||||||
code = MODE_HAS_NANS (TYPE_MODE (TREE_TYPE (arg0))) ? unordered_code
|
code = HONOR_NANS (TYPE_MODE (TREE_TYPE (arg0))) ? unordered_code
|
||||||
: ordered_code;
|
: ordered_code;
|
||||||
return fold_build1 (TRUTH_NOT_EXPR, type,
|
return fold_build1 (TRUTH_NOT_EXPR, type,
|
||||||
fold_build2 (code, type, arg0, arg1));
|
fold_build2 (code, type, arg0, arg1));
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user