diff options
author | Richard Henderson <rth@redhat.com> | 2003-02-15 13:01:48 -0800 |
---|---|---|
committer | Richard Henderson <rth@gcc.gnu.org> | 2003-02-15 13:01:48 -0800 |
commit | 9381bbc998366a7d255d2ad86d3f87b64b22ba22 (patch) | |
tree | 140f465ad8335a004a10374f9d56037902ccc56a /gcc/recog.c | |
parent | 86ac05753c9d7fcf27375fe17e70cda5333ab50e (diff) | |
download | gcc-9381bbc998366a7d255d2ad86d3f87b64b22ba22.tar.gz |
recog.c (split_all_insns): Include new blocks in life update; do a global life update.
* recog.c (split_all_insns): Include new blocks in life update;
do a global life update.
From-SVN: r62941
Diffstat (limited to 'gcc/recog.c')
-rw-r--r-- | gcc/recog.c | 21 |
1 files changed, 14 insertions, 7 deletions
diff --git a/gcc/recog.c b/gcc/recog.c index 34eaeb32732..bfa988b4b16 100644 --- a/gcc/recog.c +++ b/gcc/recog.c @@ -2840,12 +2840,12 @@ split_all_insns (upd_life) int upd_life; { sbitmap blocks; - int changed; + bool changed; basic_block bb; blocks = sbitmap_alloc (last_basic_block); sbitmap_zero (blocks); - changed = 0; + changed = false; FOR_EACH_BB_REVERSE (bb) { @@ -2870,7 +2870,7 @@ split_all_insns (upd_life) while (GET_CODE (last) == BARRIER) last = PREV_INSN (last); SET_BIT (blocks, bb->index); - changed = 1; + changed = true; insn = last; } } @@ -2878,14 +2878,21 @@ split_all_insns (upd_life) if (changed) { + int old_last_basic_block = last_basic_block; + find_many_sub_basic_blocks (blocks); + + while (old_last_basic_block < last_basic_block) + { + SET_BIT (blocks, old_last_basic_block); + old_last_basic_block++; + } } if (changed && upd_life) - { - count_or_remove_death_notes (blocks, 1); - update_life_info (blocks, UPDATE_LIFE_LOCAL, PROP_DEATH_NOTES); - } + update_life_info (blocks, UPDATE_LIFE_GLOBAL_RM_NOTES, + PROP_DEATH_NOTES | PROP_REG_INFO); + #ifdef ENABLE_CHECKING verify_flow_info (); #endif |