aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/ChangeLog7
-rw-r--r--gcc/cgraphbuild.c16
2 files changed, 12 insertions, 11 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 32ec554..61e46ff 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,10 @@
+2015-10-11 Jan Hubicka <hubicka@ucw.cz>
+
+ revert:
+ 2015-10-11 Jan Hubicka <hubicka@ucw.cz>
+ * cgraphbuild.c (compute_call_stmt_bb_frequency): Use
+ counts when these are more informative.
+
2015-10-12 Jeff Law <law@redhat.com>
* tree-ssa-threadbackward.c (fsm_find_thread_path): Remove
diff --git a/gcc/cgraphbuild.c b/gcc/cgraphbuild.c
index a7b4af6..33b01be 100644
--- a/gcc/cgraphbuild.c
+++ b/gcc/cgraphbuild.c
@@ -202,21 +202,15 @@ compute_call_stmt_bb_frequency (tree decl, basic_block bb)
{
int entry_freq = ENTRY_BLOCK_PTR_FOR_FN
(DECL_STRUCT_FUNCTION (decl))->frequency;
- gcov_type entry_count = ENTRY_BLOCK_PTR_FOR_FN
- (DECL_STRUCT_FUNCTION (decl))->count;
- gcov_type freq = bb->frequency;
+ int freq = bb->frequency;
if (profile_status_for_fn (DECL_STRUCT_FUNCTION (decl)) == PROFILE_ABSENT)
return CGRAPH_FREQ_BASE;
- if (entry_count > entry_freq)
- freq = RDIV (bb->count * CGRAPH_FREQ_BASE, entry_count);
- else
- {
- if (!entry_freq)
- entry_freq = 1, freq++;
- freq = RDIV (freq * CGRAPH_FREQ_BASE, entry_freq);
- }
+ if (!entry_freq)
+ entry_freq = 1, freq++;
+
+ freq = freq * CGRAPH_FREQ_BASE / entry_freq;
if (freq > CGRAPH_FREQ_MAX)
freq = CGRAPH_FREQ_MAX;