diff options
author | Jan Hubicka <jh@suse.cz> | 2010-05-12 23:32:59 +0200 |
---|---|---|
committer | Jan Hubicka <hubicka@gcc.gnu.org> | 2010-05-12 21:32:59 +0000 |
commit | 5f902d766c18beade9fd700b53a83d4e57622b10 (patch) | |
tree | d7aef00d4cbf971dd328d8e3e60c9fd6278373a2 /gcc/ipa-prop.c | |
parent | 87a0ebfd203382a034b76c3a087d310908005454 (diff) | |
download | gcc-5f902d766c18beade9fd700b53a83d4e57622b10.tar.gz |
cgraphbuild.c (build_cgraph_edges, [...]): Build indrect edges too.
* cgraphbuild.c (build_cgraph_edges, rebuild_cgraph_edges): Build
indrect edges too.
* cgraph.c (cgraph_create_indirect_edge): Take ecf_flags argument.
(cgraph_clone_edge): Update.
(cgraph_node_remove_callees): Remove indirect calls too.
* cgraph.h (cgraph_indirect_call_info): Add ecf_flags.
(cgraph_create_indirect_edge): Update prototype.
* ipa-reference.c (has_proper_scope_for_analysis): Rename to
is_proper_for_analysis.
(add_new_function, visited_nodes, function_insertion_hook_holder,
get_local_reference_vars_info, mark_address_taken, mark_address,
mark_load, mark_store, check_asm_memory_clobber, check_call,
scan_stmt_for_static_refs, scan_initializer_for_static_refs): Remove.
(ipa_init): Do not initialize visited_nodes;
function_insertion_hook_holder.
(analyze_variable): Rewrite.
(analyze_function): Rewrite.
(copy_local_bitmap): Remove.
(duplicate_node_dat): Do not duplicate local info.
(generate_summary): Simplify to only walk cgraph.
(write_node_summary_p, ipa_reference_write_summary,
ipa_reference_read_summary): Remove.
(propagate): Do not remove function insertion;
generate summary.
(pass_ipa_reference): NULLify summary handling fields.
* lto-cgraph.c (lto_output_edge): Output ecf_flags.
(input_edge): Input ecf_flags.
* ipa-prop.c (ipa_note_parm_call): Expect edge to be around.
(update_indirect_edges_after_inlining): Ignore edges with unknown
param.
From-SVN: r159343
Diffstat (limited to 'gcc/ipa-prop.c')
-rw-r--r-- | gcc/ipa-prop.c | 9 |
1 files changed, 3 insertions, 6 deletions
diff --git a/gcc/ipa-prop.c b/gcc/ipa-prop.c index 7ab3a3e607c..d40fe448a3a 100644 --- a/gcc/ipa-prop.c +++ b/gcc/ipa-prop.c @@ -757,12 +757,8 @@ static void ipa_note_param_call (struct cgraph_node *node, int formal_id, gimple stmt) { struct cgraph_edge *cs; - basic_block bb = gimple_bb (stmt); - int freq; - freq = compute_call_stmt_bb_frequency (current_function_decl, bb); - cs = cgraph_create_indirect_edge (node, stmt, bb->count, freq, - bb->loop_depth); + cs = cgraph_edge (node, stmt); cs->indirect_info->param_index = formal_id; } @@ -1071,7 +1067,8 @@ update_indirect_edges_after_inlining (struct cgraph_edge *cs, /* If we ever use indirect edges for anything other than indirect inlining, we will need to skip those with negative param_indices. */ - gcc_assert (ici->param_index >= 0); + if (ici->param_index == -1) + continue; /* We must check range due to calls with variable number of arguments: */ if (ici->param_index >= ipa_get_cs_argument_count (top)) |