From 24bc216e687db2ac9c74a3c421e6b085e6705825 Mon Sep 17 00:00:00 2001 From: hubicka Date: Wed, 14 Mar 2007 01:26:00 +0000 Subject: [PATCH] * ipa-inline.c (cgraph_maybe_hot_edge_p): Look for hot/cold attributes, when profile esitmate is present, calls with very low frequency are cold. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@122898 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/ChangeLog | 6 ++++++ gcc/ipa-inline.c | 9 +++++++++ 2 files changed, 15 insertions(+) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 1a40c6f846e3..b90b689e8379 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2007-03-13 Jan Hubicka + + * ipa-inline.c (cgraph_maybe_hot_edge_p): Look for hot/cold attributes, + when profile esitmate is present, calls with very low frequency are + cold. + 2007-03-13 Zdenek Dvorak PR tree-optimization/30730 diff --git a/gcc/ipa-inline.c b/gcc/ipa-inline.c index 67ca5fdee247..04306aaa7e06 100644 --- a/gcc/ipa-inline.c +++ b/gcc/ipa-inline.c @@ -472,6 +472,15 @@ cgraph_maybe_hot_edge_p (struct cgraph_edge *edge) && (edge->count <= profile_info->sum_max / PARAM_VALUE (HOT_BB_COUNT_FRACTION))) return false; + if (lookup_attribute ("cold", DECL_ATTRIBUTES (edge->callee->decl)) + || lookup_attribute ("cold", DECL_ATTRIBUTES (edge->caller->decl))) + return false; + if (lookup_attribute ("hot", DECL_ATTRIBUTES (edge->caller->decl))) + return true; + if (flag_guess_branch_prob + && edge->frequency < (CGRAPH_FREQ_MAX + / PARAM_VALUE (HOT_BB_FREQUENCY_FRACTION))) + return false; return true; } -- 2.47.3