Commit 39ee93f0 authored by Michael Lippautz's avatar Michael Lippautz Committed by Commit Bot

[unified-heap] Preserve flags when forcing finalization

Preserve flags for GC finalization triggered by EmbedderHeapTracer.

Bug: chromium:843903
Cq-Include-Trybots: luci.chromium.try:linux_chromium_rel_ng
Change-Id: Ie3d039bc1b69771ce9830dddb5e4d4375581981f
Reviewed-on: https://chromium-review.googlesource.com/1134766Reviewed-by: 's avatarUlan Degenbaev <ulan@chromium.org>
Commit-Queue: Michael Lippautz <mlippautz@chromium.org>
Cr-Commit-Position: refs/heads/master@{#54391}
parent 58ead42b
...@@ -10640,9 +10640,8 @@ void EmbedderHeapTracer::FinalizeTracing() { ...@@ -10640,9 +10640,8 @@ void EmbedderHeapTracer::FinalizeTracing() {
if (isolate_) { if (isolate_) {
i::Isolate* isolate = reinterpret_cast<i::Isolate*>(isolate_); i::Isolate* isolate = reinterpret_cast<i::Isolate*>(isolate_);
if (isolate->heap()->incremental_marking()->IsMarking()) { if (isolate->heap()->incremental_marking()->IsMarking()) {
isolate->heap()->CollectAllGarbage( isolate->heap()->FinalizeIncrementalMarkingAtomically(
i::Heap::kNoGCFlags, i::GarbageCollectionReason::kExternalFinalize, i::GarbageCollectionReason::kExternalFinalize);
kNoGCCallbackFlags);
} }
} }
} }
......
...@@ -1093,7 +1093,7 @@ void Heap::HandleGCRequest() { ...@@ -1093,7 +1093,7 @@ void Heap::HandleGCRequest() {
incremental_marking()->IsMarking() && incremental_marking()->IsMarking() &&
!incremental_marking()->finalize_marking_completed()) { !incremental_marking()->finalize_marking_completed()) {
incremental_marking()->reset_request_type(); incremental_marking()->reset_request_type();
FinalizeIncrementalMarking( FinalizeIncrementalMarkingIncrementally(
GarbageCollectionReason::kFinalizeMarkingViaStackGuard); GarbageCollectionReason::kFinalizeMarkingViaStackGuard);
} }
} }
...@@ -1103,41 +1103,6 @@ void Heap::ScheduleIdleScavengeIfNeeded(int bytes_allocated) { ...@@ -1103,41 +1103,6 @@ void Heap::ScheduleIdleScavengeIfNeeded(int bytes_allocated) {
scavenge_job_->ScheduleIdleTaskIfNeeded(this, bytes_allocated); scavenge_job_->ScheduleIdleTaskIfNeeded(this, bytes_allocated);
} }
void Heap::FinalizeIncrementalMarking(GarbageCollectionReason gc_reason) {
if (FLAG_trace_incremental_marking) {
isolate()->PrintWithTimestamp(
"[IncrementalMarking] (%s).\n",
Heap::GarbageCollectionReasonToString(gc_reason));
}
HistogramTimerScope incremental_marking_scope(
isolate()->counters()->gc_incremental_marking_finalize());
TRACE_EVENT0("v8", "V8.GCIncrementalMarkingFinalize");
TRACE_GC(tracer(), GCTracer::Scope::MC_INCREMENTAL_FINALIZE);
{
GCCallbacksScope scope(this);
if (scope.CheckReenter()) {
AllowHeapAllocation allow_allocation;
TRACE_GC(tracer(), GCTracer::Scope::MC_INCREMENTAL_EXTERNAL_PROLOGUE);
VMState<EXTERNAL> state(isolate_);
HandleScope handle_scope(isolate_);
CallGCPrologueCallbacks(kGCTypeIncrementalMarking, kNoGCCallbackFlags);
}
}
incremental_marking()->FinalizeIncrementally();
{
GCCallbacksScope scope(this);
if (scope.CheckReenter()) {
AllowHeapAllocation allow_allocation;
TRACE_GC(tracer(), GCTracer::Scope::MC_INCREMENTAL_EXTERNAL_EPILOGUE);
VMState<EXTERNAL> state(isolate_);
HandleScope handle_scope(isolate_);
CallGCEpilogueCallbacks(kGCTypeIncrementalMarking, kNoGCCallbackFlags);
}
}
}
HistogramTimer* Heap::GCTypePriorityTimer(GarbageCollector collector) { HistogramTimer* Heap::GCTypePriorityTimer(GarbageCollector collector) {
if (IsYoungGenerationCollector(collector)) { if (IsYoungGenerationCollector(collector)) {
if (isolate_->IsIsolateInBackground()) { if (isolate_->IsIsolateInBackground()) {
...@@ -3198,7 +3163,7 @@ void Heap::FinalizeIncrementalMarkingIfComplete( ...@@ -3198,7 +3163,7 @@ void Heap::FinalizeIncrementalMarkingIfComplete(
(!incremental_marking()->finalize_marking_completed() && (!incremental_marking()->finalize_marking_completed() &&
mark_compact_collector()->marking_worklist()->IsEmpty() && mark_compact_collector()->marking_worklist()->IsEmpty() &&
local_embedder_heap_tracer()->ShouldFinalizeIncrementalMarking()))) { local_embedder_heap_tracer()->ShouldFinalizeIncrementalMarking()))) {
FinalizeIncrementalMarking(gc_reason); FinalizeIncrementalMarkingIncrementally(gc_reason);
} else if (incremental_marking()->IsComplete() || } else if (incremental_marking()->IsComplete() ||
(mark_compact_collector()->marking_worklist()->IsEmpty() && (mark_compact_collector()->marking_worklist()->IsEmpty() &&
local_embedder_heap_tracer() local_embedder_heap_tracer()
...@@ -3207,6 +3172,48 @@ void Heap::FinalizeIncrementalMarkingIfComplete( ...@@ -3207,6 +3172,48 @@ void Heap::FinalizeIncrementalMarkingIfComplete(
} }
} }
void Heap::FinalizeIncrementalMarkingAtomically(
GarbageCollectionReason gc_reason) {
DCHECK(!incremental_marking()->IsStopped());
CollectAllGarbage(current_gc_flags_, gc_reason, current_gc_callback_flags_);
}
void Heap::FinalizeIncrementalMarkingIncrementally(
GarbageCollectionReason gc_reason) {
if (FLAG_trace_incremental_marking) {
isolate()->PrintWithTimestamp(
"[IncrementalMarking] (%s).\n",
Heap::GarbageCollectionReasonToString(gc_reason));
}
HistogramTimerScope incremental_marking_scope(
isolate()->counters()->gc_incremental_marking_finalize());
TRACE_EVENT0("v8", "V8.GCIncrementalMarkingFinalize");
TRACE_GC(tracer(), GCTracer::Scope::MC_INCREMENTAL_FINALIZE);
{
GCCallbacksScope scope(this);
if (scope.CheckReenter()) {
AllowHeapAllocation allow_allocation;
TRACE_GC(tracer(), GCTracer::Scope::MC_INCREMENTAL_EXTERNAL_PROLOGUE);
VMState<EXTERNAL> state(isolate_);
HandleScope handle_scope(isolate_);
CallGCPrologueCallbacks(kGCTypeIncrementalMarking, kNoGCCallbackFlags);
}
}
incremental_marking()->FinalizeIncrementally();
{
GCCallbacksScope scope(this);
if (scope.CheckReenter()) {
AllowHeapAllocation allow_allocation;
TRACE_GC(tracer(), GCTracer::Scope::MC_INCREMENTAL_EXTERNAL_EPILOGUE);
VMState<EXTERNAL> state(isolate_);
HandleScope handle_scope(isolate_);
CallGCEpilogueCallbacks(kGCTypeIncrementalMarking, kNoGCCallbackFlags);
}
}
}
void Heap::RegisterDeserializedObjectsForBlackAllocation( void Heap::RegisterDeserializedObjectsForBlackAllocation(
Reservation* reservations, const std::vector<HeapObject*>& large_objects, Reservation* reservations, const std::vector<HeapObject*>& large_objects,
const std::vector<Address>& maps) { const std::vector<Address>& maps) {
......
...@@ -1021,6 +1021,8 @@ class Heap { ...@@ -1021,6 +1021,8 @@ class Heap {
GCCallbackFlags gc_callback_flags = GCCallbackFlags::kNoGCCallbackFlags); GCCallbackFlags gc_callback_flags = GCCallbackFlags::kNoGCCallbackFlags);
void FinalizeIncrementalMarkingIfComplete(GarbageCollectionReason gc_reason); void FinalizeIncrementalMarkingIfComplete(GarbageCollectionReason gc_reason);
// Synchronously finalizes incremental marking.
void FinalizeIncrementalMarkingAtomically(GarbageCollectionReason gc_reason);
void RegisterDeserializedObjectsForBlackAllocation( void RegisterDeserializedObjectsForBlackAllocation(
Reservation* reservations, const std::vector<HeapObject*>& large_objects, Reservation* reservations, const std::vector<HeapObject*>& large_objects,
...@@ -1722,7 +1724,8 @@ class Heap { ...@@ -1722,7 +1724,8 @@ class Heap {
// implicit references from global handles, but don't atomically complete // implicit references from global handles, but don't atomically complete
// marking. If we continue to mark incrementally, we might have marked // marking. If we continue to mark incrementally, we might have marked
// objects that die later. // objects that die later.
void FinalizeIncrementalMarking(GarbageCollectionReason gc_reason); void FinalizeIncrementalMarkingIncrementally(
GarbageCollectionReason gc_reason);
// Returns the timer used for a given GC type. // Returns the timer used for a given GC type.
// - GCScavenger: young generation GC // - GCScavenger: young generation GC
......
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