From 472945f6d292c19eaf74b153311a935b362f097b Mon Sep 17 00:00:00 2001 From: Jeff Law Date: Wed, 18 May 2005 10:49:49 -0600 Subject: [PATCH] tree-ssa-forwprop.c (forward_propagate_addr_expr): Do not propagate an ADDR_EXPR if the definition and use sites are in different... * tree-ssa-forwprop.c (forward_propagate_addr_expr): Do not propagate an ADDR_EXPR if the definition and use sites are in different EH regions. From-SVN: r99906 --- gcc/ChangeLog | 6 ++++++ gcc/tree-ssa-forwprop.c | 5 +++++ 2 files changed, 11 insertions(+) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index a112e174ab2..acc2bcb0610 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2005-05-18 Jeff Law + + * tree-ssa-forwprop.c (forward_propagate_addr_expr): Do not + propagate an ADDR_EXPR if the definition and use sites are + in different EH regions. + 2005-05-18 Ian Lance Taylor * read-rtl.c (mode_attr_index): Use obstack_grow0, not diff --git a/gcc/tree-ssa-forwprop.c b/gcc/tree-ssa-forwprop.c index fb3dcaf6ea8..f65df577cb3 100644 --- a/gcc/tree-ssa-forwprop.c +++ b/gcc/tree-ssa-forwprop.c @@ -537,6 +537,11 @@ forward_propagate_addr_expr (tree stmt) if (bb_for_stmt (use_stmt)->loop_depth > stmt_loop_depth) return false; + /* If the two statements belong to different EH regions, then there + is nothing we can or should try to do. */ + if (lookup_stmt_eh_region (use_stmt) != lookup_stmt_eh_region (stmt)) + return false; + /* Strip away any outer COMPONENT_REF/ARRAY_REF nodes from the LHS. */ lhs = TREE_OPERAND (use_stmt, 0); while (TREE_CODE (lhs) == COMPONENT_REF || TREE_CODE (lhs) == ARRAY_REF) -- 2.30.2