diff options
author | Jakub Jelinek <jakub@redhat.com> | 2014-01-13 20:14:03 +0100 |
---|---|---|
committer | Jakub Jelinek <jakub@gcc.gnu.org> | 2014-01-13 20:14:03 +0100 |
commit | 19e51b409e89cb13f388bf2442e3d00b904dddde (patch) | |
tree | 3287f7d4ff23c203c29bc715bc7a4141b0081b4c /gcc/tree-ssa-loop-im.c | |
parent | cd794ed4c2424b3381a5fb09c6f08e53ae919a8a (diff) | |
download | gcc-19e51b409e89cb13f388bf2442e3d00b904dddde.zip gcc-19e51b409e89cb13f388bf2442e3d00b904dddde.tar.gz gcc-19e51b409e89cb13f388bf2442e3d00b904dddde.tar.bz2 |
re PR tree-optimization/59387 (wrong code (hangs) at -Os on x86_64-linux-gnu)
PR tree-optimization/59387
* tree-scalar-evolution.c: Include gimple-fold.h and gimplify-me.h.
(scev_const_prop): If folded_casts and type has undefined overflow,
use force_gimple_operand instead of force_gimple_operand_gsi and
for each added stmt if it is assign with
arith_code_with_undefined_signed_overflow, call
rewrite_to_defined_overflow.
* tree-ssa-loop-im.c: Don't include gimplify-me.h, include
gimple-fold.h instead.
(arith_code_with_undefined_signed_overflow,
rewrite_to_defined_overflow): Moved to ...
* gimple-fold.c (arith_code_with_undefined_signed_overflow,
rewrite_to_defined_overflow): ... here. No longer static.
Include gimplify-me.h.
* gimple-fold.h (arith_code_with_undefined_signed_overflow,
rewrite_to_defined_overflow): New prototypes.
* gcc.c-torture/execute/pr59387.c: New test.
From-SVN: r206583
Diffstat (limited to 'gcc/tree-ssa-loop-im.c')
-rw-r--r-- | gcc/tree-ssa-loop-im.c | 63 |
1 files changed, 1 insertions, 62 deletions
diff --git a/gcc/tree-ssa-loop-im.c b/gcc/tree-ssa-loop-im.c index 7bd0605..c545502 100644 --- a/gcc/tree-ssa-loop-im.c +++ b/gcc/tree-ssa-loop-im.c @@ -35,7 +35,6 @@ along with GCC; see the file COPYING3. If not see #include "gimple.h" #include "gimplify.h" #include "gimple-iterator.h" -#include "gimplify-me.h" #include "gimple-ssa.h" #include "tree-cfg.h" #include "tree-phinodes.h" @@ -53,6 +52,7 @@ along with GCC; see the file COPYING3. If not see #include "tree-affine.h" #include "tree-ssa-propagate.h" #include "trans-mem.h" +#include "gimple-fold.h" /* TODO: Support for predicated code motion. I.e. @@ -1135,67 +1135,6 @@ public: unsigned int todo_; }; -/* Return true if CODE is an operation that when operating on signed - integer types involves undefined behavior on overflow and the - operation can be expressed with unsigned arithmetic. */ - -static bool -arith_code_with_undefined_signed_overflow (tree_code code) -{ - switch (code) - { - case PLUS_EXPR: - case MINUS_EXPR: - case MULT_EXPR: - case NEGATE_EXPR: - case POINTER_PLUS_EXPR: - return true; - default: - return false; - } -} - -/* Rewrite STMT, an assignment with a signed integer or pointer arithmetic - operation that can be transformed to unsigned arithmetic by converting - its operand, carrying out the operation in the corresponding unsigned - type and converting the result back to the original type. - - Returns a sequence of statements that replace STMT and also contain - a modified form of STMT itself. */ - -static gimple_seq -rewrite_to_defined_overflow (gimple stmt) -{ - if (dump_file && (dump_flags & TDF_DETAILS)) - { - fprintf (dump_file, "rewriting stmt with undefined signed " - "overflow "); - print_gimple_stmt (dump_file, stmt, 0, TDF_SLIM); - } - - tree lhs = gimple_assign_lhs (stmt); - tree type = unsigned_type_for (TREE_TYPE (lhs)); - gimple_seq stmts = NULL; - for (unsigned i = 1; i < gimple_num_ops (stmt); ++i) - { - gimple_seq stmts2 = NULL; - gimple_set_op (stmt, i, - force_gimple_operand (fold_convert (type, - gimple_op (stmt, i)), - &stmts2, true, NULL_TREE)); - gimple_seq_add_seq (&stmts, stmts2); - } - gimple_assign_set_lhs (stmt, make_ssa_name (type, stmt)); - if (gimple_assign_rhs_code (stmt) == POINTER_PLUS_EXPR) - gimple_assign_set_rhs_code (stmt, PLUS_EXPR); - gimple_seq_add_stmt (&stmts, stmt); - gimple cvt = gimple_build_assign_with_ops - (NOP_EXPR, lhs, gimple_assign_lhs (stmt), NULL_TREE); - gimple_seq_add_stmt (&stmts, cvt); - - return stmts; -} - /* Hoist the statements in basic block BB out of the loops prescribed by data stored in LIM_DATA structures associated with each statement. Callback for walk_dominator_tree. */ |