Commit 3de12329 authored by Mythri A's avatar Mythri A Committed by Commit Bot

[turboprop] Fix Turboprop to Turbofan tiering heuristics

1. Don't optimize small functions early when tiering up from ignition
to Turboprop.
2. When tiering up from Turboprop to Turbofan scale the ticks so we
optimize small functions at roughly same time as default.
3. Adjust for the fact that profiler ticks are updated before performing
the ShouldOptimize check when tiering up from TP -> TF.

Bug: v8:9684
Change-Id: I6b68eed70abb9a86f9b99eac9c0b9a1fe6346027
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2560725
Commit-Queue: Mythri Alle <mythria@chromium.org>
Reviewed-by: 's avatarRoss McIlroy <rmcilroy@chromium.org>
Cr-Commit-Position: refs/heads/master@{#71436}
parent 3688dd61
...@@ -232,6 +232,27 @@ bool RuntimeProfiler::MaybeOSR(JSFunction function, InterpretedFrame* frame) { ...@@ -232,6 +232,27 @@ bool RuntimeProfiler::MaybeOSR(JSFunction function, InterpretedFrame* frame) {
return false; return false;
} }
namespace {
bool ShouldOptimizeAsSmallFunction(int bytecode_size, int ticks,
bool any_ic_changed,
bool active_tier_is_turboprop) {
if (any_ic_changed || bytecode_size >= kMaxBytecodeSizeForEarlyOpt)
return false;
// Without turboprop we always allow early optimizations for small functions
if (!FLAG_turboprop) return true;
// For turboprop, we only do small function optimizations when tiering up from
// TP-> TF. We should also scale the ticks, so we optimize small functions
// when reaching one tick for top tier.
// TODO(turboprop, mythria): Investigate if small function optimization is
// required at all and avoid this if possible by changing the heuristics to
// take function size into account.
return active_tier_is_turboprop &&
ticks > FLAG_ticks_scale_factor_for_top_tier;
}
} // namespace
OptimizationReason RuntimeProfiler::ShouldOptimize(JSFunction function, OptimizationReason RuntimeProfiler::ShouldOptimize(JSFunction function,
BytecodeArray bytecode) { BytecodeArray bytecode) {
if (function.ActiveTierIsTurbofan()) { if (function.ActiveTierIsTurbofan()) {
...@@ -241,20 +262,26 @@ OptimizationReason RuntimeProfiler::ShouldOptimize(JSFunction function, ...@@ -241,20 +262,26 @@ OptimizationReason RuntimeProfiler::ShouldOptimize(JSFunction function,
return OptimizationReason::kDoNotOptimize; return OptimizationReason::kDoNotOptimize;
} }
int ticks = function.feedback_vector().profiler_ticks(); int ticks = function.feedback_vector().profiler_ticks();
int scale_factor = function.ActiveTierIsMidtierTurboprop() bool active_tier_is_turboprop = function.ActiveTierIsMidtierTurboprop();
? FLAG_ticks_scale_factor_for_top_tier int scale_factor =
: 1; active_tier_is_turboprop ? FLAG_ticks_scale_factor_for_top_tier : 1;
// TODO(turboprop, mythria): There is a difference in when we increment the
// profiler ticks on the feedback vector. For interrupts from interpreted code
// we increment after the tier up decision and from optimized code we
// increment before the decision. So we need to adjust the ticks here if we
// are tiering up from Turboprop to Turbofan. The right fix is to make the
// increments consistent in both places and avoid adding one additional tick
// here.
int ticks_for_optimization = int ticks_for_optimization =
kProfilerTicksBeforeOptimization + kProfilerTicksBeforeOptimization +
(bytecode.length() / kBytecodeSizeAllowancePerTick); (bytecode.length() / kBytecodeSizeAllowancePerTick) +
(active_tier_is_turboprop ? 1 : 0);
ticks_for_optimization *= scale_factor; ticks_for_optimization *= scale_factor;
if (ticks >= ticks_for_optimization) { if (ticks >= ticks_for_optimization) {
return OptimizationReason::kHotAndStable; return OptimizationReason::kHotAndStable;
} else if (!any_ic_changed_ && } else if (ShouldOptimizeAsSmallFunction(bytecode.length(), ticks,
bytecode.length() < kMaxBytecodeSizeForEarlyOpt) { any_ic_changed_,
// TODO(turboprop, mythria): Do we need to support small function active_tier_is_turboprop)) {
// optimization for TP->TF tier up. If so, do we want to scale the bytecode
// size?
// If no IC was patched since the last tick and this function is very // If no IC was patched since the last tick and this function is very
// small, optimistically optimize it now. // small, optimistically optimize it now.
return OptimizationReason::kSmallFunction; return OptimizationReason::kSmallFunction;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment