aboutsummaryrefslogtreecommitdiff
path: root/gcc/profile-count.h
diff options
context:
space:
mode:
authorJan Hubicka <hubicka@ucw.cz>2017-06-05 19:41:32 +0200
committerJan Hubicka <hubicka@gcc.gnu.org>2017-06-05 17:41:32 +0000
commitaea5e79a63f965a9ed5fd2ef1943e3865495e987 (patch)
tree52c60043f6ed486d65cb1a8a38cb71979166465c /gcc/profile-count.h
parent2f20e7db2caea4909ddff539b2419c9f34c907c4 (diff)
downloadgcc-aea5e79a63f965a9ed5fd2ef1943e3865495e987.zip
gcc-aea5e79a63f965a9ed5fd2ef1943e3865495e987.tar.gz
gcc-aea5e79a63f965a9ed5fd2ef1943e3865495e987.tar.bz2
cfgexpand.c (expand_gimple_tailcall): Initialize profile of new edge.
* cfgexpand.c (expand_gimple_tailcall): Initialize profile of new edge. * ipa-inline.c (want_inline_self_recursive_call_p): Watch for missing profile in callgraph edge. * profile-count.h (apply_probability): If THIS is 0, then result is 0 (apply_scale): Likewise. * tree-inline.c (copy_bb, copy_edges_for_bb, copy_cfg_body): Also scale profile when inlining function with zero profile. (initialize_cfun): Update exit block profile even when it is zero. * tree-ssa-threadupdate.c (clear_counts_path): Handle correctly case when profile is read. From-SVN: r248885
Diffstat (limited to 'gcc/profile-count.h')
-rw-r--r--gcc/profile-count.h6
1 files changed, 5 insertions, 1 deletions
diff --git a/gcc/profile-count.h b/gcc/profile-count.h
index 2ac7f32..e7815db 100644
--- a/gcc/profile-count.h
+++ b/gcc/profile-count.h
@@ -221,6 +221,8 @@ public:
profile_count apply_probability (int prob) const
{
gcc_checking_assert (prob >= 0 && prob <= REG_BR_PROB_BASE);
+ if (*this == profile_count::zero ())
+ return *this;
if (!initialized_p ())
return profile_count::uninitialized ();
profile_count ret;
@@ -230,6 +232,8 @@ public:
/* Return *THIS * NUM / DEN. */
profile_count apply_scale (int64_t num, int64_t den) const
{
+ if (*this == profile_count::zero ())
+ return *this;
if (!initialized_p ())
return profile_count::uninitialized ();
profile_count ret;
@@ -243,7 +247,7 @@ public:
}
profile_count apply_scale (profile_count num, profile_count den) const
{
- if (*this == profile_count::zero ())
+ if (*this == profile_count::zero () || num == profile_count::zero ())
return profile_count::zero ();
if (!initialized_p () || !num.initialized_p () || !den.initialized_p ())
return profile_count::uninitialized ();