summaryrefslogtreecommitdiff
path: root/gcc/cfg.c
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/cfg.c')
-rw-r--r--gcc/cfg.c147
1 files changed, 58 insertions, 89 deletions
diff --git a/gcc/cfg.c b/gcc/cfg.c
index 0300484efbb..47dfb238ea5 100644
--- a/gcc/cfg.c
+++ b/gcc/cfg.c
@@ -63,10 +63,7 @@ static char *flow_firstobj;
/* Number of basic blocks in the current function. */
-int num_basic_blocks;
-
-/* First free basic block number. */
-int last_basic_block;
+int n_basic_blocks;
/* Number of edges in the current function. */
@@ -96,8 +93,6 @@ struct basic_block_def entry_exit_blocks[2]
NULL, /* global_live_at_end */
NULL, /* aux */
ENTRY_BLOCK, /* index */
- NULL, /* prev_bb */
- EXIT_BLOCK_PTR, /* next_bb */
0, /* loop_depth */
0, /* count */
0, /* frequency */
@@ -116,8 +111,6 @@ struct basic_block_def entry_exit_blocks[2]
NULL, /* global_live_at_end */
NULL, /* aux */
EXIT_BLOCK, /* index */
- ENTRY_BLOCK_PTR, /* prev_bb */
- NULL, /* next_bb */
0, /* loop_depth */
0, /* count */
0, /* frequency */
@@ -170,11 +163,12 @@ free_edge (e)
void
clear_edges ()
{
- basic_block bb;
+ int i;
edge e;
- FOR_ALL_BB (bb)
+ for (i = 0; i < n_basic_blocks; ++i)
{
+ basic_block bb = BASIC_BLOCK (i);
edge e = bb->succ;
while (e)
@@ -226,66 +220,36 @@ alloc_block ()
return bb;
}
-/* Link block B to chain after AFTER. */
-void
-link_block (b, after)
- basic_block b, after;
-{
- b->next_bb = after->next_bb;
- b->prev_bb = after;
- after->next_bb = b;
- b->next_bb->prev_bb = b;
-}
+/* Remove block B from the basic block array and compact behind it. */
-/* Unlink block B from chain. */
void
-unlink_block (b)
+expunge_block_nocompact (b)
basic_block b;
{
- b->next_bb->prev_bb = b->prev_bb;
- b->prev_bb->next_bb = b->next_bb;
+ /* Invalidate data to make bughunting easier. */
+ memset (b, 0, sizeof *b);
+ b->index = -3;
+ b->succ = (edge) first_deleted_block;
+ first_deleted_block = (basic_block) b;
}
-/* Sequentially order blocks and compact the arrays. */
void
-compact_blocks ()
+expunge_block (b)
+ basic_block b;
{
- basic_block *bbs = xcalloc (num_basic_blocks, sizeof (basic_block));
- int i;
- basic_block bb;
-
- i = 0;
- FOR_ALL_BB (bb)
- bbs[i++] = bb;
-
- if (i != num_basic_blocks)
- abort ();
+ int i, n = n_basic_blocks;
- for (i = 0; i < num_basic_blocks; i++)
+ for (i = b->index; i + 1 < n; ++i)
{
- bbs[i]->sindex = i;
- BASIC_BLOCK (i) = bbs[i];
+ basic_block x = BASIC_BLOCK (i + 1);
+ BASIC_BLOCK (i) = x;
+ x->index = i;
}
- last_basic_block = num_basic_blocks;
-
- free (bbs);
-}
-/* Remove block B from the basic block array. */
-
-void
-expunge_block (b)
- basic_block b;
-{
- unlink_block (b);
- BASIC_BLOCK (b->sindex) = NULL;
- num_basic_blocks--;
+ n_basic_blocks--;
+ basic_block_info->num_elements--;
- /* Invalidate data to make bughunting easier. */
- memset (b, 0, sizeof *b);
- b->sindex = -3;
- b->succ = (edge) first_deleted_block;
- first_deleted_block = (basic_block) b;
+ expunge_block_nocompact (b);
}
/* Create an edge connecting SRC and DST with FLAGS optionally using
@@ -310,7 +274,7 @@ cached_make_edge (edge_cache, src, dst, flags)
{
default:
/* Quick test for non-existence of the edge. */
- if (! TEST_BIT (edge_cache[src->sindex], dst->sindex))
+ if (! TEST_BIT (edge_cache[src->index], dst->index))
break;
/* The edge exists; early exit if no work to do. */
@@ -350,7 +314,7 @@ cached_make_edge (edge_cache, src, dst, flags)
dst->pred = e;
if (use_edge_cache)
- SET_BIT (edge_cache[src->sindex], dst->sindex);
+ SET_BIT (edge_cache[src->index], dst->index);
return e;
}
@@ -489,10 +453,11 @@ redirect_edge_pred (e, new_pred)
void
clear_bb_flags ()
{
- basic_block bb;
-
- FOR_BB_BETWEEN (bb, ENTRY_BLOCK_PTR, NULL, next_bb)
- bb->flags = 0;
+ int i;
+ ENTRY_BLOCK_PTR->flags = 0;
+ EXIT_BLOCK_PTR->flags = 0;
+ for (i = 0; i < n_basic_blocks; i++)
+ BASIC_BLOCK (i)->flags = 0;
}
void
@@ -500,7 +465,6 @@ dump_flow_info (file)
FILE *file;
{
int i;
- basic_block bb;
static const char * const reg_class_names[] = REG_CLASS_NAMES;
fprintf (file, "%d registers.\n", max_regno);
@@ -547,17 +511,16 @@ dump_flow_info (file)
fprintf (file, ".\n");
}
- fprintf (file, "\n%d basic blocks, %d edges.\n", num_basic_blocks, n_edges);
- FOR_ALL_BB (bb)
+ fprintf (file, "\n%d basic blocks, %d edges.\n", n_basic_blocks, n_edges);
+ for (i = 0; i < n_basic_blocks; i++)
{
+ basic_block bb = BASIC_BLOCK (i);
edge e;
int sum;
gcov_type lsum;
fprintf (file, "\nBasic block %d: first insn %d, last %d, ",
- bb->sindex, INSN_UID (bb->head), INSN_UID (bb->end));
- fprintf (file, "prev %d, next %d, ",
- bb->prev_bb->sindex, bb->next_bb->sindex);
+ i, INSN_UID (bb->head), INSN_UID (bb->end));
fprintf (file, "loop_depth %d, count ", bb->loop_depth);
fprintf (file, HOST_WIDEST_INT_PRINT_DEC, bb->count);
fprintf (file, ", freq %i.\n", bb->frequency);
@@ -632,7 +595,7 @@ dump_edge_info (file, e, do_succ)
else if (side == EXIT_BLOCK_PTR)
fputs (" EXIT", file);
else
- fprintf (file, " %d", side->sindex);
+ fprintf (file, " %d", side->index);
if (e->probability)
fprintf (file, " [%.1f%%] ", e->probability * 100.0 / REG_BR_PROB_BASE);
@@ -712,10 +675,10 @@ alloc_aux_for_blocks (size)
first_block_aux_obj = (char *) obstack_alloc (&block_aux_obstack, 0);
if (size)
{
- basic_block bb;
+ int i;
- FOR_ALL_BB (bb)
- alloc_aux_for_block (bb, size);
+ for (i = 0; i < n_basic_blocks; i++)
+ alloc_aux_for_block (BASIC_BLOCK (i), size);
alloc_aux_for_block (ENTRY_BLOCK_PTR, size);
alloc_aux_for_block (EXIT_BLOCK_PTR, size);
@@ -727,10 +690,13 @@ alloc_aux_for_blocks (size)
void
clear_aux_for_blocks ()
{
- basic_block bb;
+ int i;
+
+ for (i = 0; i < n_basic_blocks; i++)
+ BASIC_BLOCK (i)->aux = NULL;
- FOR_BB_BETWEEN (bb, ENTRY_BLOCK_PTR, NULL, next_bb)
- bb->aux = NULL;
+ ENTRY_BLOCK_PTR->aux = NULL;
+ EXIT_BLOCK_PTR->aux = NULL;
}
/* Free data allocated in block_aux_obstack and clear AUX pointers
@@ -784,12 +750,17 @@ alloc_aux_for_edges (size)
first_edge_aux_obj = (char *) obstack_alloc (&edge_aux_obstack, 0);
if (size)
{
- basic_block bb;
-
- FOR_BB_BETWEEN (bb, ENTRY_BLOCK_PTR, EXIT_BLOCK_PTR, next_bb)
+ int i;
+ for (i = -1; i < n_basic_blocks; i++)
{
+ basic_block bb;
edge e;
+ if (i >= 0)
+ bb = BASIC_BLOCK (i);
+ else
+ bb = ENTRY_BLOCK_PTR;
+
for (e = bb->succ; e; e = e->succ_next)
alloc_aux_for_edge (e, size);
}
@@ -801,12 +772,18 @@ alloc_aux_for_edges (size)
void
clear_aux_for_edges ()
{
- basic_block bb;
+ int i;
- FOR_BB_BETWEEN (bb, ENTRY_BLOCK_PTR, EXIT_BLOCK_PTR, next_bb)
+ for (i = -1; i < n_basic_blocks; i++)
{
+ basic_block bb;
edge e;
+ if (i >= 0)
+ bb = BASIC_BLOCK (i);
+ else
+ bb = ENTRY_BLOCK_PTR;
+
for (e = bb->succ; e; e = e->succ_next)
e->aux = NULL;
}
@@ -825,11 +802,3 @@ free_aux_for_edges ()
clear_aux_for_edges ();
}
-
-/* The same as BASIC_BLOCK, but usable from debugger. */
-basic_block
-debug_num2bb (num)
- int num;
-{
- return BASIC_BLOCK (num);
-}