From: Jan Hubicka Date: Sat, 13 Jan 2018 19:32:04 +0000 (+0100) Subject: predict.c (determine_unlikely_bbs): Handle correctly BBs which appears in the queue... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=f36180f4a415cb579461f8f3e79a1a4aa80e6be8;p=gcc.git 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 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 37656fa68ae..bcc77eb28d9 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2018-01-13 Jan Hubicka + + * predict.c (determine_unlikely_bbs): Handle correctly BBs + which appears in the queue multiple times. + 2018-01-13 Richard Sandiford Alan Hayward David Sherwood 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);