aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJan Hubicka <jh@suse.cz>2002-06-03 20:16:50 +0200
committerJan Hubicka <hubicka@gcc.gnu.org>2002-06-03 18:16:50 +0000
commit5204d66596d7864904364c8a61a1e62e81c091a1 (patch)
tree766b4f10bf4b5fb575a750457126b07e7b091dfc /gcc
parent824030c6245b042e3dbc81e4151425c446787d91 (diff)
downloadgcc-5204d66596d7864904364c8a61a1e62e81c091a1.zip
gcc-5204d66596d7864904364c8a61a1e62e81c091a1.tar.gz
gcc-5204d66596d7864904364c8a61a1e62e81c091a1.tar.bz2
except.c (except.c): Do not rebuild CFG.
* except.c (except.c): Do not rebuild CFG. * toplev.c (rest_of_compilation): Recompute CFG after sibcall optimization. From-SVN: r54217
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/except.c2
-rw-r--r--gcc/toplev.c7
3 files changed, 12 insertions, 3 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index c14287a..9b61fa6 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+Mon Jun 3 19:11:53 CEST 2002 Jan Hubicka <jh@suse.cz>
+
+ * except.c (except.c): Do not rebuild CFG.
+ * toplev.c (rest_of_compilation): Recompute CFG after sibcall
+ optimization.
+
Mon Jun 3 11:53:01 CEST 2002 Jan Hubicka <jh@suse.cz>
* integrate.c (copy_insn_list): Properly pace the INSN_SCOPE copies.
diff --git a/gcc/except.c b/gcc/except.c
index 5b21d64..a2f2c69 100644
--- a/gcc/except.c
+++ b/gcc/except.c
@@ -2499,8 +2499,6 @@ finish_eh_generation ()
connect many of the handlers, and then type information will not
be effective. Still, this is a win over previous implementations. */
- rebuild_jump_labels (get_insns ());
- find_basic_blocks (get_insns (), max_reg_num (), 0);
cleanup_cfg (CLEANUP_PRE_LOOP | CLEANUP_NO_INSN_DEL);
/* These registers are used by the landing pads. Make sure they
diff --git a/gcc/toplev.c b/gcc/toplev.c
index 4c52a04..7029375 100644
--- a/gcc/toplev.c
+++ b/gcc/toplev.c
@@ -2560,6 +2560,12 @@ rest_of_compilation (decl)
rtx insn;
optimize_sibling_and_tail_recursive_calls ();
+ /* Recompute the CFG as sibling optimization clobbers it randomly. */
+ free_bb_for_insn ();
+ find_exception_handler_labels ();
+ rebuild_jump_labels (insns);
+ find_basic_blocks (insns, max_reg_num (), rtl_dump_file);
+
/* There is pass ordering problem - we must lower NOTE_INSN_PREDICTION
notes before simplifying cfg and we must do lowering after sibcall
that unhides parts of RTL chain and cleans up the CFG.
@@ -2576,7 +2582,6 @@ rest_of_compilation (decl)
scope_to_insns_initialize ();
/* Complete generation of exception handling code. */
- find_exception_handler_labels ();
if (doing_eh (0))
{
timevar_push (TV_JUMP);