OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/heap/mark-compact.h" | 5 #include "src/heap/mark-compact.h" |
6 | 6 |
7 #include "src/base/atomicops.h" | 7 #include "src/base/atomicops.h" |
8 #include "src/base/bits.h" | 8 #include "src/base/bits.h" |
9 #include "src/base/sys-info.h" | 9 #include "src/base/sys-info.h" |
10 #include "src/code-stubs.h" | 10 #include "src/code-stubs.h" |
(...skipping 490 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
501 if (FLAG_concurrent_sweeping) { | 501 if (FLAG_concurrent_sweeping) { |
502 ForAllSweepingSpaces([this](AllocationSpace space) { | 502 ForAllSweepingSpaces([this](AllocationSpace space) { |
503 if (space == NEW_SPACE) return; | 503 if (space == NEW_SPACE) return; |
504 StartSweepingHelper(space); | 504 StartSweepingHelper(space); |
505 }); | 505 }); |
506 } | 506 } |
507 } | 507 } |
508 | 508 |
509 void MarkCompactCollector::Sweeper::StartSweepingHelper( | 509 void MarkCompactCollector::Sweeper::StartSweepingHelper( |
510 AllocationSpace space_to_start) { | 510 AllocationSpace space_to_start) { |
511 num_sweeping_tasks_++; | 511 num_sweeping_tasks_.Increment(1); |
512 V8::GetCurrentPlatform()->CallOnBackgroundThread( | 512 V8::GetCurrentPlatform()->CallOnBackgroundThread( |
513 new SweeperTask(this, &pending_sweeper_tasks_semaphore_, space_to_start), | 513 new SweeperTask(this, &pending_sweeper_tasks_semaphore_, space_to_start), |
514 v8::Platform::kShortRunningTask); | 514 v8::Platform::kShortRunningTask); |
515 } | 515 } |
516 | 516 |
517 void MarkCompactCollector::Sweeper::SweepOrWaitUntilSweepingCompleted( | 517 void MarkCompactCollector::Sweeper::SweepOrWaitUntilSweepingCompleted( |
518 Page* page) { | 518 Page* page) { |
519 PagedSpace* owner = reinterpret_cast<PagedSpace*>(page->owner()); | 519 PagedSpace* owner = reinterpret_cast<PagedSpace*>(page->owner()); |
520 if (!page->SweepingDone()) { | 520 if (!page->SweepingDone()) { |
521 ParallelSweepPage(page, owner); | 521 ParallelSweepPage(page, owner); |
(...skipping 26 matching lines...) Expand all Loading... |
548 if (!sweeping_in_progress_) return; | 548 if (!sweeping_in_progress_) return; |
549 | 549 |
550 // If sweeping is not completed or not running at all, we try to complete it | 550 // If sweeping is not completed or not running at all, we try to complete it |
551 // here. | 551 // here. |
552 if (!FLAG_concurrent_sweeping || !IsSweepingCompleted()) { | 552 if (!FLAG_concurrent_sweeping || !IsSweepingCompleted()) { |
553 ForAllSweepingSpaces( | 553 ForAllSweepingSpaces( |
554 [this](AllocationSpace space) { ParallelSweepSpace(space, 0); }); | 554 [this](AllocationSpace space) { ParallelSweepSpace(space, 0); }); |
555 } | 555 } |
556 | 556 |
557 if (FLAG_concurrent_sweeping) { | 557 if (FLAG_concurrent_sweeping) { |
558 while (num_sweeping_tasks_ > 0) { | 558 while (num_sweeping_tasks_.Value() > 0) { |
559 pending_sweeper_tasks_semaphore_.Wait(); | 559 pending_sweeper_tasks_semaphore_.Wait(); |
560 num_sweeping_tasks_--; | 560 num_sweeping_tasks_.Increment(-1); |
561 } | 561 } |
562 } | 562 } |
563 | 563 |
564 ForAllSweepingSpaces( | 564 ForAllSweepingSpaces( |
565 [this](AllocationSpace space) { DCHECK(sweeping_list_[space].empty()); }); | 565 [this](AllocationSpace space) { DCHECK(sweeping_list_[space].empty()); }); |
566 late_pages_ = false; | 566 late_pages_ = false; |
567 sweeping_in_progress_ = false; | 567 sweeping_in_progress_ = false; |
568 } | 568 } |
569 | 569 |
570 void MarkCompactCollector::EnsureSweepingCompleted() { | 570 void MarkCompactCollector::EnsureSweepingCompleted() { |
571 if (!sweeper().sweeping_in_progress()) return; | 571 if (!sweeper().sweeping_in_progress()) return; |
572 | 572 |
573 sweeper().EnsureCompleted(); | 573 sweeper().EnsureCompleted(); |
574 heap()->old_space()->RefillFreeList(); | 574 heap()->old_space()->RefillFreeList(); |
575 heap()->code_space()->RefillFreeList(); | 575 heap()->code_space()->RefillFreeList(); |
576 heap()->map_space()->RefillFreeList(); | 576 heap()->map_space()->RefillFreeList(); |
577 | 577 |
578 #ifdef VERIFY_HEAP | 578 #ifdef VERIFY_HEAP |
579 if (FLAG_verify_heap && !evacuation()) { | 579 if (FLAG_verify_heap && !evacuation()) { |
580 VerifyEvacuation(heap_); | 580 VerifyEvacuation(heap_); |
581 } | 581 } |
582 #endif | 582 #endif |
583 } | 583 } |
584 | 584 |
585 bool MarkCompactCollector::Sweeper::IsSweepingCompleted() { | 585 bool MarkCompactCollector::Sweeper::IsSweepingCompleted() { |
586 if (!pending_sweeper_tasks_semaphore_.WaitFor( | 586 while (pending_sweeper_tasks_semaphore_.WaitFor( |
587 base::TimeDelta::FromSeconds(0))) { | 587 base::TimeDelta::FromSeconds(0))) { |
588 return false; | 588 num_sweeping_tasks_.Increment(-1); |
589 } | 589 } |
590 pending_sweeper_tasks_semaphore_.Signal(); | 590 return num_sweeping_tasks_.Value() == 0; |
591 return true; | |
592 } | 591 } |
593 | 592 |
594 void Marking::TransferMark(Heap* heap, Address old_start, Address new_start) { | 593 void Marking::TransferMark(Heap* heap, Address old_start, Address new_start) { |
595 // This is only used when resizing an object. | 594 // This is only used when resizing an object. |
596 DCHECK(MemoryChunk::FromAddress(old_start) == | 595 DCHECK(MemoryChunk::FromAddress(old_start) == |
597 MemoryChunk::FromAddress(new_start)); | 596 MemoryChunk::FromAddress(new_start)); |
598 | 597 |
599 if (!heap->incremental_marking()->IsMarking() || | 598 if (!heap->incremental_marking()->IsMarking() || |
600 Page::FromAddress(old_start)->IsFlagSet(Page::BLACK_PAGE)) | 599 Page::FromAddress(old_start)->IsFlagSet(Page::BLACK_PAGE)) |
601 return; | 600 return; |
(...skipping 3391 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3993 MarkBit mark_bit = Marking::MarkBitFrom(host); | 3992 MarkBit mark_bit = Marking::MarkBitFrom(host); |
3994 if (Marking::IsBlack(mark_bit)) { | 3993 if (Marking::IsBlack(mark_bit)) { |
3995 RelocInfo rinfo(isolate(), pc, RelocInfo::CODE_TARGET, 0, host); | 3994 RelocInfo rinfo(isolate(), pc, RelocInfo::CODE_TARGET, 0, host); |
3996 RecordRelocSlot(host, &rinfo, target); | 3995 RecordRelocSlot(host, &rinfo, target); |
3997 } | 3996 } |
3998 } | 3997 } |
3999 } | 3998 } |
4000 | 3999 |
4001 } // namespace internal | 4000 } // namespace internal |
4002 } // namespace v8 | 4001 } // namespace v8 |
OLD | NEW |