Index: src/heap/heap.cc |
diff --git a/src/heap/heap.cc b/src/heap/heap.cc |
index 104175ddacbd172724fc30bcb676be8375b2bd06..f9e0ed3de13416dcc2aaced98b55118a75c0cd5e 100644 |
--- a/src/heap/heap.cc |
+++ b/src/heap/heap.cc |
@@ -440,7 +440,7 @@ void Heap::GarbageCollectionPrologue() { |
} |
CheckNewSpaceExpansionCriteria(); |
UpdateNewSpaceAllocationCounter(); |
- store_buffer()->MoveEntriesToRememberedSet(); |
+ store_buffer()->MoveAllEntriesToRememberedSet(); |
} |
@@ -5906,11 +5906,10 @@ void Heap::CheckHandleCount() { |
void Heap::ClearRecordedSlot(HeapObject* object, Object** slot) { |
if (!InNewSpace(object)) { |
- store_buffer()->MoveEntriesToRememberedSet(); |
Address slot_addr = reinterpret_cast<Address>(slot); |
Page* page = Page::FromAddress(slot_addr); |
DCHECK_EQ(page->owner()->identity(), OLD_SPACE); |
- RememberedSet<OLD_TO_NEW>::Remove(page, slot_addr); |
+ store_buffer()->DeleteEntry(slot_addr); |
RememberedSet<OLD_TO_OLD>::Remove(page, slot_addr); |
} |
} |
@@ -5918,10 +5917,8 @@ void Heap::ClearRecordedSlot(HeapObject* object, Object** slot) { |
void Heap::ClearRecordedSlotRange(Address start, Address end) { |
Page* page = Page::FromAddress(start); |
if (!page->InNewSpace()) { |
- store_buffer()->MoveEntriesToRememberedSet(); |
DCHECK_EQ(page->owner()->identity(), OLD_SPACE); |
- RememberedSet<OLD_TO_NEW>::RemoveRange(page, start, end, |
- SlotSet::PREFREE_EMPTY_BUCKETS); |
+ store_buffer()->DeleteEntry(start, end); |
RememberedSet<OLD_TO_OLD>::RemoveRange(page, start, end, |
SlotSet::FREE_EMPTY_BUCKETS); |
} |