Index: src/heap/heap.cc |
diff --git a/src/heap/heap.cc b/src/heap/heap.cc |
index ae77e1eeee1ec5fdb59c6e794b41bea62e7be892..a9db0f42a5edcf80e457dfcdbf639f47289a58ad 100644 |
--- a/src/heap/heap.cc |
+++ b/src/heap/heap.cc |
@@ -122,7 +122,7 @@ Heap::Heap() |
last_idle_notification_time_(0.0), |
last_gc_time_(0.0), |
scavenge_collector_(nullptr), |
- mark_compact_collector_(this), |
+ mark_compact_collector_(nullptr), |
store_buffer_(this), |
incremental_marking_(this), |
gc_idle_time_handler_(nullptr), |
@@ -909,7 +909,8 @@ bool Heap::CollectGarbage(GarbageCollector collector, const char* gc_reason, |
incremental_marking()->Step(kStepSizeWhenDelayedByScavenge, |
IncrementalMarking::NO_GC_VIA_STACK_GUARD); |
if (!incremental_marking()->IsComplete() && |
- !mark_compact_collector_.marking_deque_.IsEmpty() && !FLAG_gc_global) { |
+ !mark_compact_collector()->marking_deque_.IsEmpty() && |
+ !FLAG_gc_global) { |
if (FLAG_trace_incremental_marking) { |
PrintF("[IncrementalMarking] Delaying MarkSweep.\n"); |
} |
@@ -1250,8 +1251,8 @@ bool Heap::PerformGarbageCollection( |
// We finished a marking cycle. We can uncommit the marking deque until |
// we start marking again. |
- mark_compact_collector_.marking_deque()->Uninitialize(); |
- mark_compact_collector_.EnsureMarkingDequeIsCommitted( |
+ mark_compact_collector()->marking_deque()->Uninitialize(); |
+ mark_compact_collector()->EnsureMarkingDequeIsCommitted( |
MarkCompactCollector::kMinMarkingDequeSize); |
} |
@@ -1345,13 +1346,13 @@ void Heap::MarkCompact() { |
uint64_t size_of_objects_before_gc = SizeOfObjects(); |
- mark_compact_collector_.Prepare(); |
+ mark_compact_collector()->Prepare(); |
ms_count_++; |
MarkCompactPrologue(); |
- mark_compact_collector_.CollectGarbage(); |
+ mark_compact_collector()->CollectGarbage(); |
LOG(isolate_, ResourceEvent("markcompact", "end")); |
@@ -4054,10 +4055,10 @@ void Heap::FinalizeIncrementalMarkingIfComplete(const char* comment) { |
if (FLAG_overapproximate_weak_closure && incremental_marking()->IsMarking() && |
(incremental_marking()->IsReadyToOverApproximateWeakClosure() || |
(!incremental_marking()->weak_closure_was_overapproximated() && |
- mark_compact_collector_.marking_deque()->IsEmpty()))) { |
+ mark_compact_collector()->marking_deque()->IsEmpty()))) { |
OverApproximateWeakClosure(comment); |
} else if (incremental_marking()->IsComplete() || |
- (mark_compact_collector_.marking_deque()->IsEmpty())) { |
+ (mark_compact_collector()->marking_deque()->IsEmpty())) { |
CollectAllGarbage(current_gc_flags_, comment); |
} |
} |
@@ -4071,14 +4072,14 @@ bool Heap::TryFinalizeIdleIncrementalMarking(double idle_time_in_ms) { |
if (FLAG_overapproximate_weak_closure && |
(incremental_marking()->IsReadyToOverApproximateWeakClosure() || |
(!incremental_marking()->weak_closure_was_overapproximated() && |
- mark_compact_collector_.marking_deque()->IsEmpty() && |
+ mark_compact_collector()->marking_deque()->IsEmpty() && |
gc_idle_time_handler_->ShouldDoOverApproximateWeakClosure( |
static_cast<size_t>(idle_time_in_ms))))) { |
OverApproximateWeakClosure( |
"Idle notification: overapproximate weak closure"); |
return true; |
} else if (incremental_marking()->IsComplete() || |
- (mark_compact_collector_.marking_deque()->IsEmpty() && |
+ (mark_compact_collector()->marking_deque()->IsEmpty() && |
gc_idle_time_handler_->ShouldDoFinalIncrementalMarkCompact( |
static_cast<size_t>(idle_time_in_ms), size_of_objects, |
final_incremental_mark_compact_speed_in_bytes_per_ms))) { |
@@ -4129,7 +4130,7 @@ double Heap::AdvanceIncrementalMarking( |
} while (remaining_time_in_ms >= |
2.0 * GCIdleTimeHandler::kIncrementalMarkingStepTimeInMs && |
!incremental_marking()->IsComplete() && |
- !mark_compact_collector_.marking_deque()->IsEmpty()); |
+ !mark_compact_collector()->marking_deque()->IsEmpty()); |
return remaining_time_in_ms; |
} |
@@ -4436,9 +4437,9 @@ void Heap::Verify() { |
lo_space_->Verify(); |
- mark_compact_collector_.VerifyWeakEmbeddedObjectsInCode(); |
+ mark_compact_collector()->VerifyWeakEmbeddedObjectsInCode(); |
if (FLAG_omit_map_checks_for_leaf_maps) { |
- mark_compact_collector_.VerifyOmittedMapChecks(); |
+ mark_compact_collector()->VerifyOmittedMapChecks(); |
} |
} |
#endif |
@@ -5074,6 +5075,8 @@ bool Heap::SetUp() { |
scavenge_collector_ = new Scavenger(this); |
+ mark_compact_collector_ = new MarkCompactCollector(this); |
+ |
gc_idle_time_handler_ = new GCIdleTimeHandler(); |
memory_reducer_ = new MemoryReducer(this); |
@@ -5190,6 +5193,12 @@ void Heap::TearDown() { |
delete scavenge_collector_; |
scavenge_collector_ = nullptr; |
+ if (mark_compact_collector_ != nullptr) { |
+ mark_compact_collector_->TearDown(); |
+ delete mark_compact_collector_; |
+ mark_compact_collector_ = nullptr; |
+ } |
+ |
delete gc_idle_time_handler_; |
gc_idle_time_handler_ = nullptr; |
@@ -5211,8 +5220,6 @@ void Heap::TearDown() { |
external_string_table_.TearDown(); |
- mark_compact_collector()->TearDown(); |
- |
delete tracer_; |
tracer_ = nullptr; |