From e4e822abcdfaba5878845a82722b8bed879d647e Mon Sep 17 00:00:00 2001 From: Jan Hubicka Date: Sun, 16 Jul 2017 18:28:57 +0200 Subject: [PATCH] asan.c (create_cond_insert_point): Avoid use of REG_BR_PROB_BASE fixpoint arithmetics. * asan.c (create_cond_insert_point): Avoid use of REG_BR_PROB_BASE fixpoint arithmetics. From-SVN: r250240 --- gcc/ChangeLog | 5 +++++ gcc/asan.c | 12 +++++------- 2 files changed, 10 insertions(+), 7 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index f3bafa52d37..f17ed1fe91d 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2017-07-16 Jan Hubicka + + * asan.c (create_cond_insert_point): Avoid use of REG_BR_PROB_BASE + fixpoint arithmetics. + 2017-07-16 Jan Hubicka * profile-count.h (profile_probability::from_reg_br_prob_note, diff --git a/gcc/asan.c b/gcc/asan.c index a56174a1656..5f9275f6425 100644 --- a/gcc/asan.c +++ b/gcc/asan.c @@ -1798,12 +1798,11 @@ create_cond_insert_point (gimple_stmt_iterator *iter, /* Set up the newly created 'then block'. */ e = make_edge (cond_bb, then_bb, EDGE_TRUE_VALUE); - int fallthrough_probability + profile_probability fallthrough_probability = then_more_likely_p - ? PROB_VERY_UNLIKELY - : PROB_ALWAYS - PROB_VERY_UNLIKELY; - e->probability = profile_probability::from_reg_br_prob_base - (PROB_ALWAYS - fallthrough_probability); + ? profile_probability::very_unlikely () + : profile_probability::very_likely (); + e->probability = fallthrough_probability.invert (); if (create_then_fallthru_edge) make_single_succ_edge (then_bb, fallthru_bb, EDGE_FALLTHRU); @@ -1811,8 +1810,7 @@ create_cond_insert_point (gimple_stmt_iterator *iter, e = find_edge (cond_bb, fallthru_bb); e->flags = EDGE_FALSE_VALUE; e->count = cond_bb->count; - e->probability - = profile_probability::from_reg_br_prob_base (fallthrough_probability); + e->probability = fallthrough_probability; /* Update dominance info for the newly created then_bb; note that fallthru_bb's dominance info has already been updated by -- 2.30.2