Commit dd0ce924 authored by Ulan Degenbaev's avatar Ulan Degenbaev Committed by Commit Bot

Revert "[heap] Removing marking step size ramp-up interval heuristic."

This reverts commit 2998a176.

Reason for revert: perf regressions crbug.com/835472

Original change's description:
> [heap] Removing marking step size ramp-up interval heuristic.
> 
> The heuristic is no longer needed now that we have concurrent marking.
> 
> Bug: chromium:834371
> Change-Id: I8ca3eaacdab618f690d8007aff66713260ace19f
> Reviewed-on: https://chromium-review.googlesource.com/1017123
> Reviewed-by: Michael Lippautz <mlippautz@chromium.org>
> Commit-Queue: Ulan Degenbaev <ulan@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#52693}

TBR=ulan@chromium.org,hpayer@chromium.org,mlippautz@chromium.org

# Not skipping CQ checks because original CL landed > 1 day ago.

Bug: chromium:834371
Change-Id: I574abd75e77ae9ff443419f01750a3f01072adaf
Reviewed-on: https://chromium-review.googlesource.com/1023890Reviewed-by: 's avatarUlan Degenbaev <ulan@chromium.org>
Commit-Queue: Ulan Degenbaev <ulan@chromium.org>
Cr-Commit-Position: refs/heads/master@{#52728}
parent 8c897648
...@@ -2248,7 +2248,7 @@ void Heap::ComputeFastPromotionMode(double survival_rate) { ...@@ -2248,7 +2248,7 @@ void Heap::ComputeFastPromotionMode(double survival_rate) {
!FLAG_optimize_for_size && FLAG_fast_promotion_new_space && !FLAG_optimize_for_size && FLAG_fast_promotion_new_space &&
!ShouldReduceMemory() && new_space_->IsAtMaximumCapacity() && !ShouldReduceMemory() && new_space_->IsAtMaximumCapacity() &&
survived_in_new_space >= kMinPromotedPercentForFastPromotionMode; survived_in_new_space >= kMinPromotedPercentForFastPromotionMode;
if (FLAG_trace_gc_verbose && !FLAG_trace_gc_ignore_scavenger) { if (FLAG_trace_gc_verbose) {
PrintIsolate( PrintIsolate(
isolate(), "Fast promotion mode: %s survival rate: %" PRIuS "%%\n", isolate(), "Fast promotion mode: %s survival rate: %" PRIuS "%%\n",
fast_promotion_mode_ ? "true" : "false", survived_in_new_space); fast_promotion_mode_ ? "true" : "false", survived_in_new_space);
......
...@@ -952,6 +952,10 @@ size_t IncrementalMarking::StepSizeToKeepUpWithAllocations() { ...@@ -952,6 +952,10 @@ size_t IncrementalMarking::StepSizeToKeepUpWithAllocations() {
} }
size_t IncrementalMarking::StepSizeToMakeProgress() { size_t IncrementalMarking::StepSizeToMakeProgress() {
// We increase step size gradually based on the time passed in order to
// leave marking work to standalone tasks. The ramp up duration and the
// target step count are chosen based on benchmarks.
const int kRampUpIntervalMs = 300;
const size_t kTargetStepCount = 256; const size_t kTargetStepCount = 256;
const size_t kTargetStepCountAtOOM = 32; const size_t kTargetStepCountAtOOM = 32;
size_t oom_slack = heap()->new_space()->Capacity() + 64 * MB; size_t oom_slack = heap()->new_space()->Capacity() + 64 * MB;
...@@ -960,8 +964,12 @@ size_t IncrementalMarking::StepSizeToMakeProgress() { ...@@ -960,8 +964,12 @@ size_t IncrementalMarking::StepSizeToMakeProgress() {
return heap()->PromotedSpaceSizeOfObjects() / kTargetStepCountAtOOM; return heap()->PromotedSpaceSizeOfObjects() / kTargetStepCountAtOOM;
} }
return Max(initial_old_generation_size_ / kTargetStepCount, size_t step_size = Max(initial_old_generation_size_ / kTargetStepCount,
IncrementalMarking::kMinStepSizeInBytes); IncrementalMarking::kMinStepSizeInBytes);
double time_passed_ms =
heap_->MonotonicallyIncreasingTimeInMs() - start_time_ms_;
double factor = Min(time_passed_ms / kRampUpIntervalMs, 1.0);
return static_cast<size_t>(factor * step_size);
} }
void IncrementalMarking::AdvanceIncrementalMarkingOnAllocation() { void IncrementalMarking::AdvanceIncrementalMarkingOnAllocation() {
......
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