Commit 88b764d7 authored by mlippautz's avatar mlippautz Committed by Commit bot

[heap] Use live memory as heuristic for spawning compaction tasks

R=hpayer@chromium.org
BUG=chromium:524425
LOG=N

Review URL: https://codereview.chromium.org/1410163005

Cr-Commit-Position: refs/heads/master@{#31725}
parent 8789eca0
...@@ -3311,12 +3311,20 @@ int MarkCompactCollector::NumberOfParallelCompactionTasks() { ...@@ -3311,12 +3311,20 @@ int MarkCompactCollector::NumberOfParallelCompactionTasks() {
if (!FLAG_parallel_compaction) return 1; if (!FLAG_parallel_compaction) return 1;
// We cap the number of parallel compaction tasks by // We cap the number of parallel compaction tasks by
// - (#cores - 1) // - (#cores - 1)
// - a value depending on the list of evacuation candidates // - a value depending on the live memory in evacuation candidates
// - a hard limit // - a hard limit
const int kPagesPerCompactionTask = 4; //
// TODO(mlippautz): Instead of basing the limit on live memory, we could also
// compute the number from the time it takes to evacuate memory and a given
// desired time in which compaction should be finished.
const int kLiveMemoryPerCompactionTask = 2 * Page::kPageSize;
const int kMaxCompactionTasks = 8; const int kMaxCompactionTasks = 8;
int live_bytes = 0;
for (Page* page : evacuation_candidates_) {
live_bytes += page->LiveBytes();
}
return Min(kMaxCompactionTasks, return Min(kMaxCompactionTasks,
Min(1 + evacuation_candidates_.length() / kPagesPerCompactionTask, Min(1 + live_bytes / kLiveMemoryPerCompactionTask,
Max(1, base::SysInfo::NumberOfProcessors() - 1))); Max(1, base::SysInfo::NumberOfProcessors() - 1)));
} }
......
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