cgraphbuild.c (cgraph_rebuild_references): New.
* cgraphbuild.c (cgraph_rebuild_references): New. (cgraph_mark_reachable_node): Accept references to optimized out extern inlines. * cgraph.h (cgraph_rebuild_references): Declare. * tree-inline.c (tree_function_versioning): Use it. * ipa-struct-reorg.c (do_reorg_for_func): Likewise. From-SVN: r159259
This commit is contained in:
parent
a940b4d9ab
commit
99b766fc8b
|
@ -1,3 +1,12 @@
|
|||
2010-05-11 Jan Hubicka <jh@suse.cz>
|
||||
|
||||
* cgraphbuild.c (cgraph_rebuild_references): New.
|
||||
(cgraph_mark_reachable_node): Accept references to optimized out
|
||||
extern inlines.
|
||||
* cgraph.h (cgraph_rebuild_references): Declare.
|
||||
* tree-inline.c (tree_function_versioning): Use it.
|
||||
* ipa-struct-reorg.c (do_reorg_for_func): Likewise.
|
||||
|
||||
2010-05-11 Jan Hubicka <jh@suse.cz>
|
||||
|
||||
* cgraph.c: Include ipa-utils.h
|
||||
|
|
|
@ -619,6 +619,7 @@ gimple cgraph_redirect_edge_call_stmt_to_callee (struct cgraph_edge *);
|
|||
bool cgraph_propagate_frequency (struct cgraph_node *node);
|
||||
/* In cgraphbuild.c */
|
||||
unsigned int rebuild_cgraph_edges (void);
|
||||
void cgraph_rebuild_references (void);
|
||||
void reset_inline_failed (struct cgraph_node *);
|
||||
int compute_call_stmt_bb_frequency (tree, basic_block bb);
|
||||
|
||||
|
|
|
@ -463,6 +463,37 @@ rebuild_cgraph_edges (void)
|
|||
return 0;
|
||||
}
|
||||
|
||||
/* Rebuild cgraph edges for current function node. This needs to be run after
|
||||
passes that don't update the cgraph. */
|
||||
|
||||
void
|
||||
cgraph_rebuild_references (void)
|
||||
{
|
||||
basic_block bb;
|
||||
struct cgraph_node *node = cgraph_node (current_function_decl);
|
||||
gimple_stmt_iterator gsi;
|
||||
|
||||
ipa_remove_all_references (&node->ref_list);
|
||||
|
||||
node->count = ENTRY_BLOCK_PTR->count;
|
||||
|
||||
FOR_EACH_BB (bb)
|
||||
{
|
||||
for (gsi = gsi_start_bb (bb); !gsi_end_p (gsi); gsi_next (&gsi))
|
||||
{
|
||||
gimple stmt = gsi_stmt (gsi);
|
||||
|
||||
walk_stmt_load_store_addr_ops (stmt, node, mark_load,
|
||||
mark_store, mark_address);
|
||||
|
||||
}
|
||||
for (gsi = gsi_start (phi_nodes (bb)); !gsi_end_p (gsi); gsi_next (&gsi))
|
||||
walk_stmt_load_store_addr_ops (gsi_stmt (gsi), node,
|
||||
mark_load, mark_store, mark_address);
|
||||
}
|
||||
record_eh_tables (node, cfun);
|
||||
}
|
||||
|
||||
struct gimple_opt_pass pass_rebuild_cgraph_edges =
|
||||
{
|
||||
{
|
||||
|
|
|
@ -3241,6 +3241,7 @@ do_reorg_for_func (struct cgraph_node *node)
|
|||
create_new_accesses_for_func ();
|
||||
update_ssa (TODO_update_ssa);
|
||||
cleanup_tree_cfg ();
|
||||
cgraph_rebuild_references ();
|
||||
|
||||
/* Free auxiliary data representing local variables. */
|
||||
free_new_vars_htab (new_local_vars);
|
||||
|
|
|
@ -5037,6 +5037,8 @@ tree_function_versioning (tree old_decl, tree new_decl,
|
|||
pointer_set_destroy (id.statements_to_fold);
|
||||
fold_cond_expr_cond ();
|
||||
delete_unreachable_blocks_update_callgraph (&id);
|
||||
if (id.dst_node->analyzed)
|
||||
cgraph_rebuild_references ();
|
||||
update_ssa (TODO_update_ssa);
|
||||
free_dominance_info (CDI_DOMINATORS);
|
||||
free_dominance_info (CDI_POST_DOMINATORS);
|
||||
|
|
Loading…
Reference in New Issue