summaryrefslogtreecommitdiff
path: root/gcc/predict.c
diff options
context:
space:
mode:
authorJan Hubicka <hubicka@ucw.cz>2018-01-13 20:32:04 +0100
committerJan Hubicka <hubicka@gcc.gnu.org>2018-01-13 19:32:04 +0000
commitf36180f4a415cb579461f8f3e79a1a4aa80e6be8 (patch)
tree74423b123d83963345d78c0b2f20c0b53f441929 /gcc/predict.c
parent39f309aca6e6b756ffab4222ffc39094042b9413 (diff)
predict.c (determine_unlikely_bbs): Handle correctly BBs which appears in the queue multiple times.
* predict.c (determine_unlikely_bbs): Handle correctly BBs which appears in the queue multiple times. From-SVN: r256648
Diffstat (limited to 'gcc/predict.c')
-rw-r--r--gcc/predict.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/gcc/predict.c b/gcc/predict.c
index b6be32d48bc..4c1e4489b55 100644
--- a/gcc/predict.c
+++ b/gcc/predict.c
@@ -3565,6 +3565,8 @@ determine_unlikely_bbs ()
while (worklist.length () > 0)
{
bb = worklist.pop ();
+ if (bb->count == profile_count::zero ())
+ continue;
if (bb != ENTRY_BLOCK_PTR_FOR_FN (cfun))
{
bool found = false;
@@ -3583,8 +3585,7 @@ determine_unlikely_bbs ()
if (found)
continue;
}
- if (!(bb->count == profile_count::zero ())
- && (dump_file && (dump_flags & TDF_DETAILS)))
+ if (dump_file && (dump_flags & TDF_DETAILS))
fprintf (dump_file,
"Basic block %i is marked unlikely by backward prop\n",
bb->index);
@@ -3594,6 +3595,7 @@ determine_unlikely_bbs ()
{
if (!(e->src->count == profile_count::zero ()))
{
+ gcc_checking_assert (nsuccs[e->src->index] > 0);
nsuccs[e->src->index]--;
if (!nsuccs[e->src->index])
worklist.safe_push (e->src);