diff options
author | kenner <kenner@138bc75d-0d04-0410-961f-82ee72b054a4> | 2001-02-24 13:15:55 +0000 |
---|---|---|
committer | kenner <kenner@138bc75d-0d04-0410-961f-82ee72b054a4> | 2001-02-24 13:15:55 +0000 |
commit | 53cca8463aaa78bfefe99e9a18414954d96d937e (patch) | |
tree | dba8fc1b41b606bab2b832ed5473057759474521 /gcc/integrate.c | |
parent | 0ae3acac75896c224470b7bdbc380168ca501c17 (diff) | |
download | gcc-53cca8463aaa78bfefe99e9a18414954d96d937e.tar.gz |
* tree.h (BLOCK_DEAD): New macro.
(struct tree_block): New flag, dead_flag.
* print-tree.c (print_node, case 'b'): Print missing fields.
* emit-rtl.c (remove_unnecessary_notes): Set BLOCK_DEAD.
* function.c (identify_blocks): Enable test for misplaced notes.
(all_blocks): Skip BLOCK_DEAD blocks.
* integrate.c (integrate_decl_tree): Likewise.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@40039 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/integrate.c')
-rw-r--r-- | gcc/integrate.c | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/gcc/integrate.c b/gcc/integrate.c index 270a9c5a115..23f3590b4f3 100644 --- a/gcc/integrate.c +++ b/gcc/integrate.c @@ -1684,11 +1684,12 @@ integrate_decl_tree (let, map) next = &BLOCK_SUBBLOCKS (new_block); for (t = BLOCK_SUBBLOCKS (let); t; t = BLOCK_CHAIN (t)) - { - *next = integrate_decl_tree (t, map); - BLOCK_SUPERCONTEXT (*next) = new_block; - next = &BLOCK_CHAIN (*next); - } + if (!BLOCK_DEAD (t)) + { + *next = integrate_decl_tree (t, map); + BLOCK_SUPERCONTEXT (*next) = new_block; + next = &BLOCK_CHAIN (*next); + } TREE_USED (new_block) = TREE_USED (let); BLOCK_ABSTRACT_ORIGIN (new_block) = let; |