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 #ifndef V8_MARK_COMPACT_H_ | 5 #ifndef V8_MARK_COMPACT_H_ |
6 #define V8_MARK_COMPACT_H_ | 6 #define V8_MARK_COMPACT_H_ |
7 | 7 |
8 #include "src/compiler-intrinsics.h" | 8 #include "src/compiler-intrinsics.h" |
9 #include "src/spaces.h" | 9 #include "src/spaces.h" |
10 | 10 |
(...skipping 552 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
563 static inline bool IsMarked(Object* obj); | 563 static inline bool IsMarked(Object* obj); |
564 | 564 |
565 inline Heap* heap() const { return heap_; } | 565 inline Heap* heap() const { return heap_; } |
566 inline Isolate* isolate() const; | 566 inline Isolate* isolate() const; |
567 | 567 |
568 CodeFlusher* code_flusher() { return code_flusher_; } | 568 CodeFlusher* code_flusher() { return code_flusher_; } |
569 inline bool is_code_flushing_enabled() const { return code_flusher_ != NULL; } | 569 inline bool is_code_flushing_enabled() const { return code_flusher_ != NULL; } |
570 void EnableCodeFlushing(bool enable); | 570 void EnableCodeFlushing(bool enable); |
571 | 571 |
572 enum SweeperType { | 572 enum SweeperType { |
573 CONSERVATIVE, | |
574 PARALLEL_CONSERVATIVE, | 573 PARALLEL_CONSERVATIVE, |
575 CONCURRENT_CONSERVATIVE, | 574 CONCURRENT_CONSERVATIVE, |
576 PRECISE | 575 PRECISE |
577 }; | 576 }; |
578 | 577 |
579 enum SweepingParallelism { | 578 enum SweepingParallelism { |
580 SWEEP_ON_MAIN_THREAD, | 579 SWEEP_ON_MAIN_THREAD, |
581 SWEEP_IN_PARALLEL | 580 SWEEP_IN_PARALLEL |
582 }; | 581 }; |
583 | 582 |
(...skipping 74 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
658 bool is_compacting() const { return compacting_; } | 657 bool is_compacting() const { return compacting_; } |
659 | 658 |
660 MarkingParity marking_parity() { return marking_parity_; } | 659 MarkingParity marking_parity() { return marking_parity_; } |
661 | 660 |
662 // Concurrent and parallel sweeping support. If required_freed_bytes was set | 661 // Concurrent and parallel sweeping support. If required_freed_bytes was set |
663 // to a value larger than 0, then sweeping returns after a block of at least | 662 // to a value larger than 0, then sweeping returns after a block of at least |
664 // required_freed_bytes was freed. If required_freed_bytes was set to zero | 663 // required_freed_bytes was freed. If required_freed_bytes was set to zero |
665 // then the whole given space is swept. | 664 // then the whole given space is swept. |
666 int SweepInParallel(PagedSpace* space, int required_freed_bytes); | 665 int SweepInParallel(PagedSpace* space, int required_freed_bytes); |
667 | 666 |
668 void WaitUntilSweepingCompleted(); | 667 void EnsureSweepingCompleted(); |
669 | 668 |
| 669 // If sweeper threads are not active this method will return true. If |
| 670 // this is a latency issue we should be smarter here. Otherwise, it will |
| 671 // return true if the sweeper threads are done processing the pages. |
670 bool IsSweepingCompleted(); | 672 bool IsSweepingCompleted(); |
671 | 673 |
672 void RefillFreeList(PagedSpace* space); | 674 void RefillFreeList(PagedSpace* space); |
673 | 675 |
674 bool AreSweeperThreadsActivated(); | 676 bool AreSweeperThreadsActivated(); |
675 | 677 |
676 // If a paged space is passed in, this method checks if the given space is | 678 // Checks if sweeping is in progress right now on any space. |
677 // swept concurrently. Otherwise, this method checks if concurrent sweeping | 679 bool sweeping_in_progress() { return sweeping_in_progress_; } |
678 // is in progress right now on any space. | |
679 bool IsConcurrentSweepingInProgress(PagedSpace* space = NULL); | |
680 | 680 |
681 void set_sequential_sweeping(bool sequential_sweeping) { | 681 void set_sequential_sweeping(bool sequential_sweeping) { |
682 sequential_sweeping_ = sequential_sweeping; | 682 sequential_sweeping_ = sequential_sweeping; |
683 } | 683 } |
684 | 684 |
685 bool sequential_sweeping() const { | 685 bool sequential_sweeping() const { |
686 return sequential_sweeping_; | 686 return sequential_sweeping_; |
687 } | 687 } |
688 | 688 |
689 // Mark the global table which maps weak objects to dependent code without | 689 // Mark the global table which maps weak objects to dependent code without |
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
732 | 732 |
733 MarkingParity marking_parity_; | 733 MarkingParity marking_parity_; |
734 | 734 |
735 // True if we are collecting slots to perform evacuation from evacuation | 735 // True if we are collecting slots to perform evacuation from evacuation |
736 // candidates. | 736 // candidates. |
737 bool compacting_; | 737 bool compacting_; |
738 | 738 |
739 bool was_marked_incrementally_; | 739 bool was_marked_incrementally_; |
740 | 740 |
741 // True if concurrent or parallel sweeping is currently in progress. | 741 // True if concurrent or parallel sweeping is currently in progress. |
742 bool sweeping_pending_; | 742 bool sweeping_in_progress_; |
743 | 743 |
744 base::Semaphore pending_sweeper_jobs_semaphore_; | 744 base::Semaphore pending_sweeper_jobs_semaphore_; |
745 | 745 |
746 bool sequential_sweeping_; | 746 bool sequential_sweeping_; |
747 | 747 |
748 // A pointer to the current stack-allocated GC tracer object during a full | 748 // A pointer to the current stack-allocated GC tracer object during a full |
749 // collection (NULL before and after). | 749 // collection (NULL before and after). |
750 GCTracer* tracer_; | 750 GCTracer* tracer_; |
751 | 751 |
752 SlotsBufferAllocator slots_buffer_allocator_; | 752 SlotsBufferAllocator slots_buffer_allocator_; |
(...skipping 232 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
985 private: | 985 private: |
986 MarkCompactCollector* collector_; | 986 MarkCompactCollector* collector_; |
987 }; | 987 }; |
988 | 988 |
989 | 989 |
990 const char* AllocationSpaceName(AllocationSpace space); | 990 const char* AllocationSpaceName(AllocationSpace space); |
991 | 991 |
992 } } // namespace v8::internal | 992 } } // namespace v8::internal |
993 | 993 |
994 #endif // V8_MARK_COMPACT_H_ | 994 #endif // V8_MARK_COMPACT_H_ |
OLD | NEW |