Commit 23ca3ec8 authored by hpayer's avatar hpayer Committed by Commit bot

Revert of Reland concurrent sweeping of code space. (patchset #5 id:80001 of...

Revert of Reland concurrent sweeping of code space. (patchset #5 id:80001 of https://codereview.chromium.org/1225733002/)

Reason for revert:
Tests became flaky.

Original issue's description:
> Reland concurrent sweeping of code space.
>
> BUG=chromium:506778,chromium:506957,chromium:507211
> LOG=n
>
> Committed: https://crrev.com/806b81f11e3bfaef0d4330c7669e6934074be9cb
> Cr-Commit-Position: refs/heads/master@{#29748}

TBR=jochen@chromium.org,mvstanton@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=chromium:506778,chromium:506957,chromium:507211

Review URL: https://codereview.chromium.org/1242743002

Cr-Commit-Position: refs/heads/master@{#29751}
parent d5083451
...@@ -1446,10 +1446,6 @@ Code* InnerPointerToCodeCache::GcSafeFindCodeForInnerPointer( ...@@ -1446,10 +1446,6 @@ Code* InnerPointerToCodeCache::GcSafeFindCodeForInnerPointer(
// after the inner pointer. // after the inner pointer.
Page* page = Page::FromAddress(inner_pointer); Page* page = Page::FromAddress(inner_pointer);
DCHECK(page->owner() == heap->code_space());
heap->mark_compact_collector()->EnsureSweepingCompleted(
page, reinterpret_cast<PagedSpace*>(page->owner()));
Address addr = page->skip_list()->StartFor(inner_pointer); Address addr = page->skip_list()->StartFor(inner_pointer);
Address top = heap->code_space()->top(); Address top = heap->code_space()->top();
......
...@@ -509,12 +509,6 @@ const char* Heap::GetSpaceName(int idx) { ...@@ -509,12 +509,6 @@ const char* Heap::GetSpaceName(int idx) {
void Heap::ClearAllICsByKind(Code::Kind kind) { void Heap::ClearAllICsByKind(Code::Kind kind) {
// If concurrent sweeping is in progress, we have to wait for the sweeper
// threads before we iterate the heap.
if (mark_compact_collector()->sweeping_in_progress()) {
mark_compact_collector()->EnsureSweepingCompleted();
}
// TODO(mvstanton): Do not iterate the heap.
HeapObjectIterator it(code_space()); HeapObjectIterator it(code_space());
for (Object* object = it.Next(); object != NULL; object = it.Next()) { for (Object* object = it.Next(); object != NULL; object = it.Next()) {
...@@ -5163,11 +5157,6 @@ void Heap::Verify() { ...@@ -5163,11 +5157,6 @@ void Heap::Verify() {
code_space_->Verify(&no_dirty_regions_visitor); code_space_->Verify(&no_dirty_regions_visitor);
lo_space_->Verify(); lo_space_->Verify();
mark_compact_collector_.VerifyWeakEmbeddedObjectsInCode();
if (FLAG_omit_map_checks_for_leaf_maps) {
mark_compact_collector_.VerifyOmittedMapChecks();
}
} }
#endif #endif
......
...@@ -226,7 +226,6 @@ static void VerifyEvacuation(Heap* heap) { ...@@ -226,7 +226,6 @@ static void VerifyEvacuation(Heap* heap) {
void MarkCompactCollector::SetUp() { void MarkCompactCollector::SetUp() {
free_list_old_space_.Reset(new FreeList(heap_->old_space())); free_list_old_space_.Reset(new FreeList(heap_->old_space()));
free_list_code_space_.Reset(new FreeList(heap_->code_space()));
EnsureMarkingDequeIsReserved(); EnsureMarkingDequeIsReserved();
EnsureMarkingDequeIsCommitted(kMinMarkingDequeSize); EnsureMarkingDequeIsCommitted(kMinMarkingDequeSize);
} }
...@@ -367,6 +366,13 @@ void MarkCompactCollector::CollectGarbage() { ...@@ -367,6 +366,13 @@ void MarkCompactCollector::CollectGarbage() {
SweepSpaces(); SweepSpaces();
#ifdef VERIFY_HEAP
VerifyWeakEmbeddedObjectsInCode();
if (FLAG_omit_map_checks_for_leaf_maps) {
VerifyOmittedMapChecks();
}
#endif
Finish(); Finish();
if (marking_parity_ == EVEN_MARKING_PARITY) { if (marking_parity_ == EVEN_MARKING_PARITY) {
...@@ -493,13 +499,9 @@ class MarkCompactCollector::SweeperTask : public v8::Task { ...@@ -493,13 +499,9 @@ class MarkCompactCollector::SweeperTask : public v8::Task {
void MarkCompactCollector::StartSweeperThreads() { void MarkCompactCollector::StartSweeperThreads() {
DCHECK(free_list_old_space_.get()->IsEmpty()); DCHECK(free_list_old_space_.get()->IsEmpty());
DCHECK(free_list_code_space_.get()->IsEmpty());
V8::GetCurrentPlatform()->CallOnBackgroundThread( V8::GetCurrentPlatform()->CallOnBackgroundThread(
new SweeperTask(heap(), heap()->old_space()), new SweeperTask(heap(), heap()->old_space()),
v8::Platform::kShortRunningTask); v8::Platform::kShortRunningTask);
V8::GetCurrentPlatform()->CallOnBackgroundThread(
new SweeperTask(heap(), heap()->code_space()),
v8::Platform::kShortRunningTask);
} }
...@@ -510,19 +512,15 @@ void MarkCompactCollector::EnsureSweepingCompleted() { ...@@ -510,19 +512,15 @@ void MarkCompactCollector::EnsureSweepingCompleted() {
// here. // here.
if (!heap()->concurrent_sweeping_enabled() || !IsSweepingCompleted()) { if (!heap()->concurrent_sweeping_enabled() || !IsSweepingCompleted()) {
SweepInParallel(heap()->paged_space(OLD_SPACE), 0); SweepInParallel(heap()->paged_space(OLD_SPACE), 0);
SweepInParallel(heap()->paged_space(CODE_SPACE), 0);
} }
// Wait twice for both jobs. // Wait twice for both jobs.
if (heap()->concurrent_sweeping_enabled()) { if (heap()->concurrent_sweeping_enabled()) {
pending_sweeper_jobs_semaphore_.Wait(); pending_sweeper_jobs_semaphore_.Wait();
pending_sweeper_jobs_semaphore_.Wait();
} }
ParallelSweepSpacesComplete(); ParallelSweepSpacesComplete();
sweeping_in_progress_ = false; sweeping_in_progress_ = false;
RefillFreeList(heap()->paged_space(OLD_SPACE)); RefillFreeList(heap()->paged_space(OLD_SPACE));
RefillFreeList(heap()->paged_space(CODE_SPACE));
heap()->paged_space(OLD_SPACE)->ResetUnsweptFreeBytes(); heap()->paged_space(OLD_SPACE)->ResetUnsweptFreeBytes();
heap()->paged_space(CODE_SPACE)->ResetUnsweptFreeBytes();
#ifdef VERIFY_HEAP #ifdef VERIFY_HEAP
if (FLAG_verify_heap && !evacuation()) { if (FLAG_verify_heap && !evacuation()) {
...@@ -532,21 +530,6 @@ void MarkCompactCollector::EnsureSweepingCompleted() { ...@@ -532,21 +530,6 @@ void MarkCompactCollector::EnsureSweepingCompleted() {
} }
void MarkCompactCollector::EnsureSweepingCompleted(Page* page,
PagedSpace* space) {
if (!page->SweepingCompleted()) {
SweepInParallel(page, space);
if (!page->SweepingCompleted()) {
// We were not able to sweep that page, i.e., a concurrent
// sweeper thread currently owns this page.
// TODO(hpayer): This may introduce a huge pause here. We
// just care about finish sweeping of the scan on scavenge page.
EnsureSweepingCompleted();
}
}
}
bool MarkCompactCollector::IsSweepingCompleted() { bool MarkCompactCollector::IsSweepingCompleted() {
if (!pending_sweeper_jobs_semaphore_.WaitFor( if (!pending_sweeper_jobs_semaphore_.WaitFor(
base::TimeDelta::FromSeconds(0))) { base::TimeDelta::FromSeconds(0))) {
...@@ -562,8 +545,6 @@ void MarkCompactCollector::RefillFreeList(PagedSpace* space) { ...@@ -562,8 +545,6 @@ void MarkCompactCollector::RefillFreeList(PagedSpace* space) {
if (space == heap()->old_space()) { if (space == heap()->old_space()) {
free_list = free_list_old_space_.get(); free_list = free_list_old_space_.get();
} else if (space == heap()->code_space()) {
free_list = free_list_code_space_.get();
} else { } else {
// Any PagedSpace might invoke RefillFreeLists, so we need to make sure // Any PagedSpace might invoke RefillFreeLists, so we need to make sure
// to only refill them for the old space. // to only refill them for the old space.
...@@ -3512,17 +3493,14 @@ static int Sweep(PagedSpace* space, FreeList* free_list, Page* p, ...@@ -3512,17 +3493,14 @@ static int Sweep(PagedSpace* space, FreeList* free_list, Page* p,
DCHECK(reinterpret_cast<intptr_t>(free_start) % (32 * kPointerSize) == 0); DCHECK(reinterpret_cast<intptr_t>(free_start) % (32 * kPointerSize) == 0);
int offsets[16]; int offsets[16];
// If we use the skip list for code space pages, we have to lock the skip
// list because it could be accessed concurrently by the runtime or the
// deoptimizer.
SkipList* skip_list = p->skip_list(); SkipList* skip_list = p->skip_list();
int curr_region = -1;
if ((skip_list_mode == REBUILD_SKIP_LIST) && skip_list) { if ((skip_list_mode == REBUILD_SKIP_LIST) && skip_list) {
skip_list->Clear(); skip_list->Clear();
} }
intptr_t freed_bytes = 0; intptr_t freed_bytes = 0;
intptr_t max_freed_bytes = 0; intptr_t max_freed_bytes = 0;
int curr_region = -1;
for (MarkBitCellIterator it(p); !it.Done(); it.Advance()) { for (MarkBitCellIterator it(p); !it.Done(); it.Advance()) {
Address cell_base = it.CurrentCellBase(); Address cell_base = it.CurrentCellBase();
...@@ -4186,19 +4164,10 @@ int MarkCompactCollector::SweepInParallel(PagedSpace* space, ...@@ -4186,19 +4164,10 @@ int MarkCompactCollector::SweepInParallel(PagedSpace* space,
int MarkCompactCollector::SweepInParallel(Page* page, PagedSpace* space) { int MarkCompactCollector::SweepInParallel(Page* page, PagedSpace* space) {
int max_freed = 0; int max_freed = 0;
if (page->TryParallelSweeping()) { if (page->TryParallelSweeping()) {
FreeList* free_list; FreeList* free_list = free_list_old_space_.get();
FreeList private_free_list(space); FreeList private_free_list(space);
if (space->identity() == CODE_SPACE) { max_freed = Sweep<SWEEP_ONLY, SWEEP_IN_PARALLEL, IGNORE_SKIP_LIST,
free_list = free_list_code_space_.get(); IGNORE_FREE_SPACE>(space, &private_free_list, page, NULL);
max_freed =
Sweep<SWEEP_ONLY, SWEEP_IN_PARALLEL, REBUILD_SKIP_LIST,
IGNORE_FREE_SPACE>(space, &private_free_list, page, NULL);
} else {
free_list = free_list_old_space_.get();
max_freed =
Sweep<SWEEP_ONLY, SWEEP_IN_PARALLEL, IGNORE_SKIP_LIST,
IGNORE_FREE_SPACE>(space, &private_free_list, page, NULL);
}
free_list->Concatenate(&private_free_list); free_list->Concatenate(&private_free_list);
} }
return max_freed; return max_freed;
...@@ -4255,19 +4224,8 @@ void MarkCompactCollector::SweepSpace(PagedSpace* space, SweeperType sweeper) { ...@@ -4255,19 +4224,8 @@ void MarkCompactCollector::SweepSpace(PagedSpace* space, SweeperType sweeper) {
PrintF("Sweeping 0x%" V8PRIxPTR ".\n", PrintF("Sweeping 0x%" V8PRIxPTR ".\n",
reinterpret_cast<intptr_t>(p)); reinterpret_cast<intptr_t>(p));
} }
if (space->identity() == CODE_SPACE) { Sweep<SWEEP_ONLY, SWEEP_ON_MAIN_THREAD, IGNORE_SKIP_LIST,
if (FLAG_zap_code_space) { IGNORE_FREE_SPACE>(space, NULL, p, NULL);
Sweep<SWEEP_ONLY, SWEEP_ON_MAIN_THREAD, REBUILD_SKIP_LIST,
ZAP_FREE_SPACE>(space, NULL, p, NULL);
} else {
Sweep<SWEEP_ONLY, SWEEP_ON_MAIN_THREAD, REBUILD_SKIP_LIST,
IGNORE_FREE_SPACE>(space, NULL, p, NULL);
}
} else {
DCHECK(space->identity() == OLD_SPACE);
Sweep<SWEEP_ONLY, SWEEP_ON_MAIN_THREAD, IGNORE_SKIP_LIST,
IGNORE_FREE_SPACE>(space, NULL, p, NULL);
}
pages_swept++; pages_swept++;
parallel_sweeping_active = true; parallel_sweeping_active = true;
} else { } else {
...@@ -4284,17 +4242,13 @@ void MarkCompactCollector::SweepSpace(PagedSpace* space, SweeperType sweeper) { ...@@ -4284,17 +4242,13 @@ void MarkCompactCollector::SweepSpace(PagedSpace* space, SweeperType sweeper) {
if (FLAG_gc_verbose) { if (FLAG_gc_verbose) {
PrintF("Sweeping 0x%" V8PRIxPTR ".\n", reinterpret_cast<intptr_t>(p)); PrintF("Sweeping 0x%" V8PRIxPTR ".\n", reinterpret_cast<intptr_t>(p));
} }
if (space->identity() == CODE_SPACE) { if (space->identity() == CODE_SPACE && FLAG_zap_code_space) {
if (FLAG_zap_code_space) { Sweep<SWEEP_ONLY, SWEEP_ON_MAIN_THREAD, REBUILD_SKIP_LIST,
Sweep<SWEEP_ONLY, SWEEP_ON_MAIN_THREAD, REBUILD_SKIP_LIST, ZAP_FREE_SPACE>(space, NULL, p, NULL);
ZAP_FREE_SPACE>(space, NULL, p, NULL); } else if (space->identity() == CODE_SPACE) {
} else { Sweep<SWEEP_ONLY, SWEEP_ON_MAIN_THREAD, REBUILD_SKIP_LIST,
Sweep<SWEEP_ONLY, SWEEP_ON_MAIN_THREAD, REBUILD_SKIP_LIST, IGNORE_FREE_SPACE>(space, NULL, p, NULL);
IGNORE_FREE_SPACE>(space, NULL, p, NULL);
}
} else { } else {
DCHECK(space->identity() == OLD_SPACE ||
space->identity() == MAP_SPACE);
Sweep<SWEEP_ONLY, SWEEP_ON_MAIN_THREAD, IGNORE_SKIP_LIST, Sweep<SWEEP_ONLY, SWEEP_ON_MAIN_THREAD, IGNORE_SKIP_LIST,
IGNORE_FREE_SPACE>(space, NULL, p, NULL); IGNORE_FREE_SPACE>(space, NULL, p, NULL);
} }
...@@ -4334,22 +4288,19 @@ void MarkCompactCollector::SweepSpaces() { ...@@ -4334,22 +4288,19 @@ void MarkCompactCollector::SweepSpaces() {
// the other spaces rely on possibly non-live maps to get the sizes for // the other spaces rely on possibly non-live maps to get the sizes for
// non-live objects. // non-live objects.
{ {
{ GCTracer::Scope sweep_scope(heap()->tracer(),
GCTracer::Scope sweep_scope(heap()->tracer(), GCTracer::Scope::MC_SWEEP_OLDSPACE);
GCTracer::Scope::MC_SWEEP_OLDSPACE); { SweepSpace(heap()->old_space(), CONCURRENT_SWEEPING); }
SweepSpace(heap()->old_space(), CONCURRENT_SWEEPING);
}
{
GCTracer::Scope sweep_scope(heap()->tracer(),
GCTracer::Scope::MC_SWEEP_CODE);
SweepSpace(heap()->code_space(), CONCURRENT_SWEEPING);
}
sweeping_in_progress_ = true; sweeping_in_progress_ = true;
if (heap()->concurrent_sweeping_enabled()) { if (heap()->concurrent_sweeping_enabled()) {
StartSweeperThreads(); StartSweeperThreads();
} }
} }
{
GCTracer::Scope sweep_scope(heap()->tracer(),
GCTracer::Scope::MC_SWEEP_CODE);
SweepSpace(heap()->code_space(), SEQUENTIAL_SWEEPING);
}
EvacuateNewSpaceAndCandidates(); EvacuateNewSpaceAndCandidates();
...@@ -4402,7 +4353,6 @@ void MarkCompactCollector::ParallelSweepSpaceComplete(PagedSpace* space) { ...@@ -4402,7 +4353,6 @@ void MarkCompactCollector::ParallelSweepSpaceComplete(PagedSpace* space) {
void MarkCompactCollector::ParallelSweepSpacesComplete() { void MarkCompactCollector::ParallelSweepSpacesComplete() {
ParallelSweepSpaceComplete(heap()->old_space()); ParallelSweepSpaceComplete(heap()->old_space());
ParallelSweepSpaceComplete(heap()->code_space());
} }
......
...@@ -691,8 +691,6 @@ class MarkCompactCollector { ...@@ -691,8 +691,6 @@ class MarkCompactCollector {
void EnsureSweepingCompleted(); void EnsureSweepingCompleted();
void EnsureSweepingCompleted(Page* page, PagedSpace* space);
// If sweeper threads are not active this method will return true. If // If sweeper threads are not active this method will return true. If
// this is a latency issue we should be smarter here. Otherwise, it will // this is a latency issue we should be smarter here. Otherwise, it will
// return true if the sweeper threads are done processing the pages. // return true if the sweeper threads are done processing the pages.
...@@ -969,7 +967,6 @@ class MarkCompactCollector { ...@@ -969,7 +967,6 @@ class MarkCompactCollector {
List<Page*> evacuation_candidates_; List<Page*> evacuation_candidates_;
base::SmartPointer<FreeList> free_list_old_space_; base::SmartPointer<FreeList> free_list_old_space_;
base::SmartPointer<FreeList> free_list_code_space_;
friend class Heap; friend class Heap;
}; };
......
...@@ -468,9 +468,17 @@ void StoreBuffer::IteratePointersToNewSpace(ObjectSlotCallback slot_callback) { ...@@ -468,9 +468,17 @@ void StoreBuffer::IteratePointersToNewSpace(ObjectSlotCallback slot_callback) {
} }
} }
} else { } else {
if (!page->SweepingCompleted()) {
heap_->mark_compact_collector()->SweepInParallel(page, owner);
if (!page->SweepingCompleted()) {
// We were not able to sweep that page, i.e., a concurrent
// sweeper thread currently owns this page.
// TODO(hpayer): This may introduce a huge pause here. We
// just care about finish sweeping of the scan on scavenge page.
heap_->mark_compact_collector()->EnsureSweepingCompleted();
}
}
CHECK(page->owner() == heap_->old_space()); CHECK(page->owner() == heap_->old_space());
heap_->mark_compact_collector()->EnsureSweepingCompleted(page,
owner);
HeapObjectIterator iterator(page, NULL); HeapObjectIterator iterator(page, NULL);
for (HeapObject* heap_object = iterator.Next(); heap_object != NULL; for (HeapObject* heap_object = iterator.Next(); heap_object != NULL;
heap_object = iterator.Next()) { heap_object = iterator.Next()) {
......
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