aboutsummaryrefslogtreecommitdiff
path: root/gcc/function.c
diff options
context:
space:
mode:
authorMark Mitchell <mark@codesourcery.com>1999-12-05 00:13:53 +0000
committerMark Mitchell <mmitchel@gcc.gnu.org>1999-12-05 00:13:53 +0000
commit4ce893648569539981c77058e89108a9461217ab (patch)
tree4c623881730c17325e6c2b7f1279503b27e53cd1 /gcc/function.c
parent12f612289556bf30dd2d25854feec38ab43c7f73 (diff)
downloadgcc-4ce893648569539981c77058e89108a9461217ab.zip
gcc-4ce893648569539981c77058e89108a9461217ab.tar.gz
gcc-4ce893648569539981c77058e89108a9461217ab.tar.bz2
function.h (insert_block_after_note): Declare.
* function.h (insert_block_after_note): Declare. * function.c (insert_block_after_note): Split out from ... (retrofit_block): ... here. From-SVN: r30776
Diffstat (limited to 'gcc/function.c')
-rw-r--r--gcc/function.c57
1 files changed, 37 insertions, 20 deletions
diff --git a/gcc/function.c b/gcc/function.c
index 587fdff..67f5e41 100644
--- a/gcc/function.c
+++ b/gcc/function.c
@@ -5482,6 +5482,37 @@ round_trampoline_addr (tramp)
return tramp;
}
+/* Insert the BLOCK in the block-tree, knowing that the previous
+ block-note is for OLD_BLOCK. BEGIN_P is non-zero if the previous
+ block-note was the for the beginning of a BLOCK. FN is the
+ FUNCTION_DECL into which the BLOCK is being inserted. */
+
+void
+insert_block_after_note (block, old_block, begin_p, fn)
+ tree block;
+ tree old_block;
+ int begin_p;
+ tree fn;
+{
+ if (begin_p)
+ {
+ /* If there was no previous block, use the top-level block for
+ the function. */
+ if (!old_block)
+ old_block = DECL_INITIAL (fn);
+
+ BLOCK_SUPERCONTEXT (block) = old_block;
+ BLOCK_CHAIN (block) = BLOCK_SUBBLOCKS (old_block);
+ BLOCK_SUBBLOCKS (old_block) = block;
+ }
+ else
+ {
+ BLOCK_SUPERCONTEXT (block) = BLOCK_SUPERCONTEXT (old_block);
+ BLOCK_CHAIN (block) = BLOCK_CHAIN (old_block);
+ BLOCK_CHAIN (old_block) = block;
+ }
+}
+
/* Insert the BLOCK in the block-tree before LAST_INSN. */
void
@@ -5502,27 +5533,13 @@ retrofit_block (block, last_insn)
&& (NOTE_LINE_NUMBER (insn) == NOTE_INSN_BLOCK_BEG
|| NOTE_LINE_NUMBER (insn) == NOTE_INSN_BLOCK_END))
break;
- if (!insn || NOTE_LINE_NUMBER (insn) == NOTE_INSN_BLOCK_BEG)
- {
- tree superblock;
- if (insn)
- superblock = NOTE_BLOCK (insn);
- else
- superblock = DECL_INITIAL (current_function_decl);
-
- BLOCK_SUPERCONTEXT (block) = superblock;
- BLOCK_CHAIN (block) = BLOCK_SUBBLOCKS (superblock);
- BLOCK_SUBBLOCKS (superblock) = block;
- }
- else
- {
- tree prevblock = NOTE_BLOCK (insn);
-
- BLOCK_SUPERCONTEXT (block) = BLOCK_SUPERCONTEXT (prevblock);
- BLOCK_CHAIN (block) = BLOCK_CHAIN (prevblock);
- BLOCK_CHAIN (prevblock) = block;
- }
+ insert_block_after_note (block,
+ insn ? NOTE_BLOCK (insn) : NULL_TREE,
+ insn
+ ? (NOTE_LINE_NUMBER (insn) == NOTE_INSN_BLOCK_BEG)
+ : 1,
+ current_function_decl);
}
/* The functions identify_blocks and reorder_blocks provide a way to