aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/predict.c20
2 files changed, 16 insertions, 9 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 5b8d35e..697ed16 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2017-06-08 Jan Hubicka <hubicka@ucw.cz>
+
+ * predict.c (unlikely_executed_edge_p): Move ahead.
+ (probably_never_executed_edge_p): Use it.
+
2017-06-08 Alexander Ivchenko <alexander.ivchenko@intel.com>
PR middle-end/79988
diff --git a/gcc/predict.c b/gcc/predict.c
index b460a6f..bf93230 100644
--- a/gcc/predict.c
+++ b/gcc/predict.c
@@ -238,11 +238,22 @@ probably_never_executed_bb_p (struct function *fun, const_basic_block bb)
}
+/* Return true if E is unlikely executed for obvious reasons. */
+
+static bool
+unlikely_executed_edge_p (edge e)
+{
+ return e->count == profile_count::zero ()
+ || (e->flags & (EDGE_EH | EDGE_FAKE));
+}
+
/* Return true in case edge E is probably never executed. */
bool
probably_never_executed_edge_p (struct function *fun, edge e)
{
+ if (e->count.initialized_p ())
+ unlikely_executed_edge_p (e);
return probably_never_executed (fun, e->count, EDGE_FREQUENCY (e));
}
@@ -761,15 +772,6 @@ dump_prediction (FILE *file, enum br_predictor predictor, int probability,
fprintf (file, "\n");
}
-/* Return true if E is unlikely executed. */
-
-static bool
-unlikely_executed_edge_p (edge e)
-{
- return e->count == profile_count::zero ()
- || (e->flags & (EDGE_EH | EDGE_FAKE));
-}
-
/* Return true if STMT is known to be unlikely executed. */
static bool