Commit 80b3f169 authored by hpayer's avatar hpayer Committed by Commit bot

Directly remove slot buffer entries in deoptimized code objects.

BUG=

Review URL: https://codereview.chromium.org/1221643004

Cr-Commit-Position: refs/heads/master@{#29379}
parent b4275a70
...@@ -414,9 +414,9 @@ void Deoptimizer::DeoptimizeMarkedCodeForContext(Context* context) { ...@@ -414,9 +414,9 @@ void Deoptimizer::DeoptimizeMarkedCodeForContext(Context* context) {
PatchCodeForDeoptimization(isolate, codes[i]); PatchCodeForDeoptimization(isolate, codes[i]);
// We might be in the middle of incremental marking with compaction. // We might be in the middle of incremental marking with compaction.
// Tell collector to treat this code object in a special way and // Ignore all slots that might have been recorded on the deoptimized code
// ignore all slots that might have been recorded on it. // object.
isolate->heap()->mark_compact_collector()->InvalidateCode(codes[i]); isolate->heap()->mark_compact_collector()->RemoveObjectSlots(codes[i]);
} }
} }
......
This diff is collapsed.
...@@ -116,10 +116,6 @@ class Marking { ...@@ -116,10 +116,6 @@ class Marking {
markbit.Next().Set(); markbit.Next().Set();
} }
static void SetAllMarkBitsInRange(MarkBit start, MarkBit end);
static void ClearAllMarkBitsOfCellsContainedInRange(MarkBit start,
MarkBit end);
void TransferMark(Address old_start, Address new_start); void TransferMark(Address old_start, Address new_start);
#ifdef DEBUG #ifdef DEBUG
...@@ -325,6 +321,12 @@ class SlotsBuffer { ...@@ -325,6 +321,12 @@ class SlotsBuffer {
slots_[idx_++] = slot; slots_[idx_++] = slot;
} }
// Should be used for testing only.
ObjectSlot Get(intptr_t i) {
DCHECK(i >= 0 && i < kNumberOfElements);
return slots_[i];
}
enum SlotType { enum SlotType {
EMBEDDED_OBJECT_SLOT, EMBEDDED_OBJECT_SLOT,
OBJECT_SLOT, OBJECT_SLOT,
...@@ -363,8 +365,6 @@ class SlotsBuffer { ...@@ -363,8 +365,6 @@ class SlotsBuffer {
void UpdateSlots(Heap* heap); void UpdateSlots(Heap* heap);
void UpdateSlotsWithFilter(Heap* heap);
SlotsBuffer* next() { return next_; } SlotsBuffer* next() { return next_; }
static int SizeOfChain(SlotsBuffer* buffer) { static int SizeOfChain(SlotsBuffer* buffer) {
...@@ -377,14 +377,9 @@ class SlotsBuffer { ...@@ -377,14 +377,9 @@ class SlotsBuffer {
inline bool HasSpaceForTypedSlot() { return idx_ < kNumberOfElements - 1; } inline bool HasSpaceForTypedSlot() { return idx_ < kNumberOfElements - 1; }
static void UpdateSlotsRecordedIn(Heap* heap, SlotsBuffer* buffer, static void UpdateSlotsRecordedIn(Heap* heap, SlotsBuffer* buffer) {
bool code_slots_filtering_required) {
while (buffer != NULL) { while (buffer != NULL) {
if (code_slots_filtering_required) { buffer->UpdateSlots(heap);
buffer->UpdateSlotsWithFilter(heap);
} else {
buffer->UpdateSlots(heap);
}
buffer = buffer->next(); buffer = buffer->next();
} }
} }
...@@ -423,6 +418,10 @@ class SlotsBuffer { ...@@ -423,6 +418,10 @@ class SlotsBuffer {
// before sweeping when mark bits are still intact. // before sweeping when mark bits are still intact.
static void RemoveInvalidSlots(Heap* heap, SlotsBuffer* buffer); static void RemoveInvalidSlots(Heap* heap, SlotsBuffer* buffer);
// Eliminate all slots that point to the given invalid_object.
static void RemoveObjectSlots(Heap* heap, SlotsBuffer* buffer,
HeapObject* invalid_object);
// Ensures that there are no invalid slots in the chain of slots buffers. // Ensures that there are no invalid slots in the chain of slots buffers.
static void VerifySlots(Heap* heap, SlotsBuffer* buffer); static void VerifySlots(Heap* heap, SlotsBuffer* buffer);
...@@ -670,8 +669,6 @@ class MarkCompactCollector { ...@@ -670,8 +669,6 @@ class MarkCompactCollector {
bool TryPromoteObject(HeapObject* object, int object_size); bool TryPromoteObject(HeapObject* object, int object_size);
void InvalidateCode(Code* code);
void ClearMarkbits(); void ClearMarkbits();
bool abort_incremental_marking() const { return abort_incremental_marking_; } bool abort_incremental_marking() const { return abort_incremental_marking_; }
...@@ -744,16 +741,17 @@ class MarkCompactCollector { ...@@ -744,16 +741,17 @@ class MarkCompactCollector {
bool IsSlotInLiveObject(Address slot); bool IsSlotInLiveObject(Address slot);
void VerifyIsSlotInLiveObject(Address slot, HeapObject* object); void VerifyIsSlotInLiveObject(Address slot, HeapObject* object);
// Removes all the slots in the slot buffers that are within the given
// invalid_object.
void RemoveObjectSlots(HeapObject* invalid_object);
private: private:
class SweeperTask; class SweeperTask;
explicit MarkCompactCollector(Heap* heap); explicit MarkCompactCollector(Heap* heap);
~MarkCompactCollector(); ~MarkCompactCollector();
bool MarkInvalidatedCode();
bool WillBeDeoptimized(Code* code); bool WillBeDeoptimized(Code* code);
void RemoveDeadInvalidatedCode();
void ProcessInvalidatedCode(ObjectVisitor* visitor);
void EvictPopularEvacuationCandidate(Page* page); void EvictPopularEvacuationCandidate(Page* page);
void ClearInvalidSlotsBufferEntries(PagedSpace* space); void ClearInvalidSlotsBufferEntries(PagedSpace* space);
void ClearInvalidStoreAndSlotsBufferEntries(); void ClearInvalidStoreAndSlotsBufferEntries();
...@@ -970,7 +968,6 @@ class MarkCompactCollector { ...@@ -970,7 +968,6 @@ class MarkCompactCollector {
bool have_code_to_deoptimize_; bool have_code_to_deoptimize_;
List<Page*> evacuation_candidates_; List<Page*> evacuation_candidates_;
List<Code*> invalidated_code_;
SmartPointer<FreeList> free_list_old_space_; SmartPointer<FreeList> free_list_old_space_;
......
...@@ -6015,3 +6015,45 @@ TEST(AllocationThroughput) { ...@@ -6015,3 +6015,45 @@ TEST(AllocationThroughput) {
throughput = tracer->AllocationThroughputInBytesPerMillisecond(100); throughput = tracer->AllocationThroughputInBytesPerMillisecond(100);
CHECK_EQ(2 * (counter3 - counter1) / (time3 - time1), throughput); CHECK_EQ(2 * (counter3 - counter1) / (time3 - time1), throughput);
} }
TEST(SlotsBufferObjectSlotsRemoval) {
CcTest::InitializeVM();
v8::HandleScope scope(CcTest::isolate());
Isolate* isolate = CcTest::i_isolate();
Heap* heap = isolate->heap();
Factory* factory = isolate->factory();
SlotsBuffer* buffer = new SlotsBuffer(NULL);
void* fake_object[1];
Handle<FixedArray> array = factory->NewFixedArray(2, TENURED);
CHECK(heap->old_space()->Contains(*array));
array->set(0, reinterpret_cast<Object*>(fake_object), SKIP_WRITE_BARRIER);
// Firstly, let's test the regular slots buffer entry.
buffer->Add(HeapObject::RawField(*array, FixedArray::kHeaderSize));
DCHECK(reinterpret_cast<void*>(buffer->Get(0)) ==
HeapObject::RawField(*array, FixedArray::kHeaderSize));
SlotsBuffer::RemoveObjectSlots(CcTest::i_isolate()->heap(), buffer, *array);
DCHECK(reinterpret_cast<void*>(buffer->Get(0)) ==
HeapObject::RawField(heap->empty_fixed_array(),
FixedArrayBase::kLengthOffset));
// Secondly, let's test the typed slots buffer entry.
SlotsBuffer::AddTo(NULL, &buffer, SlotsBuffer::EMBEDDED_OBJECT_SLOT,
array->address() + FixedArray::kHeaderSize,
SlotsBuffer::FAIL_ON_OVERFLOW);
DCHECK(reinterpret_cast<void*>(buffer->Get(1)) ==
reinterpret_cast<Object**>(SlotsBuffer::EMBEDDED_OBJECT_SLOT));
DCHECK(reinterpret_cast<void*>(buffer->Get(2)) ==
HeapObject::RawField(*array, FixedArray::kHeaderSize));
SlotsBuffer::RemoveObjectSlots(CcTest::i_isolate()->heap(), buffer, *array);
DCHECK(reinterpret_cast<void*>(buffer->Get(1)) ==
HeapObject::RawField(heap->empty_fixed_array(),
FixedArrayBase::kLengthOffset));
DCHECK(reinterpret_cast<void*>(buffer->Get(2)) ==
HeapObject::RawField(heap->empty_fixed_array(),
FixedArrayBase::kLengthOffset));
delete buffer;
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment