From 6d1c2bd3ae36584af0b6d288569c845e86600bda Mon Sep 17 00:00:00 2001 From: Jakub Jelinek Date: Fri, 9 Dec 2011 21:50:40 +0100 Subject: [PATCH] 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 --- gcc/ChangeLog | 7 +++++++ gcc/tree-eh.c | 12 ++++-------- 2 files changed, 11 insertions(+), 8 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 3f3506179d45..0400f1bc8372 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2011-12-09 Jakub Jelinek + + 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. + 2011-12-09 Michael Meissner * config/rs6000/rs6000.c (altivec_expand_builtin): Call diff --git a/gcc/tree-eh.c b/gcc/tree-eh.c index 7fc850a2ae98..7ab8a90a37f5 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); -- 2.47.2