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

Side by Side Diff: src/heap/scavenger-inl.h

Issue 2005173003: Immediatelly promote marked objects (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Detemplatize Scavenger::Scavenge and friends, add tests Created 4 years, 6 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/scavenger.cc ('k') | test/cctest/heap/test-heap.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 2015 the V8 project authors. All rights reserved. 1 // Copyright 2015 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_SCAVENGER_INL_H_ 5 #ifndef V8_HEAP_SCAVENGER_INL_H_
6 #define V8_HEAP_SCAVENGER_INL_H_ 6 #define V8_HEAP_SCAVENGER_INL_H_
7 7
8 #include "src/heap/scavenger.h" 8 #include "src/heap/scavenger.h"
9 9
10 namespace v8 { 10 namespace v8 {
11 namespace internal { 11 namespace internal {
12 12
13 void Scavenger::ScavengeObject(HeapObject** p, HeapObject* object, 13 template <PromotionMode promotion_mode>
14 PromotionMode promotion_mode) { 14 void Scavenger::ScavengeObject(HeapObject** p, HeapObject* object) {
15 DCHECK(object->GetIsolate()->heap()->InFromSpace(object)); 15 DCHECK(object->GetIsolate()->heap()->InFromSpace(object));
16 16
17 // We use the first word (where the map pointer usually is) of a heap 17 // We use the first word (where the map pointer usually is) of a heap
18 // object to record the forwarding pointer. A forwarding pointer can 18 // object to record the forwarding pointer. A forwarding pointer can
19 // point to an old space, the code space, or the to space of the new 19 // point to an old space, the code space, or the to space of the new
20 // generation. 20 // generation.
21 MapWord first_word = object->map_word(); 21 MapWord first_word = object->map_word();
22 22
23 // If the first word is a forwarding address, the object has already been 23 // If the first word is a forwarding address, the object has already been
24 // copied. 24 // copied.
25 if (first_word.IsForwardingAddress()) { 25 if (first_word.IsForwardingAddress()) {
26 HeapObject* dest = first_word.ToForwardingAddress(); 26 HeapObject* dest = first_word.ToForwardingAddress();
27 DCHECK(object->GetIsolate()->heap()->InFromSpace(*p)); 27 DCHECK(object->GetIsolate()->heap()->InFromSpace(*p));
28 *p = dest; 28 *p = dest;
29 return; 29 return;
30 } 30 }
31 31
32 object->GetHeap()->UpdateAllocationSite<Heap::kGlobal>( 32 object->GetHeap()->UpdateAllocationSite<Heap::kGlobal>(
33 object, object->GetHeap()->global_pretenuring_feedback_); 33 object, object->GetHeap()->global_pretenuring_feedback_);
34 34
35 // AllocationMementos are unrooted and shouldn't survive a scavenge 35 // AllocationMementos are unrooted and shouldn't survive a scavenge
36 DCHECK(object->map() != object->GetHeap()->allocation_memento_map()); 36 DCHECK(object->map() != object->GetHeap()->allocation_memento_map());
37 // Call the slow part of scavenge object. 37 // Call the slow part of scavenge object.
38 return ScavengeObjectSlow(p, object, promotion_mode); 38 return ScavengeObjectSlow<promotion_mode>(p, object);
39 }
40
41 // static
42 template <PromotionMode promotion_mode>
ulan 2016/06/01 09:09:40 promotion_mode is not used in this function, so yo
Marcel Hlopko 2016/06/01 09:19:50 Aah sorry for not noticing this. Done.
43 void Scavenger::ScavengeObjectSlow(HeapObject** p, HeapObject* object) {
44 SLOW_DCHECK(object->GetIsolate()->heap()->InFromSpace(object));
45 MapWord first_word = object->map_word();
46 SLOW_DCHECK(!first_word.IsForwardingAddress());
47 Map* map = first_word.ToMap();
48 Scavenger* scavenger = map->GetHeap()->scavenge_collector_;
49 scavenger->scavenging_visitors_table_.GetVisitor(map)(map, p, object);
39 } 50 }
40 51
41 SlotCallbackResult Scavenger::CheckAndScavengeObject( 52 SlotCallbackResult Scavenger::CheckAndScavengeObject(
42 Heap* heap, Address slot_address, PromotionMode promotion_mode) { 53 Heap* heap, Address slot_address, PromotionMode promotion_mode) {
43 Object** slot = reinterpret_cast<Object**>(slot_address); 54 Object** slot = reinterpret_cast<Object**>(slot_address);
44 Object* object = *slot; 55 Object* object = *slot;
45 if (heap->InFromSpace(object)) { 56 if (heap->InFromSpace(object)) {
46 HeapObject* heap_object = reinterpret_cast<HeapObject*>(object); 57 HeapObject* heap_object = reinterpret_cast<HeapObject*>(object);
47 DCHECK(heap_object->IsHeapObject()); 58 DCHECK(heap_object->IsHeapObject());
48 59
49 ScavengeObject(reinterpret_cast<HeapObject**>(slot), heap_object, 60 if (promotion_mode == PROMOTE_MARKED) {
50 promotion_mode); 61 ScavengeObject<PROMOTE_MARKED>(reinterpret_cast<HeapObject**>(slot),
62 heap_object);
63 } else {
64 ScavengeObject<DEFAULT_PROMOTION>(reinterpret_cast<HeapObject**>(slot),
65 heap_object);
66 }
51 67
52 object = *slot; 68 object = *slot;
53 // If the object was in from space before and is after executing the 69 // If the object was in from space before and is after executing the
54 // callback in to space, the object is still live. 70 // callback in to space, the object is still live.
55 // Unfortunately, we do not know about the slot. It could be in a 71 // Unfortunately, we do not know about the slot. It could be in a
56 // just freed free space object. 72 // just freed free space object.
57 if (heap->InToSpace(object)) { 73 if (heap->InToSpace(object)) {
58 return KEEP_SLOT; 74 return KEEP_SLOT;
59 } 75 }
60 } else { 76 } else {
61 DCHECK(!heap->InNewSpace(object)); 77 DCHECK(!heap->InNewSpace(object));
62 } 78 }
63 return REMOVE_SLOT; 79 return REMOVE_SLOT;
64 } 80 }
65 81
66 // static 82 // static
67 void StaticScavengeVisitor::VisitPointer(Heap* heap, HeapObject* obj, 83 template <PromotionMode promotion_mode>
68 Object** p) { 84 void StaticScavengeVisitor<promotion_mode>::VisitPointer(Heap* heap,
85 HeapObject* obj,
86 Object** p) {
69 Object* object = *p; 87 Object* object = *p;
70 if (!heap->InNewSpace(object)) return; 88 if (!heap->InNewSpace(object)) return;
71 Scavenger::ScavengeObject(reinterpret_cast<HeapObject**>(p), 89 Scavenger::ScavengeObject<promotion_mode>(
72 reinterpret_cast<HeapObject*>(object), 90 reinterpret_cast<HeapObject**>(p), reinterpret_cast<HeapObject*>(object));
73 DEFAULT_PROMOTION);
74 } 91 }
75 92
76 } // namespace internal 93 } // namespace internal
77 } // namespace v8 94 } // namespace v8
78 95
79 #endif // V8_HEAP_SCAVENGER_INL_H_ 96 #endif // V8_HEAP_SCAVENGER_INL_H_
OLDNEW
« no previous file with comments | « src/heap/scavenger.cc ('k') | test/cctest/heap/test-heap.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698