Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(353)

Unified Diff: src/heap/heap.cc

Issue 1366183003: [heap] No leakage of mark-compact.h outside of heap. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Created 5 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « src/heap/heap.h ('k') | src/heap/incremental-marking.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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;
« no previous file with comments | « src/heap/heap.h ('k') | src/heap/incremental-marking.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698