aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-eh.c
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2011-12-09 21:50:40 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2011-12-09 21:50:40 +0100
commit6d1c2bd3ae36584af0b6d288569c845e86600bda (patch)
tree22a69ae33ba4ffc6a1ac60035349486476a0bdd2 /gcc/tree-eh.c
parentd179d1790729f3be184bab0cf5c4d9e5380f0814 (diff)
downloadgcc-6d1c2bd3ae36584af0b6d288569c845e86600bda.zip
gcc-6d1c2bd3ae36584af0b6d288569c845e86600bda.tar.gz
gcc-6d1c2bd3ae36584af0b6d288569c845e86600bda.tar.bz2
re PR tree-optimization/51117 (rev.181172 causes glibc build failure)
PR tree-optimization/51117 * tree-eh.c (optimize_clobbers): Don't remove just one clobber, but all consecutive clobbers before RESX. Use gimple_clobber_p predicate. From-SVN: r182177
Diffstat (limited to 'gcc/tree-eh.c')
-rw-r--r--gcc/tree-eh.c12
1 files changed, 4 insertions, 8 deletions
diff --git a/gcc/tree-eh.c b/gcc/tree-eh.c
index 7fc850a..7ab8a90 100644
--- a/gcc/tree-eh.c
+++ b/gcc/tree-eh.c
@@ -3180,17 +3180,13 @@ static void
optimize_clobbers (basic_block bb)
{
gimple_stmt_iterator gsi = gsi_last_bb (bb);
- for (gsi_prev (&gsi); !gsi_end_p (gsi);)
+ for (gsi_prev (&gsi); !gsi_end_p (gsi); gsi_prev (&gsi))
{
gimple stmt = gsi_stmt (gsi);
if (is_gimple_debug (stmt))
- {
- gsi_prev (&gsi);
- continue;
- }
- if (!gimple_assign_single_p (stmt)
- || TREE_CODE (gimple_assign_lhs (stmt)) == SSA_NAME
- || !TREE_CLOBBER_P (gimple_assign_rhs1 (stmt)))
+ continue;
+ if (!gimple_clobber_p (stmt)
+ || TREE_CODE (gimple_assign_lhs (stmt)) == SSA_NAME)
return;
unlink_stmt_vdef (stmt);
gsi_remove (&gsi, true);