From 9faab400b8cf0611f14d377ea55a58d99795fa57 Mon Sep 17 00:00:00 2001 From: Igor Veresov Date: Wed, 11 Aug 2021 20:19:36 +0000 Subject: [PATCH] 8272330: C2: Cleanup profile counter scaling Reviewed-by: kvn --- src/hotspot/share/ci/ciMethod.cpp | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/src/hotspot/share/ci/ciMethod.cpp b/src/hotspot/share/ci/ciMethod.cpp index 7d03cfb6aa5..2aa70e23b89 100644 --- a/src/hotspot/share/ci/ciMethod.cpp +++ b/src/hotspot/share/ci/ciMethod.cpp @@ -880,17 +880,16 @@ ciKlass* ciMethod::get_declared_method_holder_at_bci(int bci) { // invocation counts in methods. int ciMethod::scale_count(int count, float prof_factor) { if (count > 0 && method_data() != NULL) { - int counter_life; + int counter_life = method_data()->invocation_count(); int method_life = interpreter_invocation_count(); - // In tiered the MDO's life is measured directly, so just use the snapshotted counters - counter_life = MAX2(method_data()->invocation_count(), method_data()->backedge_count()); - - // counter_life due to backedge_counter could be > method_life - if (counter_life > method_life) - counter_life = method_life; - if (0 < counter_life && counter_life <= method_life) { + if (method_life < counter_life) { // may happen because of the snapshot timing + method_life = counter_life; + } + if (counter_life > 0) { count = (int)((double)count * prof_factor * method_life / counter_life + 0.5); count = (count > 0) ? count : 1; + } else { + count = 1; } } return count;