Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(57)

Side by Side Diff: src/heap/mark-compact.h

Issue 2640783007: [heap] Marking cleanup (Closed)
Patch Set: Compilation fixes Created 3 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « src/heap/incremental-marking.cc ('k') | src/heap/mark-compact.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 <deque> 8 #include <deque>
9 9
10 #include "src/base/bits.h" 10 #include "src/base/bits.h"
(...skipping 498 matching lines...) Expand 10 before | Expand all | Expand 10 after
509 void AbortCompaction(); 509 void AbortCompaction();
510 510
511 // Determine type of object and emit deletion log event. 511 // Determine type of object and emit deletion log event.
512 static void ReportDeleteIfNeeded(HeapObject* obj, Isolate* isolate); 512 static void ReportDeleteIfNeeded(HeapObject* obj, Isolate* isolate);
513 513
514 // Distinguishable invalid map encodings (for single word and multiple words) 514 // Distinguishable invalid map encodings (for single word and multiple words)
515 // that indicate free regions. 515 // that indicate free regions.
516 static const uint32_t kSingleFreeEncoding = 0; 516 static const uint32_t kSingleFreeEncoding = 0;
517 static const uint32_t kMultiFreeEncoding = 1; 517 static const uint32_t kMultiFreeEncoding = 1;
518 518
519 static inline bool IsMarked(Object* obj);
520 static bool IsUnmarkedHeapObjectWithHeap(Heap* heap, Object** p); 519 static bool IsUnmarkedHeapObjectWithHeap(Heap* heap, Object** p);
521 520
522 inline Heap* heap() const { return heap_; } 521 inline Heap* heap() const { return heap_; }
523 inline Isolate* isolate() const; 522 inline Isolate* isolate() const;
524 523
525 CodeFlusher* code_flusher() { return code_flusher_; } 524 CodeFlusher* code_flusher() { return code_flusher_; }
526 inline bool is_code_flushing_enabled() const { return code_flusher_ != NULL; } 525 inline bool is_code_flushing_enabled() const { return code_flusher_ != NULL; }
527 526
528 INLINE(static bool ShouldSkipEvacuationSlotRecording(Object* host)) { 527 INLINE(static bool ShouldSkipEvacuationSlotRecording(Object* host)) {
529 return Page::FromAddress(reinterpret_cast<Address>(host)) 528 return Page::FromAddress(reinterpret_cast<Address>(host))
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after
562 // Note: Thread-safe. 561 // Note: Thread-safe.
563 void SweepAndRefill(CompactionSpace* space); 562 void SweepAndRefill(CompactionSpace* space);
564 563
565 // Checks if sweeping is in progress right now on any space. 564 // Checks if sweeping is in progress right now on any space.
566 bool sweeping_in_progress() { return sweeper().sweeping_in_progress(); } 565 bool sweeping_in_progress() { return sweeper().sweeping_in_progress(); }
567 566
568 void set_evacuation(bool evacuation) { evacuation_ = evacuation; } 567 void set_evacuation(bool evacuation) { evacuation_ = evacuation; }
569 568
570 bool evacuation() const { return evacuation_; } 569 bool evacuation() const { return evacuation_; }
571 570
572 // Special case for processing weak references in a full collection. We need
573 // to artificially keep AllocationSites alive for a time.
574 void MarkAllocationSite(AllocationSite* site);
575
576 // Mark objects in implicit references groups if their parent object 571 // Mark objects in implicit references groups if their parent object
577 // is marked. 572 // is marked.
578 void MarkImplicitRefGroups(MarkObjectFunction mark_object); 573 void MarkImplicitRefGroups(MarkObjectFunction mark_object);
579 574
580 MarkingDeque* marking_deque() { return &marking_deque_; } 575 MarkingDeque* marking_deque() { return &marking_deque_; }
581 576
582 Sweeper& sweeper() { return sweeper_; } 577 Sweeper& sweeper() { return sweeper_; }
583 578
584 #ifdef DEBUG 579 #ifdef DEBUG
585 // Checks whether performing mark-compact collection. 580 // Checks whether performing mark-compact collection.
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after
656 INLINE(void PushBlack(HeapObject* obj)); 651 INLINE(void PushBlack(HeapObject* obj));
657 652
658 // Unshifts a black object into the marking stack and accounts for live bytes. 653 // Unshifts a black object into the marking stack and accounts for live bytes.
659 // Note that this assumes lives bytes have already been counted. 654 // Note that this assumes lives bytes have already been counted.
660 INLINE(void UnshiftBlack(HeapObject* obj)); 655 INLINE(void UnshiftBlack(HeapObject* obj));
661 656
662 // Marks the object black and pushes it on the marking stack. 657 // Marks the object black and pushes it on the marking stack.
663 // This is for non-incremental marking only. 658 // This is for non-incremental marking only.
664 INLINE(void MarkObject(HeapObject* obj, MarkBit mark_bit)); 659 INLINE(void MarkObject(HeapObject* obj, MarkBit mark_bit));
665 660
666 // Marks the object black assuming that it is not yet marked.
667 // This is for non-incremental marking only.
668 INLINE(void SetMark(HeapObject* obj));
669
670 // Mark the heap roots and all objects reachable from them. 661 // Mark the heap roots and all objects reachable from them.
671 void MarkRoots(RootMarkingVisitor<MarkCompactMode::FULL>* visitor); 662 void MarkRoots(RootMarkingVisitor<MarkCompactMode::FULL>* visitor);
672 663
673 // Mark the string table specially. References to internalized strings from 664 // Mark the string table specially. References to internalized strings from
674 // the string table are weak. 665 // the string table are weak.
675 void MarkStringTable(RootMarkingVisitor<MarkCompactMode::FULL>* visitor); 666 void MarkStringTable(RootMarkingVisitor<MarkCompactMode::FULL>* visitor);
676 667
677 // Mark objects reachable (transitively) from objects in the marking stack 668 // Mark objects reachable (transitively) from objects in the marking stack
678 // or overflowed in the heap. 669 // or overflowed in the heap.
679 template <MarkCompactMode mode> 670 template <MarkCompactMode mode>
(...skipping 168 matching lines...) Expand 10 before | Expand all | Expand 10 after
848 839
849 private: 840 private:
850 MarkCompactCollector* collector_; 841 MarkCompactCollector* collector_;
851 }; 842 };
852 843
853 V8_EXPORT_PRIVATE const char* AllocationSpaceName(AllocationSpace space); 844 V8_EXPORT_PRIVATE const char* AllocationSpaceName(AllocationSpace space);
854 } // namespace internal 845 } // namespace internal
855 } // namespace v8 846 } // namespace v8
856 847
857 #endif // V8_HEAP_MARK_COMPACT_H_ 848 #endif // V8_HEAP_MARK_COMPACT_H_
OLDNEW
« no previous file with comments | « src/heap/incremental-marking.cc ('k') | src/heap/mark-compact.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698