Commit 551d67a6 authored by Aleksey Kozyatinskiy's avatar Aleksey Kozyatinskiy Committed by Commit Bot

Revert "[heap] Support for minor MC marking during incremental marking"

This reverts commit d2c093bc.

Reason for revert: looks like it brokes try bot [1].

[1] https://build.chromium.org/p/client.v8/builders/V8%20Linux64%20-%20debug

Original change's description:
> [heap] Support for minor MC marking during incremental marking
> 
> BUG=chromium:651354
> 
> Change-Id: Ia8511723b17936b78b33ea685704237c100648e1
> Reviewed-on: https://chromium-review.googlesource.com/439285
> Commit-Queue: Michael Lippautz <mlippautz@chromium.org>
> Reviewed-by: Ulan Degenbaev <ulan@chromium.org>
> Reviewed-by: Hannes Payer <hpayer@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#43422}

TBR=ulan@chromium.org,hpayer@chromium.org,mlippautz@chromium.org,hablich@chromium.org,v8-reviews@googlegroups.com
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=chromium:651354

Change-Id: Ib5bada3ecf9d687568668b9a4ef4682bb665b8e1
Reviewed-on: https://chromium-review.googlesource.com/446977Reviewed-by: 's avatarAleksey Kozyatinskiy <kozyatinskiy@chromium.org>
Commit-Queue: Aleksey Kozyatinskiy <kozyatinskiy@chromium.org>
Cr-Commit-Position: refs/heads/master@{#43424}
parent 0ccb0281
...@@ -644,6 +644,7 @@ DEFINE_INT(min_progress_during_incremental_marking_finalization, 32, ...@@ -644,6 +644,7 @@ DEFINE_INT(min_progress_during_incremental_marking_finalization, 32,
DEFINE_INT(max_incremental_marking_finalization_rounds, 3, DEFINE_INT(max_incremental_marking_finalization_rounds, 3,
"at most try this many times to finalize incremental marking") "at most try this many times to finalize incremental marking")
DEFINE_BOOL(minor_mc, false, "perform young generation mark compact GCs") DEFINE_BOOL(minor_mc, false, "perform young generation mark compact GCs")
DEFINE_NEG_IMPLICATION(minor_mc, incremental_marking)
DEFINE_BOOL(black_allocation, true, "use black allocation") DEFINE_BOOL(black_allocation, true, "use black allocation")
DEFINE_BOOL(concurrent_sweeping, true, "use concurrent sweeping") DEFINE_BOOL(concurrent_sweeping, true, "use concurrent sweeping")
DEFINE_BOOL(parallel_compaction, true, "use parallel compaction") DEFINE_BOOL(parallel_compaction, true, "use parallel compaction")
......
...@@ -12,11 +12,10 @@ ...@@ -12,11 +12,10 @@
namespace v8 { namespace v8 {
namespace internal { namespace internal {
template <MarkingMode mode>
void MarkCompactCollector::PushBlack(HeapObject* obj) { void MarkCompactCollector::PushBlack(HeapObject* obj) {
DCHECK(ObjectMarking::IsBlack<mode>(obj)); DCHECK(ObjectMarking::IsBlack(obj));
if (!marking_deque<mode>()->Push(obj)) { if (!marking_deque()->Push(obj)) {
ObjectMarking::BlackToGrey<mode>(obj); ObjectMarking::BlackToGrey(obj);
} }
} }
...@@ -28,11 +27,10 @@ void MarkCompactCollector::UnshiftBlack(HeapObject* obj) { ...@@ -28,11 +27,10 @@ void MarkCompactCollector::UnshiftBlack(HeapObject* obj) {
} }
} }
template <MarkingMode mode>
void MarkCompactCollector::MarkObject(HeapObject* obj) { void MarkCompactCollector::MarkObject(HeapObject* obj) {
if (ObjectMarking::IsWhite<mode>(obj)) { if (ObjectMarking::IsWhite(obj)) {
ObjectMarking::WhiteToBlack<mode>(obj); ObjectMarking::WhiteToBlack(obj);
PushBlack<mode>(obj); PushBlack(obj);
} }
} }
......
...@@ -60,7 +60,6 @@ MarkCompactCollector::MarkCompactCollector(Heap* heap) ...@@ -60,7 +60,6 @@ MarkCompactCollector::MarkCompactCollector(Heap* heap)
black_allocation_(false), black_allocation_(false),
have_code_to_deoptimize_(false), have_code_to_deoptimize_(false),
marking_deque_(heap), marking_deque_(heap),
marking_deque_young_generation_(heap),
code_flusher_(nullptr), code_flusher_(nullptr),
sweeper_(heap) { sweeper_(heap) {
} }
...@@ -239,7 +238,6 @@ void MarkCompactCollector::SetUp() { ...@@ -239,7 +238,6 @@ void MarkCompactCollector::SetUp() {
DCHECK(strcmp(Marking::kGreyBitPattern, "10") == 0); DCHECK(strcmp(Marking::kGreyBitPattern, "10") == 0);
DCHECK(strcmp(Marking::kImpossibleBitPattern, "01") == 0); DCHECK(strcmp(Marking::kImpossibleBitPattern, "01") == 0);
marking_deque()->SetUp(); marking_deque()->SetUp();
marking_deque<MarkingMode::YOUNG_GENERATION>()->SetUp();
if (FLAG_flush_code) { if (FLAG_flush_code) {
code_flusher_ = new CodeFlusher(isolate()); code_flusher_ = new CodeFlusher(isolate());
...@@ -253,7 +251,6 @@ void MarkCompactCollector::SetUp() { ...@@ -253,7 +251,6 @@ void MarkCompactCollector::SetUp() {
void MarkCompactCollector::TearDown() { void MarkCompactCollector::TearDown() {
AbortCompaction(); AbortCompaction();
marking_deque()->TearDown(); marking_deque()->TearDown();
marking_deque<MarkingMode::YOUNG_GENERATION>()->TearDown();
delete code_flusher_; delete code_flusher_;
} }
...@@ -1084,8 +1081,7 @@ class StaticYoungGenerationMarkingVisitor ...@@ -1084,8 +1081,7 @@ class StaticYoungGenerationMarkingVisitor
Object* target = *p; Object* target = *p;
if (heap->InNewSpace(target)) { if (heap->InNewSpace(target)) {
if (MarkRecursively(heap, HeapObject::cast(target))) return; if (MarkRecursively(heap, HeapObject::cast(target))) return;
heap->mark_compact_collector()->MarkObject<MarkingMode::YOUNG_GENERATION>( heap->mark_compact_collector()->MarkObject(HeapObject::cast(target));
HeapObject::cast(target));
} }
} }
...@@ -1094,9 +1090,8 @@ class StaticYoungGenerationMarkingVisitor ...@@ -1094,9 +1090,8 @@ class StaticYoungGenerationMarkingVisitor
StackLimitCheck check(heap->isolate()); StackLimitCheck check(heap->isolate());
if (check.HasOverflowed()) return false; if (check.HasOverflowed()) return false;
if (ObjectMarking::IsBlackOrGrey<MarkingMode::YOUNG_GENERATION>(object)) if (ObjectMarking::IsBlackOrGrey(object)) return true;
return true; ObjectMarking::WhiteToBlack(object);
ObjectMarking::WhiteToBlack<MarkingMode::YOUNG_GENERATION>(object);
IterateBody(object->map(), object); IterateBody(object->map(), object);
return true; return true;
} }
...@@ -1344,12 +1339,12 @@ void MarkCompactCollector::PrepareForCodeFlushing() { ...@@ -1344,12 +1339,12 @@ void MarkCompactCollector::PrepareForCodeFlushing() {
heap()->isolate()->compilation_cache()->IterateFunctions(&visitor); heap()->isolate()->compilation_cache()->IterateFunctions(&visitor);
heap()->isolate()->handle_scope_implementer()->Iterate(&visitor); heap()->isolate()->handle_scope_implementer()->Iterate(&visitor);
ProcessMarkingDeque<MarkingMode::FULL>(); ProcessMarkingDeque<MarkCompactMode::FULL>();
} }
// Visitor class for marking heap roots. // Visitor class for marking heap roots.
template <MarkingMode mode> template <MarkCompactMode mode>
class RootMarkingVisitor : public ObjectVisitor { class RootMarkingVisitor : public ObjectVisitor {
public: public:
explicit RootMarkingVisitor(Heap* heap) explicit RootMarkingVisitor(Heap* heap)
...@@ -1371,23 +1366,23 @@ class RootMarkingVisitor : public ObjectVisitor { ...@@ -1371,23 +1366,23 @@ class RootMarkingVisitor : public ObjectVisitor {
HeapObject* object = HeapObject::cast(*p); HeapObject* object = HeapObject::cast(*p);
if (mode == MarkingMode::YOUNG_GENERATION && if (mode == MarkCompactMode::YOUNG_GENERATION &&
!collector_->heap()->InNewSpace(object)) !collector_->heap()->InNewSpace(object))
return; return;
if (ObjectMarking::IsBlackOrGrey<mode>(object)) return; if (ObjectMarking::IsBlackOrGrey(object)) return;
Map* map = object->map(); Map* map = object->map();
// Mark the object. // Mark the object.
ObjectMarking::WhiteToBlack<mode>(object); ObjectMarking::WhiteToBlack(object);
switch (mode) { switch (mode) {
case MarkingMode::FULL: { case MarkCompactMode::FULL: {
// Mark the map pointer and body, and push them on the marking stack. // Mark the map pointer and body, and push them on the marking stack.
collector_->MarkObject(map); collector_->MarkObject(map);
MarkCompactMarkingVisitor::IterateBody(map, object); MarkCompactMarkingVisitor::IterateBody(map, object);
} break; } break;
case MarkingMode::YOUNG_GENERATION: case MarkCompactMode::YOUNG_GENERATION:
StaticYoungGenerationMarkingVisitor::IterateBody(map, object); StaticYoungGenerationMarkingVisitor::IterateBody(map, object);
break; break;
} }
...@@ -1962,7 +1957,7 @@ bool MarkCompactCollector::IsUnmarkedHeapObjectWithHeap(Heap* heap, ...@@ -1962,7 +1957,7 @@ bool MarkCompactCollector::IsUnmarkedHeapObjectWithHeap(Heap* heap,
} }
void MarkCompactCollector::MarkStringTable( void MarkCompactCollector::MarkStringTable(
RootMarkingVisitor<MarkingMode::FULL>* visitor) { RootMarkingVisitor<MarkCompactMode::FULL>* visitor) {
StringTable* string_table = heap()->string_table(); StringTable* string_table = heap()->string_table();
// Mark the string table itself. // Mark the string table itself.
if (ObjectMarking::IsWhite(string_table)) { if (ObjectMarking::IsWhite(string_table)) {
...@@ -1971,11 +1966,11 @@ void MarkCompactCollector::MarkStringTable( ...@@ -1971,11 +1966,11 @@ void MarkCompactCollector::MarkStringTable(
} }
// Explicitly mark the prefix. // Explicitly mark the prefix.
string_table->IteratePrefix(visitor); string_table->IteratePrefix(visitor);
ProcessMarkingDeque<MarkingMode::FULL>(); ProcessMarkingDeque<MarkCompactMode::FULL>();
} }
void MarkCompactCollector::MarkRoots( void MarkCompactCollector::MarkRoots(
RootMarkingVisitor<MarkingMode::FULL>* visitor) { RootMarkingVisitor<MarkCompactMode::FULL>* visitor) {
// Mark the heap roots including global variables, stack variables, // Mark the heap roots including global variables, stack variables,
// etc., and all objects reachable from them. // etc., and all objects reachable from them.
heap()->IterateStrongRoots(visitor, VISIT_ONLY_STRONG); heap()->IterateStrongRoots(visitor, VISIT_ONLY_STRONG);
...@@ -1985,8 +1980,8 @@ void MarkCompactCollector::MarkRoots( ...@@ -1985,8 +1980,8 @@ void MarkCompactCollector::MarkRoots(
// There may be overflowed objects in the heap. Visit them now. // There may be overflowed objects in the heap. Visit them now.
while (marking_deque()->overflowed()) { while (marking_deque()->overflowed()) {
RefillMarkingDeque<MarkingMode::FULL>(); RefillMarkingDeque<MarkCompactMode::FULL>();
EmptyMarkingDeque<MarkingMode::FULL>(); EmptyMarkingDeque<MarkCompactMode::FULL>();
} }
} }
...@@ -2026,24 +2021,24 @@ void MarkCompactCollector::MarkImplicitRefGroups( ...@@ -2026,24 +2021,24 @@ void MarkCompactCollector::MarkImplicitRefGroups(
// Before: the marking stack contains zero or more heap object pointers. // Before: the marking stack contains zero or more heap object pointers.
// After: the marking stack is empty, and all objects reachable from the // After: the marking stack is empty, and all objects reachable from the
// marking stack have been marked, or are overflowed in the heap. // marking stack have been marked, or are overflowed in the heap.
template <MarkingMode mode> template <MarkCompactMode mode>
void MarkCompactCollector::EmptyMarkingDeque() { void MarkCompactCollector::EmptyMarkingDeque() {
while (!marking_deque<mode>()->IsEmpty()) { while (!marking_deque()->IsEmpty()) {
HeapObject* object = marking_deque<mode>()->Pop(); HeapObject* object = marking_deque()->Pop();
DCHECK(!object->IsFiller()); DCHECK(!object->IsFiller());
DCHECK(object->IsHeapObject()); DCHECK(object->IsHeapObject());
DCHECK(heap()->Contains(object)); DCHECK(heap()->Contains(object));
DCHECK(!ObjectMarking::IsWhite<mode>(object)); DCHECK(!ObjectMarking::IsWhite(object));
Map* map = object->map(); Map* map = object->map();
switch (mode) { switch (mode) {
case MarkingMode::FULL: { case MarkCompactMode::FULL: {
MarkObject(map); MarkObject(map);
MarkCompactMarkingVisitor::IterateBody(map, object); MarkCompactMarkingVisitor::IterateBody(map, object);
} break; } break;
case MarkingMode::YOUNG_GENERATION: { case MarkCompactMode::YOUNG_GENERATION: {
DCHECK(ObjectMarking::IsBlack<mode>(object)); DCHECK(ObjectMarking::IsBlack(object));
StaticYoungGenerationMarkingVisitor::IterateBody(map, object); StaticYoungGenerationMarkingVisitor::IterateBody(map, object);
} break; } break;
} }
...@@ -2056,27 +2051,27 @@ void MarkCompactCollector::EmptyMarkingDeque() { ...@@ -2056,27 +2051,27 @@ void MarkCompactCollector::EmptyMarkingDeque() {
// before sweeping completes. If sweeping completes, there are no remaining // before sweeping completes. If sweeping completes, there are no remaining
// overflowed objects in the heap so the overflow flag on the markings stack // overflowed objects in the heap so the overflow flag on the markings stack
// is cleared. // is cleared.
template <MarkingMode mode> template <MarkCompactMode mode>
void MarkCompactCollector::RefillMarkingDeque() { void MarkCompactCollector::RefillMarkingDeque() {
isolate()->CountUsage(v8::Isolate::UseCounterFeature::kMarkDequeOverflow); isolate()->CountUsage(v8::Isolate::UseCounterFeature::kMarkDequeOverflow);
DCHECK(marking_deque<mode>()->overflowed()); DCHECK(marking_deque()->overflowed());
DiscoverGreyObjectsInNewSpace(); DiscoverGreyObjectsInNewSpace();
if (marking_deque<mode>()->IsFull()) return; if (marking_deque()->IsFull()) return;
if (mode == MarkingMode::FULL) { if (mode == MarkCompactMode::FULL) {
DiscoverGreyObjectsInSpace(heap()->old_space()); DiscoverGreyObjectsInSpace(heap()->old_space());
if (marking_deque<mode>()->IsFull()) return; if (marking_deque()->IsFull()) return;
DiscoverGreyObjectsInSpace(heap()->code_space()); DiscoverGreyObjectsInSpace(heap()->code_space());
if (marking_deque<mode>()->IsFull()) return; if (marking_deque()->IsFull()) return;
DiscoverGreyObjectsInSpace(heap()->map_space()); DiscoverGreyObjectsInSpace(heap()->map_space());
if (marking_deque<mode>()->IsFull()) return; if (marking_deque()->IsFull()) return;
LargeObjectIterator lo_it(heap()->lo_space()); LargeObjectIterator lo_it(heap()->lo_space());
DiscoverGreyObjectsWithIterator(&lo_it); DiscoverGreyObjectsWithIterator(&lo_it);
if (marking_deque<mode>()->IsFull()) return; if (marking_deque()->IsFull()) return;
} }
marking_deque<mode>()->ClearOverflowed(); marking_deque()->ClearOverflowed();
} }
...@@ -2084,14 +2079,14 @@ void MarkCompactCollector::RefillMarkingDeque() { ...@@ -2084,14 +2079,14 @@ void MarkCompactCollector::RefillMarkingDeque() {
// stack. Before: the marking stack contains zero or more heap object // stack. Before: the marking stack contains zero or more heap object
// pointers. After: the marking stack is empty and there are no overflowed // pointers. After: the marking stack is empty and there are no overflowed
// objects in the heap. // objects in the heap.
template <MarkingMode mode> template <MarkCompactMode mode>
void MarkCompactCollector::ProcessMarkingDeque() { void MarkCompactCollector::ProcessMarkingDeque() {
EmptyMarkingDeque<mode>(); EmptyMarkingDeque<mode>();
while (marking_deque<mode>()->overflowed()) { while (marking_deque()->overflowed()) {
RefillMarkingDeque<mode>(); RefillMarkingDeque<mode>();
EmptyMarkingDeque<mode>(); EmptyMarkingDeque<mode>();
} }
DCHECK(marking_deque<mode>()->IsEmpty()); DCHECK(marking_deque()->IsEmpty());
} }
// Mark all objects reachable (transitively) from objects on the marking // Mark all objects reachable (transitively) from objects on the marking
...@@ -2124,7 +2119,7 @@ void MarkCompactCollector::ProcessEphemeralMarking( ...@@ -2124,7 +2119,7 @@ void MarkCompactCollector::ProcessEphemeralMarking(
} }
ProcessWeakCollections(); ProcessWeakCollections();
work_to_do = !marking_deque()->IsEmpty(); work_to_do = !marking_deque()->IsEmpty();
ProcessMarkingDeque<MarkingMode::FULL>(); ProcessMarkingDeque<MarkCompactMode::FULL>();
} }
CHECK(marking_deque()->IsEmpty()); CHECK(marking_deque()->IsEmpty());
CHECK_EQ(0, heap()->local_embedder_heap_tracer()->NumberOfWrappersToTrace()); CHECK_EQ(0, heap()->local_embedder_heap_tracer()->NumberOfWrappersToTrace());
...@@ -2141,7 +2136,7 @@ void MarkCompactCollector::ProcessTopOptimizedFrame(ObjectVisitor* visitor) { ...@@ -2141,7 +2136,7 @@ void MarkCompactCollector::ProcessTopOptimizedFrame(ObjectVisitor* visitor) {
if (!code->CanDeoptAt(it.frame()->pc())) { if (!code->CanDeoptAt(it.frame()->pc())) {
Code::BodyDescriptor::IterateBody(code, visitor); Code::BodyDescriptor::IterateBody(code, visitor);
} }
ProcessMarkingDeque<MarkingMode::FULL>(); ProcessMarkingDeque<MarkCompactMode::FULL>();
return; return;
} }
} }
...@@ -2303,11 +2298,10 @@ SlotCallbackResult MarkCompactCollector::CheckAndMarkObject( ...@@ -2303,11 +2298,10 @@ SlotCallbackResult MarkCompactCollector::CheckAndMarkObject(
// has to be in ToSpace. // has to be in ToSpace.
DCHECK(heap->InToSpace(object)); DCHECK(heap->InToSpace(object));
HeapObject* heap_object = reinterpret_cast<HeapObject*>(object); HeapObject* heap_object = reinterpret_cast<HeapObject*>(object);
if (ObjectMarking::IsBlackOrGrey<MarkingMode::YOUNG_GENERATION>( if (ObjectMarking::IsBlackOrGrey(heap_object)) {
heap_object)) {
return KEEP_SLOT; return KEEP_SLOT;
} }
ObjectMarking::WhiteToBlack<MarkingMode::YOUNG_GENERATION>(heap_object); ObjectMarking::WhiteToBlack(heap_object);
StaticYoungGenerationMarkingVisitor::IterateBody(heap_object->map(), StaticYoungGenerationMarkingVisitor::IterateBody(heap_object->map(),
heap_object); heap_object);
return KEEP_SLOT; return KEEP_SLOT;
...@@ -2326,12 +2320,9 @@ void MarkCompactCollector::MarkLiveObjectsInYoungGeneration() { ...@@ -2326,12 +2320,9 @@ void MarkCompactCollector::MarkLiveObjectsInYoungGeneration() {
PostponeInterruptsScope postpone(isolate()); PostponeInterruptsScope postpone(isolate());
StaticYoungGenerationMarkingVisitor::Initialize(heap()); StaticYoungGenerationMarkingVisitor::Initialize(heap());
RootMarkingVisitor<MarkingMode::YOUNG_GENERATION> root_visitor(heap()); RootMarkingVisitor<MarkCompactMode::YOUNG_GENERATION> root_visitor(heap());
marking_deque<MarkingMode::YOUNG_GENERATION>()->StartUsing(); marking_deque()->StartUsing();
for (Page* p : heap()->new_space()->to_space()) {
p->AllocateExternalBitmap();
}
isolate()->global_handles()->IdentifyWeakUnmodifiedObjects( isolate()->global_handles()->IdentifyWeakUnmodifiedObjects(
&Heap::IsUnmodifiedHeapObject); &Heap::IsUnmodifiedHeapObject);
...@@ -2339,7 +2330,7 @@ void MarkCompactCollector::MarkLiveObjectsInYoungGeneration() { ...@@ -2339,7 +2330,7 @@ void MarkCompactCollector::MarkLiveObjectsInYoungGeneration() {
{ {
TRACE_GC(heap()->tracer(), GCTracer::Scope::MINOR_MC_MARK_ROOTS); TRACE_GC(heap()->tracer(), GCTracer::Scope::MINOR_MC_MARK_ROOTS);
heap()->IterateRoots(&root_visitor, VISIT_ALL_IN_SCAVENGE); heap()->IterateRoots(&root_visitor, VISIT_ALL_IN_SCAVENGE);
ProcessMarkingDeque<MarkingMode::YOUNG_GENERATION>(); ProcessMarkingDeque<MarkCompactMode::YOUNG_GENERATION>();
} }
{ {
...@@ -2356,20 +2347,20 @@ void MarkCompactCollector::MarkLiveObjectsInYoungGeneration() { ...@@ -2356,20 +2347,20 @@ void MarkCompactCollector::MarkLiveObjectsInYoungGeneration() {
reinterpret_cast<Address>(addr)); reinterpret_cast<Address>(addr));
}); });
}); });
ProcessMarkingDeque<MarkingMode::YOUNG_GENERATION>(); ProcessMarkingDeque<MarkCompactMode::YOUNG_GENERATION>();
} }
{ {
TRACE_GC(heap()->tracer(), GCTracer::Scope::MINOR_MC_MARK_WEAK); TRACE_GC(heap()->tracer(), GCTracer::Scope::MINOR_MC_MARK_WEAK);
heap()->VisitEncounteredWeakCollections(&root_visitor); heap()->VisitEncounteredWeakCollections(&root_visitor);
ProcessMarkingDeque<MarkingMode::YOUNG_GENERATION>(); ProcessMarkingDeque<MarkCompactMode::YOUNG_GENERATION>();
} }
if (is_code_flushing_enabled()) { if (is_code_flushing_enabled()) {
TRACE_GC(heap()->tracer(), TRACE_GC(heap()->tracer(),
GCTracer::Scope::MINOR_MC_MARK_CODE_FLUSH_CANDIDATES); GCTracer::Scope::MINOR_MC_MARK_CODE_FLUSH_CANDIDATES);
code_flusher()->IteratePointersToFromSpace(&root_visitor); code_flusher()->IteratePointersToFromSpace(&root_visitor);
ProcessMarkingDeque<MarkingMode::YOUNG_GENERATION>(); ProcessMarkingDeque<MarkCompactMode::YOUNG_GENERATION>();
} }
{ {
...@@ -2380,15 +2371,10 @@ void MarkCompactCollector::MarkLiveObjectsInYoungGeneration() { ...@@ -2380,15 +2371,10 @@ void MarkCompactCollector::MarkLiveObjectsInYoungGeneration() {
->global_handles() ->global_handles()
->IterateNewSpaceWeakUnmodifiedRoots<GlobalHandles::VISIT_OTHERS>( ->IterateNewSpaceWeakUnmodifiedRoots<GlobalHandles::VISIT_OTHERS>(
&root_visitor); &root_visitor);
ProcessMarkingDeque<MarkingMode::YOUNG_GENERATION>(); ProcessMarkingDeque<MarkCompactMode::YOUNG_GENERATION>();
} }
// TODO(mlippautz): External bitmap should be deallocated after evacuation. marking_deque()->StopUsing();
for (Page* p : PageRange(heap()->new_space()->FromSpaceStart(),
heap()->new_space()->FromSpaceEnd())) {
p->ReleaseExternalBitmap();
}
marking_deque<MarkingMode::YOUNG_GENERATION>()->StopUsing();
} }
void MarkCompactCollector::MarkLiveObjects() { void MarkCompactCollector::MarkLiveObjects() {
...@@ -2422,7 +2408,7 @@ void MarkCompactCollector::MarkLiveObjects() { ...@@ -2422,7 +2408,7 @@ void MarkCompactCollector::MarkLiveObjects() {
PrepareForCodeFlushing(); PrepareForCodeFlushing();
} }
RootMarkingVisitor<MarkingMode::FULL> root_visitor(heap()); RootMarkingVisitor<MarkCompactMode::FULL> root_visitor(heap());
{ {
TRACE_GC(heap()->tracer(), GCTracer::Scope::MC_MARK_ROOTS); TRACE_GC(heap()->tracer(), GCTracer::Scope::MC_MARK_ROOTS);
...@@ -2454,7 +2440,7 @@ void MarkCompactCollector::MarkLiveObjects() { ...@@ -2454,7 +2440,7 @@ void MarkCompactCollector::MarkLiveObjects() {
GCTracer::Scope::MC_MARK_WEAK_CLOSURE_WEAK_HANDLES); GCTracer::Scope::MC_MARK_WEAK_CLOSURE_WEAK_HANDLES);
heap()->isolate()->global_handles()->IdentifyWeakHandles( heap()->isolate()->global_handles()->IdentifyWeakHandles(
&IsUnmarkedHeapObject); &IsUnmarkedHeapObject);
ProcessMarkingDeque<MarkingMode::FULL>(); ProcessMarkingDeque<MarkCompactMode::FULL>();
} }
// Then we mark the objects. // Then we mark the objects.
...@@ -2462,7 +2448,7 @@ void MarkCompactCollector::MarkLiveObjects() { ...@@ -2462,7 +2448,7 @@ void MarkCompactCollector::MarkLiveObjects() {
TRACE_GC(heap()->tracer(), TRACE_GC(heap()->tracer(),
GCTracer::Scope::MC_MARK_WEAK_CLOSURE_WEAK_ROOTS); GCTracer::Scope::MC_MARK_WEAK_CLOSURE_WEAK_ROOTS);
heap()->isolate()->global_handles()->IterateWeakRoots(&root_visitor); heap()->isolate()->global_handles()->IterateWeakRoots(&root_visitor);
ProcessMarkingDeque<MarkingMode::FULL>(); ProcessMarkingDeque<MarkCompactMode::FULL>();
} }
// Repeat Harmony weak maps marking to mark unmarked objects reachable from // Repeat Harmony weak maps marking to mark unmarked objects reachable from
......
...@@ -17,6 +17,8 @@ ...@@ -17,6 +17,8 @@
namespace v8 { namespace v8 {
namespace internal { namespace internal {
enum class MarkCompactMode { FULL, YOUNG_GENERATION };
// Callback function, returns whether an object is alive. The heap size // Callback function, returns whether an object is alive. The heap size
// of the object is returned in size. It optionally updates the offset // of the object is returned in size. It optionally updates the offset
// to the first live object in the page (only used for old and map objects). // to the first live object in the page (only used for old and map objects).
...@@ -29,103 +31,87 @@ typedef void (*MarkObjectFunction)(Heap* heap, HeapObject* object); ...@@ -29,103 +31,87 @@ typedef void (*MarkObjectFunction)(Heap* heap, HeapObject* object);
class CodeFlusher; class CodeFlusher;
class MarkCompactCollector; class MarkCompactCollector;
class MarkingVisitor; class MarkingVisitor;
template <MarkingMode mode> template <MarkCompactMode mode>
class RootMarkingVisitor; class RootMarkingVisitor;
class ObjectMarking : public AllStatic { class ObjectMarking : public AllStatic {
public: public:
template <MarkingMode mode = MarkingMode::FULL>
V8_INLINE static MarkBit MarkBitFrom(HeapObject* obj) { V8_INLINE static MarkBit MarkBitFrom(HeapObject* obj) {
const Address address = obj->address(); const Address address = obj->address();
const MemoryChunk* p = MemoryChunk::FromAddress(address); MemoryChunk* p = MemoryChunk::FromAddress(address);
return p->markbits<mode>()->MarkBitFromIndex( return p->markbits()->MarkBitFromIndex(p->AddressToMarkbitIndex(address));
p->AddressToMarkbitIndex(address));
} }
template <MarkingMode mode = MarkingMode::FULL> static Marking::ObjectColor Color(HeapObject* obj) {
V8_INLINE static Marking::ObjectColor Color(HeapObject* obj) { return Marking::Color(ObjectMarking::MarkBitFrom(obj));
return Marking::Color(ObjectMarking::MarkBitFrom<mode>(obj));
} }
template <MarkingMode mode = MarkingMode::FULL>
V8_INLINE static bool IsImpossible(HeapObject* obj) { V8_INLINE static bool IsImpossible(HeapObject* obj) {
return Marking::IsImpossible(MarkBitFrom<mode>(obj)); return Marking::IsImpossible(MarkBitFrom(obj));
} }
template <MarkingMode mode = MarkingMode::FULL>
V8_INLINE static bool IsBlack(HeapObject* obj) { V8_INLINE static bool IsBlack(HeapObject* obj) {
return Marking::IsBlack(MarkBitFrom<mode>(obj)); return Marking::IsBlack(MarkBitFrom(obj));
} }
template <MarkingMode mode = MarkingMode::FULL>
V8_INLINE static bool IsWhite(HeapObject* obj) { V8_INLINE static bool IsWhite(HeapObject* obj) {
return Marking::IsWhite(MarkBitFrom<mode>(obj)); return Marking::IsWhite(MarkBitFrom(obj));
} }
template <MarkingMode mode = MarkingMode::FULL>
V8_INLINE static bool IsGrey(HeapObject* obj) { V8_INLINE static bool IsGrey(HeapObject* obj) {
return Marking::IsGrey(MarkBitFrom<mode>(obj)); return Marking::IsGrey(MarkBitFrom(obj));
} }
template <MarkingMode mode = MarkingMode::FULL>
V8_INLINE static bool IsBlackOrGrey(HeapObject* obj) { V8_INLINE static bool IsBlackOrGrey(HeapObject* obj) {
return Marking::IsBlackOrGrey(MarkBitFrom<mode>(obj)); return Marking::IsBlackOrGrey(MarkBitFrom(obj));
} }
template <MarkingMode mode = MarkingMode::FULL>
V8_INLINE static void ClearMarkBit(HeapObject* obj) { V8_INLINE static void ClearMarkBit(HeapObject* obj) {
Marking::MarkWhite(MarkBitFrom<mode>(obj)); Marking::MarkWhite(MarkBitFrom(obj));
} }
template <MarkingMode mode = MarkingMode::FULL>
V8_INLINE static void BlackToWhite(HeapObject* obj) { V8_INLINE static void BlackToWhite(HeapObject* obj) {
DCHECK(IsBlack<mode>(obj)); DCHECK(IsBlack(obj));
MarkBit markbit = MarkBitFrom<mode>(obj); MarkBit markbit = MarkBitFrom(obj);
Marking::BlackToWhite(markbit); Marking::BlackToWhite(markbit);
MemoryChunk::IncrementLiveBytes<mode>(obj, -obj->Size()); MemoryChunk::IncrementLiveBytes(obj, -obj->Size());
} }
template <MarkingMode mode = MarkingMode::FULL>
V8_INLINE static void GreyToWhite(HeapObject* obj) { V8_INLINE static void GreyToWhite(HeapObject* obj) {
DCHECK(IsGrey<mode>(obj)); DCHECK(IsGrey(obj));
Marking::GreyToWhite(MarkBitFrom<mode>(obj)); Marking::GreyToWhite(MarkBitFrom(obj));
} }
template <MarkingMode mode = MarkingMode::FULL>
V8_INLINE static void BlackToGrey(HeapObject* obj) { V8_INLINE static void BlackToGrey(HeapObject* obj) {
DCHECK(IsBlack<mode>(obj)); DCHECK(IsBlack(obj));
MarkBit markbit = MarkBitFrom<mode>(obj); MarkBit markbit = MarkBitFrom(obj);
Marking::BlackToGrey(markbit); Marking::BlackToGrey(markbit);
MemoryChunk::IncrementLiveBytes<mode>(obj, -obj->Size()); MemoryChunk::IncrementLiveBytes(obj, -obj->Size());
} }
template <MarkingMode mode = MarkingMode::FULL>
V8_INLINE static void WhiteToGrey(HeapObject* obj) { V8_INLINE static void WhiteToGrey(HeapObject* obj) {
DCHECK(IsWhite<mode>(obj)); DCHECK(IsWhite(obj));
Marking::WhiteToGrey(MarkBitFrom<mode>(obj)); Marking::WhiteToGrey(MarkBitFrom(obj));
} }
template <MarkingMode mode = MarkingMode::FULL>
V8_INLINE static void WhiteToBlack(HeapObject* obj) { V8_INLINE static void WhiteToBlack(HeapObject* obj) {
DCHECK(IsWhite<mode>(obj)); DCHECK(IsWhite(obj));
MarkBit markbit = MarkBitFrom<mode>(obj); MarkBit markbit = MarkBitFrom(obj);
Marking::WhiteToBlack(markbit); Marking::WhiteToBlack(markbit);
MemoryChunk::IncrementLiveBytes<mode>(obj, obj->Size()); MemoryChunk::IncrementLiveBytes(obj, obj->Size());
} }
template <MarkingMode mode = MarkingMode::FULL>
V8_INLINE static void GreyToBlack(HeapObject* obj) { V8_INLINE static void GreyToBlack(HeapObject* obj) {
DCHECK(IsGrey<mode>(obj)); DCHECK(IsGrey(obj));
MarkBit markbit = MarkBitFrom<mode>(obj); MarkBit markbit = MarkBitFrom(obj);
Marking::GreyToBlack(markbit); Marking::GreyToBlack(markbit);
MemoryChunk::IncrementLiveBytes<mode>(obj, obj->Size()); MemoryChunk::IncrementLiveBytes(obj, obj->Size());
} }
template <MarkingMode mode = MarkingMode::FULL>
V8_INLINE static void AnyToGrey(HeapObject* obj) { V8_INLINE static void AnyToGrey(HeapObject* obj) {
MarkBit markbit = MarkBitFrom<mode>(obj); MarkBit markbit = MarkBitFrom(obj);
if (Marking::IsBlack(markbit)) { if (Marking::IsBlack(markbit)) {
MemoryChunk::IncrementLiveBytes<mode>(obj, -obj->Size()); MemoryChunk::IncrementLiveBytes(obj, -obj->Size());
} }
Marking::AnyToGrey(markbit); Marking::AnyToGrey(markbit);
} }
...@@ -587,11 +573,7 @@ class MarkCompactCollector { ...@@ -587,11 +573,7 @@ class MarkCompactCollector {
// is marked. // is marked.
void MarkImplicitRefGroups(MarkObjectFunction mark_object); void MarkImplicitRefGroups(MarkObjectFunction mark_object);
template <MarkingMode mode = MarkingMode::FULL> MarkingDeque* marking_deque() { return &marking_deque_; }
MarkingDeque* marking_deque() {
return mode == MarkingMode::FULL ? &marking_deque_
: &marking_deque_young_generation_;
}
Sweeper& sweeper() { return sweeper_; } Sweeper& sweeper() { return sweeper_; }
...@@ -649,7 +631,7 @@ class MarkCompactCollector { ...@@ -649,7 +631,7 @@ class MarkCompactCollector {
friend class MarkCompactMarkingVisitor; friend class MarkCompactMarkingVisitor;
friend class MarkingVisitor; friend class MarkingVisitor;
friend class RecordMigratedSlotVisitor; friend class RecordMigratedSlotVisitor;
template <MarkingMode mode> template <MarkCompactMode mode>
friend class RootMarkingVisitor; friend class RootMarkingVisitor;
friend class SharedFunctionInfoMarkingVisitor; friend class SharedFunctionInfoMarkingVisitor;
friend class StaticYoungGenerationMarkingVisitor; friend class StaticYoungGenerationMarkingVisitor;
...@@ -667,28 +649,26 @@ class MarkCompactCollector { ...@@ -667,28 +649,26 @@ class MarkCompactCollector {
// Pushes a black object onto the marking stack and accounts for live bytes. // Pushes a black object onto the marking stack and accounts for live bytes.
// Note that this assumes live bytes have not yet been counted. // Note that this assumes live bytes have not yet been counted.
template <MarkingMode mode = MarkingMode::FULL> INLINE(void PushBlack(HeapObject* obj));
V8_INLINE void PushBlack(HeapObject* obj);
// Unshifts a black object into the marking stack and accounts for live bytes. // Unshifts a black object into the marking stack and accounts for live bytes.
// Note that this assumes lives bytes have already been counted. // Note that this assumes lives bytes have already been counted.
V8_INLINE void UnshiftBlack(HeapObject* obj); INLINE(void UnshiftBlack(HeapObject* obj));
// Marks the object black and pushes it on the marking stack. // Marks the object black and pushes it on the marking stack.
// This is for non-incremental marking only. // This is for non-incremental marking only.
template <MarkingMode mode = MarkingMode::FULL> INLINE(void MarkObject(HeapObject* obj));
V8_INLINE void MarkObject(HeapObject* obj);
// Mark the heap roots and all objects reachable from them. // Mark the heap roots and all objects reachable from them.
void MarkRoots(RootMarkingVisitor<MarkingMode::FULL>* visitor); void MarkRoots(RootMarkingVisitor<MarkCompactMode::FULL>* visitor);
// Mark the string table specially. References to internalized strings from // Mark the string table specially. References to internalized strings from
// the string table are weak. // the string table are weak.
void MarkStringTable(RootMarkingVisitor<MarkingMode::FULL>* visitor); void MarkStringTable(RootMarkingVisitor<MarkCompactMode::FULL>* visitor);
// Mark objects reachable (transitively) from objects in the marking stack // Mark objects reachable (transitively) from objects in the marking stack
// or overflowed in the heap. // or overflowed in the heap.
template <MarkingMode mode> template <MarkCompactMode mode>
void ProcessMarkingDeque(); void ProcessMarkingDeque();
// Mark objects reachable (transitively) from objects in the marking stack // Mark objects reachable (transitively) from objects in the marking stack
...@@ -712,13 +692,13 @@ class MarkCompactCollector { ...@@ -712,13 +692,13 @@ class MarkCompactCollector {
// stack. This function empties the marking stack, but may leave // stack. This function empties the marking stack, but may leave
// overflowed objects in the heap, in which case the marking stack's // overflowed objects in the heap, in which case the marking stack's
// overflow flag will be set. // overflow flag will be set.
template <MarkingMode mode> template <MarkCompactMode mode>
void EmptyMarkingDeque(); void EmptyMarkingDeque();
// Refill the marking stack with overflowed objects from the heap. This // Refill the marking stack with overflowed objects from the heap. This
// function either leaves the marking stack full or clears the overflow // function either leaves the marking stack full or clears the overflow
// flag on the marking stack. // flag on the marking stack.
template <MarkingMode mode> template <MarkCompactMode mode>
void RefillMarkingDeque(); void RefillMarkingDeque();
// Helper methods for refilling the marking stack by discovering grey objects // Helper methods for refilling the marking stack by discovering grey objects
...@@ -836,7 +816,6 @@ class MarkCompactCollector { ...@@ -836,7 +816,6 @@ class MarkCompactCollector {
bool have_code_to_deoptimize_; bool have_code_to_deoptimize_;
MarkingDeque marking_deque_; MarkingDeque marking_deque_;
MarkingDeque marking_deque_young_generation_;
CodeFlusher* code_flusher_; CodeFlusher* code_flusher_;
......
...@@ -226,52 +226,27 @@ void Page::InitializeFreeListCategories() { ...@@ -226,52 +226,27 @@ void Page::InitializeFreeListCategories() {
} }
} }
template <MarkingMode mode>
void MemoryChunk::IncrementLiveBytes(HeapObject* object, int by) { void MemoryChunk::IncrementLiveBytes(HeapObject* object, int by) {
MemoryChunk::FromAddress(object->address())->IncrementLiveBytes<mode>(by); MemoryChunk::FromAddress(object->address())->IncrementLiveBytes(by);
} }
template <MarkingMode mode>
void MemoryChunk::TraceLiveBytes(intptr_t old_value, intptr_t new_value) {
if (!FLAG_trace_live_bytes) return;
PrintIsolate(heap()->isolate(),
"live-bytes[%p:%s]: %" V8PRIdPTR "-> %" V8PRIdPTR "\n",
static_cast<void*>(this),
mode == MarkingMode::FULL ? "internal" : "external", old_value,
new_value);
}
template <MarkingMode mode>
void MemoryChunk::ResetLiveBytes() { void MemoryChunk::ResetLiveBytes() {
switch (mode) { if (FLAG_trace_live_bytes) {
case MarkingMode::FULL: PrintIsolate(heap()->isolate(), "live-bytes: reset page=%p %d->0\n",
TraceLiveBytes(live_byte_count_, 0); static_cast<void*>(this), live_byte_count_);
live_byte_count_ = 0;
break;
case MarkingMode::YOUNG_GENERATION:
TraceLiveBytes(young_generation_live_byte_count_, 0);
young_generation_live_byte_count_ = 0;
break;
} }
live_byte_count_ = 0;
} }
template <MarkingMode mode>
void MemoryChunk::IncrementLiveBytes(int by) { void MemoryChunk::IncrementLiveBytes(int by) {
switch (mode) { if (FLAG_trace_live_bytes) {
case MarkingMode::FULL: PrintIsolate(
TraceLiveBytes(live_byte_count_, live_byte_count_ + by); heap()->isolate(), "live-bytes: update page=%p delta=%d %d->%d\n",
live_byte_count_ += by; static_cast<void*>(this), by, live_byte_count_, live_byte_count_ + by);
DCHECK_GE(live_byte_count_, 0);
DCHECK_LE(static_cast<size_t>(live_byte_count_), size_);
break;
case MarkingMode::YOUNG_GENERATION:
TraceLiveBytes(young_generation_live_byte_count_,
young_generation_live_byte_count_ + by);
young_generation_live_byte_count_ += by;
DCHECK_GE(young_generation_live_byte_count_, 0);
DCHECK_LE(static_cast<size_t>(young_generation_live_byte_count_), size_);
break;
} }
live_byte_count_ += by;
DCHECK_GE(live_byte_count_, 0);
DCHECK_LE(static_cast<size_t>(live_byte_count_), size_);
} }
bool PagedSpace::Contains(Address addr) { bool PagedSpace::Contains(Address addr) {
......
...@@ -538,8 +538,8 @@ MemoryChunk* MemoryChunk::Initialize(Heap* heap, Address base, size_t size, ...@@ -538,8 +538,8 @@ MemoryChunk* MemoryChunk::Initialize(Heap* heap, Address base, size_t size,
chunk->mutex_ = new base::Mutex(); chunk->mutex_ = new base::Mutex();
chunk->available_in_free_list_ = 0; chunk->available_in_free_list_ = 0;
chunk->wasted_memory_ = 0; chunk->wasted_memory_ = 0;
chunk->ResetLiveBytes();
chunk->ClearLiveness(); chunk->ClearLiveness();
chunk->young_generation_bitmap_ = nullptr;
chunk->set_next_chunk(nullptr); chunk->set_next_chunk(nullptr);
chunk->set_prev_chunk(nullptr); chunk->set_prev_chunk(nullptr);
chunk->local_tracker_ = nullptr; chunk->local_tracker_ = nullptr;
...@@ -1119,7 +1119,6 @@ void MemoryChunk::ReleaseAllocatedMemory() { ...@@ -1119,7 +1119,6 @@ void MemoryChunk::ReleaseAllocatedMemory() {
if (typed_old_to_new_slots_.Value() != nullptr) ReleaseTypedOldToNewSlots(); if (typed_old_to_new_slots_.Value() != nullptr) ReleaseTypedOldToNewSlots();
if (typed_old_to_old_slots_ != nullptr) ReleaseTypedOldToOldSlots(); if (typed_old_to_old_slots_ != nullptr) ReleaseTypedOldToOldSlots();
if (local_tracker_ != nullptr) ReleaseLocalTracker(); if (local_tracker_ != nullptr) ReleaseLocalTracker();
if (young_generation_bitmap_ != nullptr) ReleaseExternalBitmap();
} }
static SlotSet* AllocateSlotSet(size_t size, Address page_start) { static SlotSet* AllocateSlotSet(size_t size, Address page_start) {
...@@ -1185,18 +1184,6 @@ void MemoryChunk::ReleaseLocalTracker() { ...@@ -1185,18 +1184,6 @@ void MemoryChunk::ReleaseLocalTracker() {
local_tracker_ = nullptr; local_tracker_ = nullptr;
} }
void MemoryChunk::AllocateExternalBitmap() {
DCHECK_NULL(young_generation_bitmap_);
young_generation_bitmap_ = static_cast<Bitmap*>(calloc(1, Bitmap::kSize));
young_generation_live_byte_count_ = 0;
}
void MemoryChunk::ReleaseExternalBitmap() {
DCHECK_NOT_NULL(young_generation_bitmap_);
free(young_generation_bitmap_);
young_generation_bitmap_ = nullptr;
}
void MemoryChunk::ClearLiveness() { void MemoryChunk::ClearLiveness() {
markbits()->Clear(); markbits()->Clear();
ResetLiveBytes(); ResetLiveBytes();
......
...@@ -224,10 +224,6 @@ class FreeListCategory { ...@@ -224,10 +224,6 @@ class FreeListCategory {
friend class PagedSpace; friend class PagedSpace;
}; };
// MarkingMode determines which bitmaps and counters should be used when
// accessing marking information on MemoryChunk.
enum class MarkingMode { FULL, YOUNG_GENERATION };
// MemoryChunk represents a memory region owned by a specific space. // MemoryChunk represents a memory region owned by a specific space.
// It is divided into the header and the body. Chunk start is always // It is divided into the header and the body. Chunk start is always
// 1MB aligned. Start of the body is aligned so it can accommodate // 1MB aligned. Start of the body is aligned so it can accommodate
...@@ -327,32 +323,30 @@ class MemoryChunk { ...@@ -327,32 +323,30 @@ class MemoryChunk {
static const intptr_t kReservationOffset = kAreaEndOffset + kPointerSize; static const intptr_t kReservationOffset = kAreaEndOffset + kPointerSize;
static const intptr_t kOwnerOffset = kReservationOffset + 2 * kPointerSize; static const intptr_t kOwnerOffset = kReservationOffset + 2 * kPointerSize;
static const size_t kMinHeaderSize = kSizeOffset // NOLINT static const size_t kMinHeaderSize =
+ kSizetSize // size_t size kSizeOffset + kSizetSize // size_t size
+ kIntptrSize // Flags flags_ + kIntptrSize // Flags flags_
+ kPointerSize // Address area_start_ + kPointerSize // Address area_start_
+ kPointerSize // Address area_end_ + kPointerSize // Address area_end_
+ 2 * kPointerSize // base::VirtualMemory reservation_ + 2 * kPointerSize // base::VirtualMemory reservation_
+ kPointerSize // Address owner_ + kPointerSize // Address owner_
+ kPointerSize // Heap* heap_ + kPointerSize // Heap* heap_
+ kIntSize // int progress_bar_ + kIntSize // int progress_bar_
+ kIntSize // int live_bytes_count_ + kIntSize // int live_bytes_count_
+ kPointerSize // SlotSet* old_to_new_slots_ + kPointerSize // SlotSet* old_to_new_slots_
+ kPointerSize // SlotSet* old_to_old_slots_ + kPointerSize // SlotSet* old_to_old_slots_
+ kPointerSize // TypedSlotSet* typed_old_to_new_slots_ + kPointerSize // TypedSlotSet* typed_old_to_new_slots_
+ kPointerSize // TypedSlotSet* typed_old_to_old_slots_ + kPointerSize // TypedSlotSet* typed_old_to_old_slots_
+ kPointerSize // SkipList* skip_list_ + kPointerSize // SkipList* skip_list_
+ kPointerSize // AtomicValue high_water_mark_ + kPointerSize // AtomicValue high_water_mark_
+ kPointerSize // base::Mutex* mutex_ + kPointerSize // base::Mutex* mutex_
+ kPointerSize // base::AtomicWord concurrent_sweeping_ + kPointerSize // base::AtomicWord concurrent_sweeping_
+ 2 * kSizetSize // AtomicNumber free-list statistics + 2 * kSizetSize // AtomicNumber free-list statistics
+ kPointerSize // AtomicValue next_chunk_ + kPointerSize // AtomicValue next_chunk_
+ kPointerSize // AtomicValue prev_chunk_ + kPointerSize // AtomicValue prev_chunk_
+ FreeListCategory::kSize * kNumberOfCategories // FreeListCategory categories_[kNumberOfCategories]
// FreeListCategory categories_[kNumberOfCategories] + FreeListCategory::kSize * kNumberOfCategories +
+ kPointerSize // LocalArrayBufferTracker* local_tracker_ kPointerSize; // LocalArrayBufferTracker* local_tracker_
+ kIntptrSize // intptr_t young_generation_live_byte_count_
+ kPointerSize; // Bitmap* young_generation_bitmap_
// We add some more space to the computed header size to amount for missing // We add some more space to the computed header size to amount for missing
// alignment requirements in our computation. // alignment requirements in our computation.
...@@ -376,7 +370,6 @@ class MemoryChunk { ...@@ -376,7 +370,6 @@ class MemoryChunk {
static const int kAllocatableMemory = kPageSize - kObjectStartOffset; static const int kAllocatableMemory = kPageSize - kObjectStartOffset;
template <MarkingMode mode = MarkingMode::FULL>
static inline void IncrementLiveBytes(HeapObject* object, int by); static inline void IncrementLiveBytes(HeapObject* object, int by);
// Only works if the pointer is in the first kPageSize of the MemoryChunk. // Only works if the pointer is in the first kPageSize of the MemoryChunk.
...@@ -402,9 +395,7 @@ class MemoryChunk { ...@@ -402,9 +395,7 @@ class MemoryChunk {
static bool IsValid(MemoryChunk* chunk) { return chunk != nullptr; } static bool IsValid(MemoryChunk* chunk) { return chunk != nullptr; }
Address address() const { Address address() { return reinterpret_cast<Address>(this); }
return reinterpret_cast<Address>(const_cast<MemoryChunk*>(this));
}
base::Mutex* mutex() { return mutex_; } base::Mutex* mutex() { return mutex_; }
...@@ -427,24 +418,12 @@ class MemoryChunk { ...@@ -427,24 +418,12 @@ class MemoryChunk {
} }
// Manage live byte count, i.e., count of bytes in black objects. // Manage live byte count, i.e., count of bytes in black objects.
template <MarkingMode mode = MarkingMode::FULL>
inline void ResetLiveBytes(); inline void ResetLiveBytes();
template <MarkingMode mode = MarkingMode::FULL>
inline void IncrementLiveBytes(int by); inline void IncrementLiveBytes(int by);
template <MarkingMode mode = MarkingMode::FULL>
int LiveBytes() { int LiveBytes() {
switch (mode) { DCHECK_LE(static_cast<unsigned>(live_byte_count_), size_);
case MarkingMode::FULL: return live_byte_count_;
DCHECK_LE(static_cast<unsigned>(live_byte_count_), size_);
return live_byte_count_;
case MarkingMode::YOUNG_GENERATION:
DCHECK_LE(static_cast<unsigned>(young_generation_live_byte_count_),
size_);
return static_cast<int>(young_generation_live_byte_count_);
}
UNREACHABLE();
return 0;
} }
void SetLiveBytes(int live_bytes) { void SetLiveBytes(int live_bytes) {
...@@ -482,8 +461,6 @@ class MemoryChunk { ...@@ -482,8 +461,6 @@ class MemoryChunk {
void ReleaseTypedOldToOldSlots(); void ReleaseTypedOldToOldSlots();
void AllocateLocalTracker(); void AllocateLocalTracker();
void ReleaseLocalTracker(); void ReleaseLocalTracker();
void AllocateExternalBitmap();
void ReleaseExternalBitmap();
Address area_start() { return area_start_; } Address area_start() { return area_start_; }
Address area_end() { return area_end_; } Address area_end() { return area_end_; }
...@@ -512,18 +489,15 @@ class MemoryChunk { ...@@ -512,18 +489,15 @@ class MemoryChunk {
} }
} }
template <MarkingMode mode = MarkingMode::FULL> inline Bitmap* markbits() {
inline Bitmap* markbits() const { return Bitmap::FromAddress(address() + kHeaderSize);
return mode == MarkingMode::FULL
? Bitmap::FromAddress(address() + kHeaderSize)
: young_generation_bitmap_;
} }
inline uint32_t AddressToMarkbitIndex(Address addr) const { inline uint32_t AddressToMarkbitIndex(Address addr) {
return static_cast<uint32_t>(addr - this->address()) >> kPointerSizeLog2; return static_cast<uint32_t>(addr - this->address()) >> kPointerSizeLog2;
} }
inline Address MarkbitIndexToAddress(uint32_t index) const { inline Address MarkbitIndexToAddress(uint32_t index) {
return this->address() + (index << kPointerSizeLog2); return this->address() + (index << kPointerSizeLog2);
} }
...@@ -614,9 +588,6 @@ class MemoryChunk { ...@@ -614,9 +588,6 @@ class MemoryChunk {
base::VirtualMemory* reserved_memory() { return &reservation_; } base::VirtualMemory* reserved_memory() { return &reservation_; }
template <MarkingMode mode = MarkingMode::FULL>
inline void TraceLiveBytes(intptr_t old_value, intptr_t new_value);
size_t size_; size_t size_;
Flags flags_; Flags flags_;
...@@ -672,9 +643,6 @@ class MemoryChunk { ...@@ -672,9 +643,6 @@ class MemoryChunk {
LocalArrayBufferTracker* local_tracker_; LocalArrayBufferTracker* local_tracker_;
intptr_t young_generation_live_byte_count_;
Bitmap* young_generation_bitmap_;
private: private:
void InitializeReservedMemory() { reservation_.Reset(); } void InitializeReservedMemory() { reservation_.Reset(); }
...@@ -2675,9 +2643,6 @@ class NewSpace : public Space { ...@@ -2675,9 +2643,6 @@ class NewSpace : public Space {
std::unique_ptr<ObjectIterator> GetObjectIterator() override; std::unique_ptr<ObjectIterator> GetObjectIterator() override;
SemiSpace& from_space() { return from_space_; }
SemiSpace& to_space() { return to_space_; }
private: private:
// Update allocation info to match the current to-space page. // Update allocation info to match the current to-space page.
void UpdateAllocationInfo(); void UpdateAllocationInfo();
......
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