diff options
author | Richard Biener <rguenther@suse.de> | 2016-08-18 10:41:53 +0000 |
---|---|---|
committer | Richard Biener <rguenth@gcc.gnu.org> | 2016-08-18 10:41:53 +0000 |
commit | f02510201aff3a572f7c67fcce3ee90c127ecd76 (patch) | |
tree | 66731264e5aac24db0964fd44ab89db11412cc57 | |
parent | 9c62c8735891bd29be0bc379b51b295f2838019a (diff) | |
download | gcc-f02510201aff3a572f7c67fcce3ee90c127ecd76.zip gcc-f02510201aff3a572f7c67fcce3ee90c127ecd76.tar.gz gcc-f02510201aff3a572f7c67fcce3ee90c127ecd76.tar.bz2 |
tree-pass.h (make_pass_materialize_all_clones): Declare.
2016-08-18 Richard Biener <rguenther@suse.de>
* tree-pass.h (make_pass_materialize_all_clones): Declare.
* ipa.c (pass_data_materialize_all_clones, pass_materialize_all_clones,
make_pass_materialize_all_clones): New simple IPA pass encapsulating
clone materialization.
* passes.def (all_late_ipa_passes): Start with
pass_materialize_all_clones.
* cgraphunit.c (symbol_table::compile): Remove call to
materialize_all_clones.
* tree-into-ssa.c: Include statistics.h.
(update_ssa): Count number of times we do incremental/rewrite
SSA update.
From-SVN: r239567
-rw-r--r-- | gcc/ChangeLog | 14 | ||||
-rw-r--r-- | gcc/cgraphunit.c | 1 | ||||
-rw-r--r-- | gcc/ipa.c | 41 | ||||
-rw-r--r-- | gcc/passes.def | 1 | ||||
-rw-r--r-- | gcc/tree-into-ssa.c | 5 | ||||
-rw-r--r-- | gcc/tree-pass.h | 2 |
6 files changed, 63 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 20c5d58..7df2a9a 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,19 @@ 2016-08-18 Richard Biener <rguenther@suse.de> + * tree-pass.h (make_pass_materialize_all_clones): Declare. + * ipa.c (pass_data_materialize_all_clones, pass_materialize_all_clones, + make_pass_materialize_all_clones): New simple IPA pass encapsulating + clone materialization. + * passes.def (all_late_ipa_passes): Start with + pass_materialize_all_clones. + * cgraphunit.c (symbol_table::compile): Remove call to + materialize_all_clones. + * tree-into-ssa.c: Include statistics.h. + (update_ssa): Count number of times we do incremental/rewrite + SSA update. + +2016-08-18 Richard Biener <rguenther@suse.de> + PR tree-optimization/77282 * tree-ssa-pre.c (eliminate_dom_walker::before_dom_children): When doing auto-parallelizing also prevent use of PHIs that diff --git a/gcc/cgraphunit.c b/gcc/cgraphunit.c index d8f7903..6a1d126 100644 --- a/gcc/cgraphunit.c +++ b/gcc/cgraphunit.c @@ -2435,7 +2435,6 @@ symbol_table::compile (void) fprintf (stderr, "Assembling functions:\n"); symtab_node::checking_verify_symtab_nodes (); - materialize_all_clones (); bitmap_obstack_initialize (NULL); execute_ipa_pass_list (g->get_passes ()->all_late_ipa_passes); bitmap_obstack_release (NULL); @@ -1443,3 +1443,44 @@ make_pass_ipa_single_use (gcc::context *ctxt) { return new pass_ipa_single_use (ctxt); } + +/* Materialize all clones. */ + +namespace { + +const pass_data pass_data_materialize_all_clones = +{ + SIMPLE_IPA_PASS, /* type */ + "materialize-all-clones", /* name */ + OPTGROUP_NONE, /* optinfo_flags */ + TV_IPA_OPT, /* tv_id */ + 0, /* properties_required */ + 0, /* properties_provided */ + 0, /* properties_destroyed */ + 0, /* todo_flags_start */ + 0, /* todo_flags_finish */ +}; + +class pass_materialize_all_clones : public simple_ipa_opt_pass +{ +public: + pass_materialize_all_clones (gcc::context *ctxt) + : simple_ipa_opt_pass (pass_data_materialize_all_clones, ctxt) + {} + + /* opt_pass methods: */ + virtual unsigned int execute (function *) + { + symtab->materialize_all_clones (); + return 0; + } + +}; // class pass_materialize_all_clones + +} // anon namespace + +simple_ipa_opt_pass * +make_pass_materialize_all_clones (gcc::context *ctxt) +{ + return new pass_materialize_all_clones (ctxt); +} diff --git a/gcc/passes.def b/gcc/passes.def index 3647e90..533157d 100644 --- a/gcc/passes.def +++ b/gcc/passes.def @@ -167,6 +167,7 @@ along with GCC; see the file COPYING3. If not see passes are executed after partitioning and thus see just parts of the compiled unit. */ INSERT_PASSES_AFTER (all_late_ipa_passes) + NEXT_PASS (pass_materialize_all_clones); NEXT_PASS (pass_ipa_pta); NEXT_PASS (pass_dispatcher_calls); NEXT_PASS (pass_omp_simd_clone); diff --git a/gcc/tree-into-ssa.c b/gcc/tree-into-ssa.c index 7ed9b9d..ceafa68 100644 --- a/gcc/tree-into-ssa.c +++ b/gcc/tree-into-ssa.c @@ -37,6 +37,7 @@ along with GCC; see the file COPYING3. If not see #include "tree-dfa.h" #include "tree-ssa.h" #include "domwalk.h" +#include "statistics.h" #define PERCENT(x,y) ((float)(x) * 100.0 / (float)(y)) @@ -3248,6 +3249,8 @@ update_ssa (unsigned update_flags) OLD_SSA_NAMES. */ if (bitmap_first_set_bit (new_ssa_names) >= 0) { + statistics_counter_event (cfun, "Incremental SSA update", 1); + prepare_names_to_update (insert_phi_p); /* If all the names in NEW_SSA_NAMES had been marked for @@ -3261,6 +3264,8 @@ update_ssa (unsigned update_flags) /* Next, determine the block at which to start the renaming process. */ if (cfun->gimple_df->ssa_renaming_needed) { + statistics_counter_event (cfun, "Symbol to SSA rewrite", 1); + /* If we rename bare symbols initialize the mapping to auxiliar info we need to keep track of. */ var_infos = new hash_table<var_info_hasher> (47); diff --git a/gcc/tree-pass.h b/gcc/tree-pass.h index 36299a6..c0059de 100644 --- a/gcc/tree-pass.h +++ b/gcc/tree-pass.h @@ -504,6 +504,8 @@ extern ipa_opt_pass_d *make_pass_ipa_profile (gcc::context *ctxt); extern ipa_opt_pass_d *make_pass_ipa_cdtor_merge (gcc::context *ctxt); extern ipa_opt_pass_d *make_pass_ipa_single_use (gcc::context *ctxt); extern ipa_opt_pass_d *make_pass_ipa_comdats (gcc::context *ctxt); +extern simple_ipa_opt_pass *make_pass_materialize_all_clones (gcc::context * + ctxt); extern gimple_opt_pass *make_pass_cleanup_cfg_post_optimizing (gcc::context *ctxt); |