diff options
author | Jan Hubicka <jh@suse.cz> | 2020-10-31 10:18:06 +0100 |
---|---|---|
committer | Jan Hubicka <jh@suse.cz> | 2020-10-31 10:18:06 +0100 |
commit | ae7a23a3fab74ebd45203d48fa09681c9945ee7a (patch) | |
tree | dd288d22c32cd5f609204c5a62c74dd025194459 /gcc/ipa-prop.c | |
parent | 617695cdc2b3d950f1e4deb5ea85d5cc302943f4 (diff) | |
download | gcc-ae7a23a3fab74ebd45203d48fa09681c9945ee7a.zip gcc-ae7a23a3fab74ebd45203d48fa09681c9945ee7a.tar.gz gcc-ae7a23a3fab74ebd45203d48fa09681c9945ee7a.tar.bz2 |
Move clone_info to summary
* Makefile.in: (OBJS): Add symtab-clones.o
(GTFILES): Add symtab-clones.h
* cgraph.c: Include symtab-clones.h.
(cgraph_edge::resolve_speculation): Fix formating
(cgraph_edge::redirect_call_stmt_to_callee): Update.
(cgraph_update_edges_for_call_stmt): Update
(release_function_body): Fix formating.
(cgraph_node::remove): Fix formating.
(cgraph_node::dump): Fix formating.
(cgraph_node::get_availability): Fix formating.
(cgraph_node::call_for_symbol_thunks_and_aliases): Fix formating.
(set_const_flag_1): Fix formating.
(set_pure_flag_1): Fix formating.
(cgraph_node::can_remove_if_no_direct_calls_p): Fix formating.
(collect_callers_of_node_1): Fix formating.
(clone_of_p): Update.
(cgraph_node::verify_node): Update.
(cgraph_c_finalize): Call clone_info::release ().
* cgraph.h (struct cgraph_clone_info): Move to symtab-clones.h.
(cgraph_node): Remove clone_info.
(symbol_table): Add m_clones.
* cgraphclones.c: Include symtab-clone.h.
(duplicate_thunk_for_node): Update.
(cgraph_node::create_clone): Update.
(cgraph_node::create_virtual_clone): Update.
(cgraph_node::find_replacement): Update.
(cgraph_node::materialize_clone): Update.
* gengtype.c (open_base_files): Include symtab-clones.h.
* ipa-cp.c: Include symtab-clones.h.
(initialize_node_lattices): Update.
(want_remove_some_param_p): Update.
(create_specialized_node): Update.
* ipa-fnsummary.c: Include symtab-clones.h.
(ipa_fn_summary_t::duplicate): Update.
* ipa-modref.c: Include symtab-clones.h.
(update_signature): Update.
* ipa-param-manipulation.c: Include symtab-clones.h.
(ipa_param_body_adjustments::common_initialization): Update.
* ipa-prop.c: Include symtab-clones.h.
(adjust_agg_replacement_values): Update.
(ipcp_get_parm_bits): Update.
(ipcp_update_bits): Update.
(ipcp_update_vr): Update.
* ipa-sra.c: Include symtab-clones.h.
(process_isra_node_results): Update.
(disable_unavailable_parameters): Update.
* lto-cgraph.c: Include symtab-clone.h.
(output_cgraph_opt_summary_p): Update.
(output_node_opt_summary): Update.
(input_node_opt_summary): Update.
* symtab-clones.cc: New file.
* symtab-clones.h: New file.
* tree-inline.c (expand_call_inline): Update.
(update_clone_info): Update.
(tree_function_versioning): Update.
Diffstat (limited to 'gcc/ipa-prop.c')
-rw-r--r-- | gcc/ipa-prop.c | 21 |
1 files changed, 13 insertions, 8 deletions
diff --git a/gcc/ipa-prop.c b/gcc/ipa-prop.c index 6014766..d4ef6ff 100644 --- a/gcc/ipa-prop.c +++ b/gcc/ipa-prop.c @@ -53,6 +53,7 @@ along with GCC; see the file COPYING3. If not see #include "builtins.h" #include "tree-cfgcleanup.h" #include "options.h" +#include "symtab-clones.h" /* Function summary where the parameter infos are actually stored. */ ipa_node_params_t *ipa_node_params_sum = NULL; @@ -5419,12 +5420,13 @@ adjust_agg_replacement_values (struct cgraph_node *node, struct ipa_agg_replacement_value *aggval) { struct ipa_agg_replacement_value *v; + clone_info *cinfo = clone_info::get (node); - if (!node->clone.param_adjustments) + if (!cinfo || !cinfo->param_adjustments) return; auto_vec<int, 16> new_indices; - node->clone.param_adjustments->get_updated_indices (&new_indices); + cinfo->param_adjustments->get_updated_indices (&new_indices); for (v = aggval; v; v = v->next) { gcc_checking_assert (v->index >= 0); @@ -5577,9 +5579,10 @@ ipcp_get_parm_bits (tree parm, tree *value, widest_int *mask) return false; } - if (cnode->clone.param_adjustments) + clone_info *cinfo = clone_info::get (cnode); + if (cinfo && cinfo->param_adjustments) { - i = cnode->clone.param_adjustments->get_original_index (i); + i = cinfo->param_adjustments->get_original_index (i); if (i < 0) return false; } @@ -5610,9 +5613,10 @@ ipcp_update_bits (struct cgraph_node *node) auto_vec<int, 16> new_indices; bool need_remapping = false; - if (node->clone.param_adjustments) + clone_info *cinfo = clone_info::get (node); + if (cinfo && cinfo->param_adjustments) { - node->clone.param_adjustments->get_updated_indices (&new_indices); + cinfo->param_adjustments->get_updated_indices (&new_indices); need_remapping = true; } auto_vec <tree, 16> parm_decls; @@ -5731,9 +5735,10 @@ ipcp_update_vr (struct cgraph_node *node) auto_vec<int, 16> new_indices; bool need_remapping = false; - if (node->clone.param_adjustments) + clone_info *cinfo = clone_info::get (node); + if (cinfo && cinfo->param_adjustments) { - node->clone.param_adjustments->get_updated_indices (&new_indices); + cinfo->param_adjustments->get_updated_indices (&new_indices); need_remapping = true; } auto_vec <tree, 16> parm_decls; |