| 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_HEAP_MARK_COMPACT_H_ | 5 #ifndef V8_HEAP_MARK_COMPACT_H_ | 
| 6 #define V8_HEAP_MARK_COMPACT_H_ | 6 #define V8_HEAP_MARK_COMPACT_H_ | 
| 7 | 7 | 
| 8 #include "src/base/bits.h" | 8 #include "src/base/bits.h" | 
| 9 #include "src/heap/spaces.h" | 9 #include "src/heap/spaces.h" | 
| 10 | 10 | 
| (...skipping 673 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 684   // then the whole given space is swept. It returns the size of the maximum | 684   // then the whole given space is swept. It returns the size of the maximum | 
| 685   // continuous freed memory chunk. | 685   // continuous freed memory chunk. | 
| 686   int SweepInParallel(PagedSpace* space, int required_freed_bytes); | 686   int SweepInParallel(PagedSpace* space, int required_freed_bytes); | 
| 687 | 687 | 
| 688   // Sweeps a given page concurrently to the sweeper threads. It returns the | 688   // Sweeps a given page concurrently to the sweeper threads. It returns the | 
| 689   // size of the maximum continuous freed memory chunk. | 689   // size of the maximum continuous freed memory chunk. | 
| 690   int SweepInParallel(Page* page, PagedSpace* space); | 690   int SweepInParallel(Page* page, PagedSpace* space); | 
| 691 | 691 | 
| 692   void EnsureSweepingCompleted(); | 692   void EnsureSweepingCompleted(); | 
| 693 | 693 | 
|  | 694   void EnsureSweepingCompleted(Page* page, PagedSpace* space); | 
|  | 695 | 
| 694   // If sweeper threads are not active this method will return true. If | 696   // If sweeper threads are not active this method will return true. If | 
| 695   // this is a latency issue we should be smarter here. Otherwise, it will | 697   // this is a latency issue we should be smarter here. Otherwise, it will | 
| 696   // return true if the sweeper threads are done processing the pages. | 698   // return true if the sweeper threads are done processing the pages. | 
| 697   bool IsSweepingCompleted(); | 699   bool IsSweepingCompleted(); | 
| 698 | 700 | 
| 699   void RefillFreeList(PagedSpace* space); | 701   void RefillFreeList(PagedSpace* space); | 
| 700 | 702 | 
| 701   // Checks if sweeping is in progress right now on any space. | 703   // Checks if sweeping is in progress right now on any space. | 
| 702   bool sweeping_in_progress() { return sweeping_in_progress_; } | 704   bool sweeping_in_progress() { return sweeping_in_progress_; } | 
| 703 | 705 | 
| (...skipping 256 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 960   Heap* heap_; | 962   Heap* heap_; | 
| 961   base::VirtualMemory* marking_deque_memory_; | 963   base::VirtualMemory* marking_deque_memory_; | 
| 962   size_t marking_deque_memory_committed_; | 964   size_t marking_deque_memory_committed_; | 
| 963   MarkingDeque marking_deque_; | 965   MarkingDeque marking_deque_; | 
| 964   CodeFlusher* code_flusher_; | 966   CodeFlusher* code_flusher_; | 
| 965   bool have_code_to_deoptimize_; | 967   bool have_code_to_deoptimize_; | 
| 966 | 968 | 
| 967   List<Page*> evacuation_candidates_; | 969   List<Page*> evacuation_candidates_; | 
| 968 | 970 | 
| 969   base::SmartPointer<FreeList> free_list_old_space_; | 971   base::SmartPointer<FreeList> free_list_old_space_; | 
|  | 972   base::SmartPointer<FreeList> free_list_code_space_; | 
| 970 | 973 | 
| 971   friend class Heap; | 974   friend class Heap; | 
| 972 }; | 975 }; | 
| 973 | 976 | 
| 974 | 977 | 
| 975 class MarkBitCellIterator BASE_EMBEDDED { | 978 class MarkBitCellIterator BASE_EMBEDDED { | 
| 976  public: | 979  public: | 
| 977   explicit MarkBitCellIterator(MemoryChunk* chunk) : chunk_(chunk) { | 980   explicit MarkBitCellIterator(MemoryChunk* chunk) : chunk_(chunk) { | 
| 978     last_cell_index_ = Bitmap::IndexToCell(Bitmap::CellAlignIndex( | 981     last_cell_index_ = Bitmap::IndexToCell(Bitmap::CellAlignIndex( | 
| 979         chunk_->AddressToMarkbitIndex(chunk_->area_end()))); | 982         chunk_->AddressToMarkbitIndex(chunk_->area_end()))); | 
| (...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 1025  private: | 1028  private: | 
| 1026   MarkCompactCollector* collector_; | 1029   MarkCompactCollector* collector_; | 
| 1027 }; | 1030 }; | 
| 1028 | 1031 | 
| 1029 | 1032 | 
| 1030 const char* AllocationSpaceName(AllocationSpace space); | 1033 const char* AllocationSpaceName(AllocationSpace space); | 
| 1031 } | 1034 } | 
| 1032 }  // namespace v8::internal | 1035 }  // namespace v8::internal | 
| 1033 | 1036 | 
| 1034 #endif  // V8_HEAP_MARK_COMPACT_H_ | 1037 #endif  // V8_HEAP_MARK_COMPACT_H_ | 
| OLD | NEW | 
|---|