Commit 23f27839 by Richard Biener Committed by Richard Biener

re PR middle-end/69854 (ICE: tree check: expected class 'constant', have…

re PR middle-end/69854 (ICE: tree check: expected class 'constant', have 'binary' (plus_expr) in generic_simplify_65, at generic-match.c:3110)

2016-02-18  Richard Biener  <rguenther@suse.de>

	PR middle-end/69854
	* match.pd: Don't use fold_binary or fold_unary for folding
	constants.

	* gcc.dg/torture/pr69854.c: New testcase.

From-SVN: r233516
parent 43414a5d
2016-02-18 Richard Biener <rguenther@suse.de>
PR middle-end/69854
* match.pd: Don't use fold_binary or fold_unary for folding
constants.
2016-02-17 Jakub Jelinek <jakub@redhat.com> 2016-02-17 Jakub Jelinek <jakub@redhat.com>
PR c++/69850 PR c++/69850
......
...@@ -1063,7 +1063,7 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT) ...@@ -1063,7 +1063,7 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
/* If the constant operation overflows we cannot do the transform /* If the constant operation overflows we cannot do the transform
as we would introduce undefined overflow, for example as we would introduce undefined overflow, for example
with (a - 1) + INT_MIN. */ with (a - 1) + INT_MIN. */
(with { tree cst = fold_binary (outer_op == inner_op (with { tree cst = const_binop (outer_op == inner_op
? PLUS_EXPR : MINUS_EXPR, type, @1, @2); } ? PLUS_EXPR : MINUS_EXPR, type, @1, @2); }
(if (cst && !TREE_OVERFLOW (cst)) (if (cst && !TREE_OVERFLOW (cst))
(inner_op @0 { cst; } )))))) (inner_op @0 { cst; } ))))))
...@@ -1072,7 +1072,7 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT) ...@@ -1072,7 +1072,7 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
(for outer_op (plus minus) (for outer_op (plus minus)
(simplify (simplify
(outer_op (minus CONSTANT_CLASS_P@1 @0) CONSTANT_CLASS_P@2) (outer_op (minus CONSTANT_CLASS_P@1 @0) CONSTANT_CLASS_P@2)
(with { tree cst = fold_binary (outer_op, type, @1, @2); } (with { tree cst = const_binop (outer_op, type, @1, @2); }
(if (cst && !TREE_OVERFLOW (cst)) (if (cst && !TREE_OVERFLOW (cst))
(minus { cst; } @0))))) (minus { cst; } @0)))))
...@@ -1270,7 +1270,7 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT) ...@@ -1270,7 +1270,7 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
RROTATE_EXPR by a new constant. */ RROTATE_EXPR by a new constant. */
(simplify (simplify
(lrotate @0 INTEGER_CST@1) (lrotate @0 INTEGER_CST@1)
(rrotate @0 { fold_binary (MINUS_EXPR, TREE_TYPE (@1), (rrotate @0 { const_binop (MINUS_EXPR, TREE_TYPE (@1),
build_int_cst (TREE_TYPE (@1), build_int_cst (TREE_TYPE (@1),
element_precision (type)), @1); })) element_precision (type)), @1); }))
...@@ -1596,7 +1596,7 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT) ...@@ -1596,7 +1596,7 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
(simplify (simplify
(plus @0 REAL_CST@1) (plus @0 REAL_CST@1)
(if (REAL_VALUE_NEGATIVE (TREE_REAL_CST (@1))) (if (REAL_VALUE_NEGATIVE (TREE_REAL_CST (@1)))
(with { tree tem = fold_unary (NEGATE_EXPR, type, @1); } (with { tree tem = const_unop (NEGATE_EXPR, type, @1); }
(if (!TREE_OVERFLOW (tem) || !flag_trapping_math) (if (!TREE_OVERFLOW (tem) || !flag_trapping_math)
(minus @0 { tem; }))))) (minus @0 { tem; })))))
...@@ -2149,7 +2149,7 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT) ...@@ -2149,7 +2149,7 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
(if (FLOAT_TYPE_P (TREE_TYPE (@0)) (if (FLOAT_TYPE_P (TREE_TYPE (@0))
|| (ANY_INTEGRAL_TYPE_P (TREE_TYPE (@0)) || (ANY_INTEGRAL_TYPE_P (TREE_TYPE (@0))
&& TYPE_OVERFLOW_UNDEFINED (TREE_TYPE (@0)))) && TYPE_OVERFLOW_UNDEFINED (TREE_TYPE (@0))))
(with { tree tem = fold_unary (NEGATE_EXPR, TREE_TYPE (@0), @1); } (with { tree tem = const_unop (NEGATE_EXPR, TREE_TYPE (@0), @1); }
(if (tem && !TREE_OVERFLOW (tem)) (if (tem && !TREE_OVERFLOW (tem))
(scmp @0 { tem; })))))) (scmp @0 { tem; }))))))
......
2016-02-18 Richard Biener <rguenther@suse.de>
PR middle-end/69854
* gcc.dg/torture/pr69854.c: New testcase.
2016-02-17 Jakub Jelinek <jakub@redhat.com> 2016-02-17 Jakub Jelinek <jakub@redhat.com>
PR c++/69850 PR c++/69850
......
/* { dg-do compile } */
/* { dg-additional-options "-frounding-math -ffast-math" } */
double fn1()
{
double w, s = fn1() - 6.12323399573676603587e17;
return 1.57079632679489655800e00 - (s + w);
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment