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

[heap] Pass external memory callback flags on external memory pressure.

This patch ensures that all code path of the external memory pressure
handler pass the kGCCallbackFlagCollectAllExternalMemory flag to the
embedder. This is necessary to force Oilpan GC.

Bug: chromium:733655
Change-Id: I2e680d1e7f9087d1930d56ead39ef7cf1bc93e56
Reviewed-on: https://chromium-review.googlesource.com/616149Reviewed-by: 's avatarMichael Lippautz <mlippautz@chromium.org>
Commit-Queue: Ulan Degenbaev <ulan@chromium.org>
Cr-Commit-Position: refs/heads/master@{#47378}
parent 32a197c7
...@@ -1069,26 +1069,28 @@ void Heap::CollectAllAvailableGarbage(GarbageCollectionReason gc_reason) { ...@@ -1069,26 +1069,28 @@ void Heap::CollectAllAvailableGarbage(GarbageCollectionReason gc_reason) {
} }
void Heap::ReportExternalMemoryPressure() { void Heap::ReportExternalMemoryPressure() {
const GCCallbackFlags kGCCallbackFlagsForExternalMemory =
static_cast<GCCallbackFlags>(
kGCCallbackFlagSynchronousPhantomCallbackProcessing |
kGCCallbackFlagCollectAllExternalMemory);
if (external_memory_ > if (external_memory_ >
(external_memory_at_last_mark_compact_ + external_memory_hard_limit())) { (external_memory_at_last_mark_compact_ + external_memory_hard_limit())) {
CollectAllGarbage( CollectAllGarbage(
kReduceMemoryFootprintMask | kFinalizeIncrementalMarkingMask, kReduceMemoryFootprintMask | kFinalizeIncrementalMarkingMask,
GarbageCollectionReason::kExternalMemoryPressure, GarbageCollectionReason::kExternalMemoryPressure,
static_cast<GCCallbackFlags>(kGCCallbackFlagCollectAllAvailableGarbage | static_cast<GCCallbackFlags>(kGCCallbackFlagCollectAllAvailableGarbage |
kGCCallbackFlagCollectAllExternalMemory)); kGCCallbackFlagsForExternalMemory));
return; return;
} }
if (incremental_marking()->IsStopped()) { if (incremental_marking()->IsStopped()) {
if (incremental_marking()->CanBeActivated()) { if (incremental_marking()->CanBeActivated()) {
StartIncrementalMarking( StartIncrementalMarking(i::Heap::kNoGCFlags,
i::Heap::kNoGCFlags, GarbageCollectionReason::kExternalMemoryPressure, GarbageCollectionReason::kExternalMemoryPressure,
static_cast<GCCallbackFlags>( kGCCallbackFlagsForExternalMemory);
kGCCallbackFlagSynchronousPhantomCallbackProcessing |
kGCCallbackFlagCollectAllExternalMemory));
} else { } else {
CollectAllGarbage(i::Heap::kNoGCFlags, CollectAllGarbage(i::Heap::kNoGCFlags,
GarbageCollectionReason::kExternalMemoryPressure, GarbageCollectionReason::kExternalMemoryPressure,
kGCCallbackFlagSynchronousPhantomCallbackProcessing); kGCCallbackFlagsForExternalMemory);
} }
} else { } else {
// Incremental marking is turned on an has already been started. // Incremental marking is turned on an has already been started.
...@@ -1099,6 +1101,9 @@ void Heap::ReportExternalMemoryPressure() { ...@@ -1099,6 +1101,9 @@ void Heap::ReportExternalMemoryPressure() {
Max(kMinStepSize, static_cast<double>(external_memory_) / Max(kMinStepSize, static_cast<double>(external_memory_) /
external_memory_limit_ * kMinStepSize)); external_memory_limit_ * kMinStepSize));
const double deadline = MonotonicallyIncreasingTimeInMs() + ms_step; const double deadline = MonotonicallyIncreasingTimeInMs() + ms_step;
// Extend the gc callback flags with external memory flags.
current_gc_callback_flags_ = static_cast<GCCallbackFlags>(
current_gc_callback_flags_ | kGCCallbackFlagsForExternalMemory);
incremental_marking()->AdvanceIncrementalMarking( incremental_marking()->AdvanceIncrementalMarking(
deadline, IncrementalMarking::GC_VIA_STACK_GUARD, deadline, IncrementalMarking::GC_VIA_STACK_GUARD,
IncrementalMarking::FORCE_COMPLETION, StepOrigin::kV8); IncrementalMarking::FORCE_COMPLETION, StepOrigin::kV8);
......
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