aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Biener <rguenther@suse.de>2016-08-18 10:41:53 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2016-08-18 10:41:53 +0000
commitf02510201aff3a572f7c67fcce3ee90c127ecd76 (patch)
tree66731264e5aac24db0964fd44ab89db11412cc57
parent9c62c8735891bd29be0bc379b51b295f2838019a (diff)
downloadgcc-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/ChangeLog14
-rw-r--r--gcc/cgraphunit.c1
-rw-r--r--gcc/ipa.c41
-rw-r--r--gcc/passes.def1
-rw-r--r--gcc/tree-into-ssa.c5
-rw-r--r--gcc/tree-pass.h2
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);
diff --git a/gcc/ipa.c b/gcc/ipa.c
index 6f4693f..035fb64 100644
--- a/gcc/ipa.c
+++ b/gcc/ipa.c
@@ -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);