aboutsummaryrefslogtreecommitdiff
path: root/gcc/cfgrtl.c
diff options
context:
space:
mode:
authorDaniel Berlin <dberlin@dberlin.org>2005-05-18 13:29:38 +0000
committerDaniel Berlin <dberlin@gcc.gnu.org>2005-05-18 13:29:38 +0000
commit2afa8dcedaa0b3db5444fe6086e991ac77bdd730 (patch)
tree24154ad4da32dba37675b38d2241bffdb18e8307 /gcc/cfgrtl.c
parent23e66a36cb937636be796fce2f7d273209a80a4f (diff)
downloadgcc-2afa8dcedaa0b3db5444fe6086e991ac77bdd730.zip
gcc-2afa8dcedaa0b3db5444fe6086e991ac77bdd730.tar.gz
gcc-2afa8dcedaa0b3db5444fe6086e991ac77bdd730.tar.bz2
cfgrtl.c (purge_dead_edges): Don't remove fake edges.
2005-05-18 Daniel Berlin <dberlin@dberlin.org> * cfgrtl.c (purge_dead_edges): Don't remove fake edges. From-SVN: r99897
Diffstat (limited to 'gcc/cfgrtl.c')
-rw-r--r--gcc/cfgrtl.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/gcc/cfgrtl.c b/gcc/cfgrtl.c
index 3ceca75..42761ca 100644
--- a/gcc/cfgrtl.c
+++ b/gcc/cfgrtl.c
@@ -2428,9 +2428,12 @@ purge_dead_edges (basic_block bb)
if (!found)
return purged;
+ /* Remove all but the fake and fallthru edges. The fake edge may be
+ the only successor for this block in the case of noreturn
+ calls. */
for (ei = ei_start (bb->succs); (e = ei_safe_edge (ei)); )
{
- if (!(e->flags & EDGE_FALLTHRU))
+ if (!(e->flags & (EDGE_FALLTHRU | EDGE_FAKE)))
{
bb->flags |= BB_DIRTY;
remove_edge (e);