aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Henderson <rth@redhat.com>2003-06-13 15:56:09 -0700
committerRichard Henderson <rth@gcc.gnu.org>2003-06-13 15:56:09 -0700
commit792bb204afa4fdde580030e7e4f703fc93395e4f (patch)
tree69d618b00df041dbd5f5b6ceb0ae8946bfd4f07a
parent54c2fc721cbe654695433d7419cb9b74f3a13642 (diff)
downloadgcc-792bb204afa4fdde580030e7e4f703fc93395e4f.zip
gcc-792bb204afa4fdde580030e7e4f703fc93395e4f.tar.gz
gcc-792bb204afa4fdde580030e7e4f703fc93395e4f.tar.bz2
cfgbuild.c (make_edges): Set ABNORMAL with SIBCALL.
* cfgbuild.c (make_edges): Set ABNORMAL with SIBCALL. * cfgrtl.c (purge_dead_edges): Expect it too. From-SVN: r67917
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/cfgbuild.c3
-rw-r--r--gcc/cfgrtl.c2
3 files changed, 8 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 9a54246..2038224 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2003-06-13 Richard Henderson <rth@redhat.com>
+
+ * cfgbuild.c (make_edges): Set ABNORMAL with SIBCALL.
+ * cfgrtl.c (purge_dead_edges): Expect it too.
+
2003-06-13 Jim Wilson <wilson@tuliptree.org>
Eric Botcazou <ebotcazou@libertysurf.fr>
diff --git a/gcc/cfgbuild.c b/gcc/cfgbuild.c
index ed8dfb8..de57653 100644
--- a/gcc/cfgbuild.c
+++ b/gcc/cfgbuild.c
@@ -406,7 +406,8 @@ make_edges (label_value_list, min, max, update_p)
worry about EH edges, since we wouldn't have created the sibling call
in the first place. */
if (code == CALL_INSN && SIBLING_CALL_P (insn))
- cached_make_edge (edge_cache, bb, EXIT_BLOCK_PTR, EDGE_SIBCALL);
+ cached_make_edge (edge_cache, bb, EXIT_BLOCK_PTR,
+ EDGE_SIBCALL | EDGE_ABNORMAL);
/* If this is a CALL_INSN, then mark it as reaching the active EH
handler for this CALL_INSN. If we're handling non-call
diff --git a/gcc/cfgrtl.c b/gcc/cfgrtl.c
index 7c36c54..35757cd 100644
--- a/gcc/cfgrtl.c
+++ b/gcc/cfgrtl.c
@@ -2182,7 +2182,7 @@ purge_dead_edges (bb)
should of course never have been a fallthru edge. */
if (!bb->succ || bb->succ->succ_next)
abort ();
- if (bb->succ->flags != EDGE_SIBCALL)
+ if (bb->succ->flags != (EDGE_SIBCALL | EDGE_ABNORMAL))
abort ();
return 0;