aboutsummaryrefslogtreecommitdiff
path: root/gcc/cfgrtl.c
diff options
context:
space:
mode:
authorMark Mitchell <mark@codesourcery.com>2002-05-16 17:04:55 +0000
committerMark Mitchell <mmitchel@gcc.gnu.org>2002-05-16 17:04:55 +0000
commit5a566bed2b7e0133247fa9fb3282116a8405dd3f (patch)
tree824f1fd2ba2be6b766d13a1d7de9d099554c905d /gcc/cfgrtl.c
parent48f6efae63cc3e9a8c8ab48bcbe2677256ac55d5 (diff)
downloadgcc-5a566bed2b7e0133247fa9fb3282116a8405dd3f.zip
gcc-5a566bed2b7e0133247fa9fb3282116a8405dd3f.tar.gz
gcc-5a566bed2b7e0133247fa9fb3282116a8405dd3f.tar.bz2
* cfgrtl.c (purge_dead_edges): Correct handling of EDGE_EH.
From-SVN: r53521
Diffstat (limited to 'gcc/cfgrtl.c')
-rw-r--r--gcc/cfgrtl.c19
1 files changed, 14 insertions, 5 deletions
diff --git a/gcc/cfgrtl.c b/gcc/cfgrtl.c
index 9a6661d..844f5df 100644
--- a/gcc/cfgrtl.c
+++ b/gcc/cfgrtl.c
@@ -2186,17 +2186,26 @@ purge_dead_edges (bb)
e->flags &= ~EDGE_ABNORMAL;
- /* Check purposes we can have edge. */
- if ((e->flags & EDGE_FALLTHRU)
- && any_condjump_p (insn))
+ /* See if this edge is one we should keep. */
+ if ((e->flags & EDGE_FALLTHRU) && any_condjump_p (insn))
+ /* A conditional jump can fall through into the next
+ block, so we should keep the edge. */
continue;
else if (e->dest != EXIT_BLOCK_PTR
&& e->dest->head == JUMP_LABEL (insn))
+ /* If the destination block is the target of the jump,
+ keep the edge. */
+ continue;
+ else if (e->dest == EXIT_BLOCK_PTR && returnjump_p (insn))
+ /* If the destination block is the exit block, and this
+ instruction is a return, then keep the edge. */
continue;
- else if (e->dest == EXIT_BLOCK_PTR
- && returnjump_p (insn))
+ else if ((e->flags & EDGE_EH) && can_throw_internal (insn))
+ /* Keep the edges that correspond to exceptions thrown by
+ this instruction. */
continue;
+ /* We do not need this edge. */
bb->flags |= BB_DIRTY;
purged = true;
remove_edge (e);