summaryrefslogtreecommitdiff
path: root/gcc/tree-into-ssa.c
diff options
context:
space:
mode:
authorkazu <kazu@138bc75d-0d04-0410-961f-82ee72b054a4>2005-03-13 13:31:01 +0000
committerkazu <kazu@138bc75d-0d04-0410-961f-82ee72b054a4>2005-03-13 13:31:01 +0000
commit597516aa059e5bf401a073c6920726f359ef446a (patch)
tree45aa8123e100141f92309d1cd58db95f2951da1d /gcc/tree-into-ssa.c
parent408663f1d4cfa978c041e68ecc794fc745f3da46 (diff)
downloadgcc-597516aa059e5bf401a073c6920726f359ef446a.tar.gz
* tree-into-ssa.c (find_idf): Speed up by putting the indexes
of basic blocks into work_stack. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@96367 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/tree-into-ssa.c')
-rw-r--r--gcc/tree-into-ssa.c19
1 files changed, 8 insertions, 11 deletions
diff --git a/gcc/tree-into-ssa.c b/gcc/tree-into-ssa.c
index fa1d0da6561..8c58a457dac 100644
--- a/gcc/tree-into-ssa.c
+++ b/gcc/tree-into-ssa.c
@@ -111,7 +111,7 @@ static htab_t def_blocks;
static VEC(tree_on_heap) *block_defs_stack;
/* Basic block vectors used in this file ought to be allocated in the heap. */
-DEF_VEC_MALLOC_P(basic_block);
+DEF_VEC_MALLOC_P(int);
/* Global data to attach to the main dominator walk structure. */
struct mark_def_sites_global_data
@@ -503,40 +503,37 @@ find_idf (bitmap def_blocks, bitmap *dfs)
{
bitmap_iterator bi;
unsigned bb_index;
- VEC(basic_block) *work_stack;
+ VEC(int) *work_stack;
bitmap phi_insertion_points;
- work_stack = VEC_alloc (basic_block, n_basic_blocks);
+ work_stack = VEC_alloc (int, n_basic_blocks);
phi_insertion_points = BITMAP_ALLOC (NULL);
/* Seed the work list with all the blocks in DEF_BLOCKS. */
EXECUTE_IF_SET_IN_BITMAP (def_blocks, 0, bb_index, bi)
- VEC_safe_push (basic_block, work_stack, BASIC_BLOCK (bb_index));
+ VEC_safe_push (int, work_stack, bb_index);
/* Pop a block off the worklist, add every block that appears in
the original block's DF that we have not already processed to
the worklist. Iterate until the worklist is empty. Blocks
which are added to the worklist are potential sites for
PHI nodes. */
- while (VEC_length (basic_block, work_stack) > 0)
+ while (VEC_length (int, work_stack) > 0)
{
- basic_block bb = VEC_pop (basic_block, work_stack);
- bb_index = bb->index;
+ bb_index = VEC_pop (int, work_stack);
EXECUTE_IF_AND_COMPL_IN_BITMAP (dfs[bb_index], phi_insertion_points,
0, bb_index, bi)
{
- bb = BASIC_BLOCK (bb_index);
-
/* Use a safe push because if there is a definition of VAR
in every basic block, then WORK_STACK may eventually have
more than N_BASIC_BLOCK entries. */
- VEC_safe_push (basic_block, work_stack, bb);
+ VEC_safe_push (int, work_stack, bb_index);
bitmap_set_bit (phi_insertion_points, bb_index);
}
}
- VEC_free (basic_block, work_stack);
+ VEC_free (int, work_stack);
return phi_insertion_points;
}