diff options
author | Jan Hubicka <jh@suse.cz> | 2002-06-20 19:51:06 +0200 |
---|---|---|
committer | Jan Hubicka <hubicka@gcc.gnu.org> | 2002-06-20 17:51:06 +0000 |
commit | 355be0dc5824199cd14e8ee57983332ae2b26226 (patch) | |
tree | 8635e8934338aabce3b83e28ee4e39d8b3df5645 /gcc/ssa.c | |
parent | 62c71f4bc29a578f50b161f20fb5f56826f4f019 (diff) | |
download | gcc-355be0dc5824199cd14e8ee57983332ae2b26226.zip gcc-355be0dc5824199cd14e8ee57983332ae2b26226.tar.gz gcc-355be0dc5824199cd14e8ee57983332ae2b26226.tar.bz2 |
Mon Jun 10 20:42:34 CEST 2002 Jan Hubicka <jh@suse.cz>
* basic-block.h: Do not include et-forest.h
(dominance_info): Declare as struct dominance-info.
* cfglayout.c (cleanup_unconditional_jumps): Remove the edge before
deleting block.
* dominance.c (struct dominance_info): Define.
(BB_NODE, SET_BB_NODE): New macros.
(bb_hash_func, bb_eq_func): Kill.
(calculate_dominace_info, free_dominacne_info, set_immediate_dominator,
nearest_common_dominator, dominated_by_p, recount_dominator,
add_to_dominance_info, delete_from_dominance_info): update for new
representation.
(get_dominated_by, redirect_immediate_dominators): Rewrite using
enumerate_sons.
* ifcvt.c (process_double_test_block, merge_if_block, find_cond_trap,
find_if_case_1, find_if_case_2): Remove killed blocks from dominance
structure.
* et-forest.h: Update copyright; revamp all function to operate on
nodes
(et_forest_value): Kill.
(et_forest_enumerate_sons, et_forest_node_value): New.
* et-forest.c: Update copyright.
* et-forest.h: Update copyright; revamp all function to operate on
nodes
(et_forest_value): Kill.
(et_forest_enumerate_sons, et_forest_node_value): New.
Thu Jun 6 22:43:43 CEST 2002 Jan Hubicka <jh@suse.cz>
* basic-block.h: Inlude et-forest.h
(basic_block_def): Kill dominator.
(dominance_info): New type.
(loops): Use dominace_info.
(dominace handling functions): Take dominace_info as argument
instead of bitmaps.
(create_preheader): Likewise.
* cfg.c (entry_exit_blocks): Kill dominator.
(dump_flow_info): Do not dump dominators.
* cfglayout.c (cleanup_unconditonal_jumps): Delete deleted block from
dominators.
* cfgloop.c (flow_pre_header_find): Use dominacne_info.
(flow_loops_pre_header_scan, make_forwarder_block,
canonicale_loop_headers, flow_loops_find): Likewise.
* dominance.c: Include error.h
(idoms_to_doms): Kill.
(bb_hash_func, bb_eq_func): New static functions.
(debug_dominace_info): New global function.
(calculate_dominance_info): Use new et forest structure.
(free_dominace_info, get_immediate_dominator, set_immediate_dominator,
get_dominated_by, redirect_immediate_dominators,
nearest_common_dominator, dominated_by_p, verify_dominators,
recount_dominator, iterate_fix_dominators, add_to_dominace_info,
delete_from_dominance_info): New global functions.
* gcse.c (domnators): CHange to dominance_info.
(alloc_hoist_mem): Do not alloc dominators
(free_code_hoist_mem): Use free_dominance_info.
(compute_code_hoist_data): Use dominance_info.
(hoist_code): Likewise.
* ifcvt.c (post_dominators): Likewise.
(find_if_case_2, if_convert): Likewise.
* predict.c (process_note_predictions, process_note_prediction,
estimate-probability): Likewise.
* sched-rgn.c (find_rgns, init_regions): Likewise.
* ssa-dce.c (find_all_control_dependences, fint_control_depemndence,
find_pdom, delete_insn_bb, ssa_eliminate_dead_code): Likewise.
* ssa.c (compute_dominance_frontiers_1, rename_block, rename_registers,
find_evaluations, convert_to_ssa): Likewise.
* ssa.h (compute_dominance_frontiers): Likewise.
Thu Jun 6 22:57:34 CEST 2002 Pavel Nejedly <bim@atrey.karlin.mff.cuni.cz>
* Makefile.in (et-forest.c): Add.
* et-forest.c: New file.
* at-forest.h: New file.
Co-Authored-By: Pavel Nejedly <bim@atrey.karlin.mff.cuni.cz>
From-SVN: r54843
Diffstat (limited to 'gcc/ssa.c')
-rw-r--r-- | gcc/ssa.c | 35 |
1 files changed, 18 insertions, 17 deletions
@@ -165,7 +165,7 @@ struct rename_context; static inline rtx * phi_alternative PARAMS ((rtx, int)); static void compute_dominance_frontiers_1 - PARAMS ((sbitmap *frontiers, int *idom, int bb, sbitmap done)); + PARAMS ((sbitmap *frontiers, dominance_info idom, int bb, sbitmap done)); static void find_evaluations_1 PARAMS ((rtx dest, rtx set, void *data)); static void find_evaluations @@ -183,9 +183,9 @@ static void apply_delayed_renames static int rename_insn_1 PARAMS ((rtx *ptr, void *data)); static void rename_block - PARAMS ((int b, int *idom)); + PARAMS ((int b, dominance_info dom)); static void rename_registers - PARAMS ((int nregs, int *idom)); + PARAMS ((int nregs, dominance_info idom)); static inline int ephi_add_node PARAMS ((rtx reg, rtx *nodes, int *n_nodes)); @@ -516,7 +516,7 @@ find_evaluations (evals, nregs) static void compute_dominance_frontiers_1 (frontiers, idom, bb, done) sbitmap *frontiers; - int *idom; + dominance_info idom; int bb; sbitmap done; { @@ -531,7 +531,8 @@ compute_dominance_frontiers_1 (frontiers, idom, bb, done) dominator tree (blocks dominated by this one) are children in the CFG, so check all blocks. */ FOR_EACH_BB (c) - if (idom[c->index] == bb && ! TEST_BIT (done, c->index)) + if (get_immediate_dominator (idom, c)->index == bb + && ! TEST_BIT (done, c->index)) compute_dominance_frontiers_1 (frontiers, idom, c->index, done); /* Find blocks conforming to rule (1) above. */ @@ -539,18 +540,18 @@ compute_dominance_frontiers_1 (frontiers, idom, bb, done) { if (e->dest == EXIT_BLOCK_PTR) continue; - if (idom[e->dest->index] != bb) + if (get_immediate_dominator (idom, e->dest)->index != bb) SET_BIT (frontiers[bb], e->dest->index); } /* Find blocks conforming to rule (2). */ FOR_EACH_BB (c) - if (idom[c->index] == bb) + if (get_immediate_dominator (idom, c)->index == bb) { int x; EXECUTE_IF_SET_IN_SBITMAP (frontiers[c->index], 0, x, { - if (idom[x] != bb) + if (get_immediate_dominator (idom, BASIC_BLOCK (x))->index != bb) SET_BIT (frontiers[bb], x); }); } @@ -559,7 +560,7 @@ compute_dominance_frontiers_1 (frontiers, idom, bb, done) void compute_dominance_frontiers (frontiers, idom) sbitmap *frontiers; - int *idom; + dominance_info idom; { sbitmap done = sbitmap_alloc (last_basic_block); sbitmap_zero (done); @@ -1001,7 +1002,7 @@ gen_sequence () static void rename_block (bb, idom) int bb; - int *idom; + dominance_info idom; { basic_block b = BASIC_BLOCK (bb); edge e; @@ -1111,7 +1112,7 @@ rename_block (bb, idom) dominator order. */ FOR_EACH_BB (c) - if (idom[c->index] == bb) + if (get_immediate_dominator (idom, c)->index == bb) rename_block (c->index, idom); /* Step Four: Update the sets to refer to their new register, @@ -1137,7 +1138,7 @@ rename_block (bb, idom) static void rename_registers (nregs, idom) int nregs; - int *idom; + dominance_info idom; { VARRAY_RTX_INIT (ssa_definition, nregs * 3, "ssa_definition"); ssa_rename_from_initialize (); @@ -1168,7 +1169,7 @@ convert_to_ssa () sbitmap *idfs; /* Element I is the immediate dominator of block I. */ - int *idom; + dominance_info idom; int nregs; @@ -1182,15 +1183,14 @@ convert_to_ssa () dead code. We'll let the SSA optimizers do that. */ life_analysis (get_insns (), NULL, 0); - idom = (int *) alloca (last_basic_block * sizeof (int)); - memset ((void *) idom, -1, (size_t) last_basic_block * sizeof (int)); - calculate_dominance_info (idom, NULL, CDI_DOMINATORS); + idom = calculate_dominance_info (CDI_DOMINATORS); if (rtl_dump_file) { fputs (";; Immediate Dominators:\n", rtl_dump_file); FOR_EACH_BB (bb) - fprintf (rtl_dump_file, ";\t%3d = %3d\n", bb->index, idom[bb->index]); + fprintf (rtl_dump_file, ";\t%3d = %3d\n", bb->index, + get_immediate_dominator (idom, bb)->index); fflush (rtl_dump_file); } @@ -1241,6 +1241,7 @@ convert_to_ssa () in_ssa_form = 1; reg_scan (get_insns (), max_reg_num (), 1); + free_dominance_info (idom); } /* REG is the representative temporary of its partition. Add it to the |