From 7d4f18f5ca7ffaf31fdcd834ba7c1aa7dcffa06e Mon Sep 17 00:00:00 2001 From: marxin Date: Tue, 9 Aug 2016 20:57:39 +0000 Subject: [PATCH] Fix usage of POW2 histogram * value-prof.c (gimple_divmod_values_to_profile): Do not instrument MOD histogram if a value is not a SSA name. * gcc.dg/tree-prof/val-prof-9.c: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@239305 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/ChangeLog | 5 +++++ gcc/testsuite/ChangeLog | 4 ++++ gcc/testsuite/gcc.dg/tree-prof/val-prof-9.c | 18 ++++++++++++++++++ gcc/value-prof.c | 3 ++- 4 files changed, 29 insertions(+), 1 deletion(-) create mode 100644 gcc/testsuite/gcc.dg/tree-prof/val-prof-9.c diff --git a/gcc/ChangeLog b/gcc/ChangeLog index dc14d6f10e70..2b1d5ffb00ec 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,10 @@ 2016-08-09 Martin Liska + * value-prof.c (gimple_divmod_values_to_profile): Do not + instrument MOD histogram if a value is not a SSA name. + +2016-08-09 Martin Liska + * value-prof.c (dump_histogram_value): Swap pow2 and non-pow2 values. diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 927f1e31a321..55ff0819c0d8 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,9 @@ 2016-08-09 Martin Liska + * gcc.dg/tree-prof/val-prof-9.c: New test. + +2016-08-09 Martin Liska + * gcc.dg/tree-prof/val-prof-8.c: New test. 2016-08-09 Martin Jambor diff --git a/gcc/testsuite/gcc.dg/tree-prof/val-prof-9.c b/gcc/testsuite/gcc.dg/tree-prof/val-prof-9.c new file mode 100644 index 000000000000..8fc23015938a --- /dev/null +++ b/gcc/testsuite/gcc.dg/tree-prof/val-prof-9.c @@ -0,0 +1,18 @@ +/* { dg-options "-O0 -fdump-tree-optimized" } */ + +int +main (int argc, char **argv) +{ + unsigned u = (argc - 1); + int counter = 0; + + for (unsigned i = 0; i < 100; i++) + { + counter += u % 16; + } + + return counter; +} + +/* autofdo does not do value profiling so far */ +/* { dg-final-use-not-autofdo { scan-tree-dump-times "__gcov_pow2_profiler" 0 "optimized" } } */ diff --git a/gcc/value-prof.c b/gcc/value-prof.c index 0527c2cc7385..a4653aa8ee98 100644 --- a/gcc/value-prof.c +++ b/gcc/value-prof.c @@ -1950,7 +1950,8 @@ gimple_divmod_values_to_profile (gimple *stmt, histogram_values *values) /* For mod, check whether it is not often a noop (or replaceable by a few subtractions). */ if (gimple_assign_rhs_code (stmt) == TRUNC_MOD_EXPR - && TYPE_UNSIGNED (type)) + && TYPE_UNSIGNED (type) + && TREE_CODE (divisor) == SSA_NAME) { tree val; /* Check for a special case where the divisor is power of 2. */ -- 2.11.4.GIT