diff options
author | hubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4> | 2003-07-03 18:40:29 +0000 |
---|---|---|
committer | hubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4> | 2003-07-03 18:40:29 +0000 |
commit | c60fa3a778a01ab52008d1bd4d832658ca8943e6 (patch) | |
tree | 315cee76b1488868b1d0dacd4aee43ace2470db6 /gcc/cfgloopmanip.c | |
parent | 9f1c0b942892c54b46138919610d8ff65619f044 (diff) | |
download | ppe42-gcc-c60fa3a778a01ab52008d1bd4d832658ca8943e6.tar.gz ppe42-gcc-c60fa3a778a01ab52008d1bd4d832658ca8943e6.zip |
* basic-block.h (create_basic_block, merge_blocks_nomove): Kill.
* cfgcleanup.c (merge_blocks): Rename to merge_blocks_move.
(merge_blocks_move_predecessor_nojumps,
merge_blocks_move_successor_nojumps): Use merge_blocks.
(try_optimize_cfg): Use merge_blocks_move.
* cfgrtl.c (create_basic_block): Rename to rtl_create_basic_block.
(merge_blocks_nomove): Rename to rtl_merge_blocks.
(cfg_layout_create_basic_block): New.
(rtl_can_merge_blocks): New.
(cfg_layout_split_block): Do not alloc aux by hand.
* cfghooks.h (cfg_hooks): Add create_basic_block, can_merge_blocks_p,
merge_blocks.
(create_basic_block, can_merge_blocks_p, merge_blocks): New macros.
* cfglayout.c (cfg_layout_duplicate_bb): Do not allocate aux by hand.
* cfgloopmanip.c (loop_split_edge_with): Likewise.
* ifcvt.c (merge_if_block): Use merge_blocks_nomove.
* basic-block.h (basic_block_def): Add field 'rbi'.
* bb-reorder.c (find_traces, rotate_loop, mark_bb_visited,
find_traces_1_round, copy_bb, connect_traces): Update use of rbi.
* cfg.c (entry_exit_blocks): Add new field.
* cfglayout.c: Include alloc-pool.h;
(cfg_layout_pool): New.
(record_effective_endpoints, fixup_reorder_chain,
fixup_fallthru_exit_predecessor, cfg_layout_duplicate_bb): Update use
of rbi.
(cfg_layout_initialize_rbi): New function.
(cfg_layout_initialize): Use it.
(cfg_layout_finalize): Clear rbi fields.
* cfglayout.h (RBI): Kill.
(cfg_layout_initialize_rbi): Declare.
* cfgloopmanip.c (copy_bbs): Use rbi.
(record_exit_edges): Likewise.
(duplicate_loop_to_header_edge): Likewise.
* cfgrtl.c (cfg_layout_create_basic_block): Use
cfg_layout_initialize_rbi.
(cfg_layout_split_block): Use rbi.
(cfg_layout_delete_block): Likewise.
* loop-init.c (loop_optimizer_finalize): Likewise.
* loop-unswitch.c (unswitch_loop): Likewise.
* tracer.c (seen, tail_duplicate, layout_superblocks): Likewise.
* cfgrtl.c: Update comments.
(try_redirect_by_replacing_jump): New argument.
(redirect_branch_edge): Break out from ...
(rtl_redirect_edge_and_branch): ... this one.
(update_cfg_after_block_merging): Break out from ...
(rtl_merge_blocks): ... this one.
(cfg_layout_split_edge): New.
(cfg_layout_merge_blocks): New.
(cfg_layout_can_merge_blocks_p): New.
(cfg_layout_redirect_edge_and_branch): Reorganize.
(cfg_layout_rtl_cfg_hooks): Fill in.
(cfg_layout_delete_block): Kill barriers.
* cfganal.c (can_fallthru): Deal with exit blocks
* cfglayout.c (cfg_layout_function_header): New function
(record_effective_endpoints): Record function header.
(fixup_reorder_chain): Fixup dead jumptables; place header
* basic-block.h (CLEANUP_CFGLAYOUT): New flag.
* bb-reorder.c (cfg_layout_initialize): Update call.
* cfgcleanup.c (try_optimize_cfg): Supress optimizations of fallthru
edges in cfglayout mode.
* cfglayout.c (cleanup_unconditional_jumps): Kill.
(cfg_layout_initialize): Kill agrument loops; use cfgcleanup.
* cfglayout.h (cfg_layout_initialize): Update prototype.
* cfgloop.h (CP_INSIDE_CFGLAYOUT): Kill.
* cfgloopmanip.c (loop_split_edge_with): Use split_edge.
* flow.c (propagate_block): Do not crash when basic block ends
by first insn in the chain.
* loop-init.c (loop_optimizer_init): First enter cfglayout mode; later
do loop discovery.
* tracer.c (tracer): Update call of cfg_layout_initialize.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@68899 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/cfgloopmanip.c')
-rw-r--r-- | gcc/cfgloopmanip.c | 43 |
1 files changed, 15 insertions, 28 deletions
diff --git a/gcc/cfgloopmanip.c b/gcc/cfgloopmanip.c index 5675f71cbf2..c627ea06348 100644 --- a/gcc/cfgloopmanip.c +++ b/gcc/cfgloopmanip.c @@ -860,7 +860,7 @@ copy_bbs (basic_block *bbs, int n, edge entry, edge latch_edge, /* Duplicate. */ bb = bbs[i]; new_bb = (*new_bbs)[i] = cfg_layout_duplicate_bb (bb, NULL); - RBI (new_bb)->duplicated = 1; + new_bb->rbi->duplicated = 1; /* Add to loop. */ add_bb_to_loop (new_bb, bb->loop_father->copy); add_to_dominance_info (loops->cfg.dom, new_bb); @@ -886,7 +886,7 @@ copy_bbs (basic_block *bbs, int n, edge entry, edge latch_edge, { /* For anything else than loop header, just copy it. */ dom_bb = get_immediate_dominator (loops->cfg.dom, bb); - dom_bb = RBI (dom_bb)->copy; + dom_bb = dom_bb->rbi->copy; } else { @@ -910,7 +910,7 @@ copy_bbs (basic_block *bbs, int n, edge entry, edge latch_edge, e_pred = e->pred_next; - if (!RBI (src)->duplicated) + if (!src->rbi->duplicated) continue; /* Leads to copied loop and it is not latch edge, redirect it. */ @@ -919,24 +919,24 @@ copy_bbs (basic_block *bbs, int n, edge entry, edge latch_edge, if (add_irreducible_flag && (bb->loop_father == header->loop_father - || RBI (src)->original->loop_father == header->loop_father)) + || src->rbi->original->loop_father == header->loop_father)) e->flags |= EDGE_IRREDUCIBLE_LOOP; } } /* Redirect header edge. */ - bb = RBI (latch_edge->src)->copy; + bb = latch_edge->src->rbi->copy; for (e = bb->succ; e->dest != latch_edge->dest; e = e->succ_next); *header_edge = e; loop_redirect_edge (*header_edge, header); /* Redirect entry to copy of header. */ - loop_redirect_edge (entry, RBI (header)->copy); + loop_redirect_edge (entry, header->rbi->copy); *copy_header_edge = entry; /* Clear information about duplicates. */ for (i = 0; i < n; i++) - RBI ((*new_bbs)[i])->duplicated = 0; + (*new_bbs)[i]->rbi->duplicated = 0; } /* Check whether LOOP's body can be duplicated. */ @@ -995,7 +995,7 @@ record_exit_edges (edge orig, basic_block *bbs, int nbbs, edge *to_remove, return; } - for (e = RBI (orig->src)->copy->succ; e; e = e->succ_next) + for (e = orig->src->rbi->copy->succ; e; e = e->succ_next) if (e->dest == orig->dest) break; if (!e) @@ -1175,7 +1175,7 @@ duplicate_loop_to_header_edge (struct loop *loop, edge e, struct loops *loops, copy_bbs (bbs, n, e, latch_edge, &new_bbs, loops, &e, &he, add_irreducible_flag); if (is_latch) - loop->latch = RBI (latch)->copy; + loop->latch = latch->rbi->copy; /* Record exit edges in this copy. */ if (TEST_BIT (wont_exit, j + 1)) @@ -1209,7 +1209,7 @@ duplicate_loop_to_header_edge (struct loop *loop, edge e, struct loops *loops, if (!first_active_latch) { memcpy (first_active, new_bbs, n * sizeof (basic_block)); - first_active_latch = RBI (latch)->copy; + first_active_latch = latch->rbi->copy; } free (new_bbs); @@ -1217,11 +1217,11 @@ duplicate_loop_to_header_edge (struct loop *loop, edge e, struct loops *loops, /* Original loop header is dominated by latch copy if we duplicated on its only entry edge. */ if (!is_latch && !header->pred->pred_next->pred_next) - set_immediate_dominator (loops->cfg.dom, header, RBI (latch)->copy); + set_immediate_dominator (loops->cfg.dom, header, latch->rbi->copy); if (is_latch && j == 0) { /* Update edge from latch. */ - for (latch_edge = RBI (header)->copy->pred; + for (latch_edge = header->rbi->copy->pred; latch_edge->src != latch; latch_edge = latch_edge->pred_next); } @@ -1409,33 +1409,20 @@ loop_split_edge_with (edge e, rtx insns, struct loops *loops) /* Create basic block for it. */ - new_bb = create_basic_block (NULL_RTX, NULL_RTX, EXIT_BLOCK_PTR->prev_bb); + new_bb = split_edge (e); add_to_dominance_info (loops->cfg.dom, new_bb); add_bb_to_loop (new_bb, loop_c); new_bb->flags = insns ? BB_SUPERBLOCK : 0; - new_e = make_edge (new_bb, dest, EDGE_FALLTHRU); - new_e->probability = REG_BR_PROB_BASE; - new_e->count = e->count; + new_e = new_bb->succ; if (e->flags & EDGE_IRREDUCIBLE_LOOP) { new_bb->flags |= BB_IRREDUCIBLE_LOOP; new_e->flags |= EDGE_IRREDUCIBLE_LOOP; } - new_bb->count = e->count; - new_bb->frequency = EDGE_FREQUENCY (e); - redirect_edge_and_branch_force (e, new_bb); - - alloc_aux_for_block (new_bb, sizeof (struct reorder_block_def)); if (insns) - { - start_sequence (); - emit_insn (insns); - insns = get_insns (); - end_sequence (); - emit_insn_after (insns, new_bb->end); - } + emit_insn_after (insns, new_bb->end); set_immediate_dominator (loops->cfg.dom, new_bb, src); set_immediate_dominator (loops->cfg.dom, dest, |