diff options
author | hubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4> | 2002-06-03 18:16:50 +0000 |
---|---|---|
committer | hubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4> | 2002-06-03 18:16:50 +0000 |
commit | 0c2263a73cfd9c882431edf3c93c1d4875375756 (patch) | |
tree | 766b4f10bf4b5fb575a750457126b07e7b091dfc /gcc/toplev.c | |
parent | 80a6b954ffb446c4701135c18d9ef3b7a5b482a0 (diff) | |
download | gcc-0c2263a73cfd9c882431edf3c93c1d4875375756.tar.gz |
* except.c (except.c): Do not rebuild CFG.
* toplev.c (rest_of_compilation): Recompute CFG after sibcall
optimization.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@54217 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/toplev.c')
-rw-r--r-- | gcc/toplev.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/gcc/toplev.c b/gcc/toplev.c index 4c52a04c7a2..702937591b1 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); |