summaryrefslogtreecommitdiff
path: root/chromium/v8/src/heap/invalidated-slots.cc
diff options
context:
space:
mode:
Diffstat (limited to 'chromium/v8/src/heap/invalidated-slots.cc')
-rw-r--r--chromium/v8/src/heap/invalidated-slots.cc59
1 files changed, 52 insertions, 7 deletions
diff --git a/chromium/v8/src/heap/invalidated-slots.cc b/chromium/v8/src/heap/invalidated-slots.cc
index 368d189c556..8fa1518d683 100644
--- a/chromium/v8/src/heap/invalidated-slots.cc
+++ b/chromium/v8/src/heap/invalidated-slots.cc
@@ -8,18 +8,35 @@
namespace v8 {
namespace internal {
-InvalidatedSlotsFilter::InvalidatedSlotsFilter(MemoryChunk* chunk) {
- // Adjust slots_in_free_space_are_valid_ if more spaces are added.
- DCHECK_IMPLIES(chunk->invalidated_slots() != nullptr,
- chunk->InOldSpace() || chunk->InLargeObjectSpace());
+InvalidatedSlotsFilter InvalidatedSlotsFilter::OldToOld(MemoryChunk* chunk) {
// The sweeper removes invalid slots and makes free space available for
// allocation. Slots for new objects can be recorded in the free space.
// Note that we cannot simply check for SweepingDone because pages in large
// object space are not swept but have SweepingDone() == true.
- slots_in_free_space_are_valid_ = chunk->SweepingDone() && chunk->InOldSpace();
+ bool slots_in_free_space_are_valid =
+ chunk->SweepingDone() && chunk->InOldSpace();
+ return InvalidatedSlotsFilter(chunk, chunk->invalidated_slots<OLD_TO_OLD>(),
+ slots_in_free_space_are_valid);
+}
+
+InvalidatedSlotsFilter InvalidatedSlotsFilter::OldToNew(MemoryChunk* chunk) {
+ // Always treat these slots as valid for old-to-new for now. Invalid
+ // old-to-new slots are always cleared.
+ bool slots_in_free_space_are_valid = true;
+ return InvalidatedSlotsFilter(chunk, chunk->invalidated_slots<OLD_TO_NEW>(),
+ slots_in_free_space_are_valid);
+}
+
+InvalidatedSlotsFilter::InvalidatedSlotsFilter(
+ MemoryChunk* chunk, InvalidatedSlots* invalidated_slots,
+ bool slots_in_free_space_are_valid) {
+ // Adjust slots_in_free_space_are_valid_ if more spaces are added.
+ DCHECK_IMPLIES(invalidated_slots != nullptr,
+ chunk->InOldSpace() || chunk->InLargeObjectSpace());
+
+ slots_in_free_space_are_valid_ = slots_in_free_space_are_valid;
+ invalidated_slots = invalidated_slots ? invalidated_slots : &empty_;
- InvalidatedSlots* invalidated_slots =
- chunk->invalidated_slots() ? chunk->invalidated_slots() : &empty_;
iterator_ = invalidated_slots->begin();
iterator_end_ = invalidated_slots->end();
sentinel_ = chunk->area_end();
@@ -37,5 +54,33 @@ InvalidatedSlotsFilter::InvalidatedSlotsFilter(MemoryChunk* chunk) {
#endif
}
+InvalidatedSlotsCleanup InvalidatedSlotsCleanup::OldToNew(MemoryChunk* chunk) {
+ return InvalidatedSlotsCleanup(chunk, chunk->invalidated_slots<OLD_TO_NEW>());
+}
+
+InvalidatedSlotsCleanup InvalidatedSlotsCleanup::NoCleanup(MemoryChunk* chunk) {
+ return InvalidatedSlotsCleanup(chunk, nullptr);
+}
+
+InvalidatedSlotsCleanup::InvalidatedSlotsCleanup(
+ MemoryChunk* chunk, InvalidatedSlots* invalidated_slots) {
+ invalidated_slots_ = invalidated_slots ? invalidated_slots : &empty_;
+ iterator_ = invalidated_slots_->begin();
+ iterator_end_ = invalidated_slots_->end();
+ sentinel_ = chunk->area_end();
+
+ if (iterator_ != iterator_end_) {
+ invalidated_start_ = iterator_->first.address();
+ invalidated_end_ = invalidated_start_ + iterator_->second;
+ } else {
+ invalidated_start_ = sentinel_;
+ invalidated_end_ = sentinel_;
+ }
+
+#ifdef DEBUG
+ last_free_ = chunk->area_start();
+#endif
+}
+
} // namespace internal
} // namespace v8