Commit 4356e99b authored by Ulan Degenbaev's avatar Ulan Degenbaev Committed by Commit Bot

[heap] Fix retaining path reporting for JS weak collections.

The link between the JS weak collection object and its backing store
was missing.

Change-Id: If8293a8d43fb52bc4fc9f156ccda578233a1991c
Reviewed-on: https://chromium-review.googlesource.com/579267Reviewed-by: 's avatarMichael Lippautz <mlippautz@chromium.org>
Commit-Queue: Ulan Degenbaev <ulan@chromium.org>
Cr-Commit-Position: refs/heads/master@{#46787}
parent 5faf7912
...@@ -316,7 +316,7 @@ class IncrementalMarkingMarkingVisitor final ...@@ -316,7 +316,7 @@ class IncrementalMarkingMarkingVisitor final
// Marks the object black without pushing it on the marking stack. // Marks the object black without pushing it on the marking stack.
// Returns true if object needed marking and false otherwise. // Returns true if object needed marking and false otherwise.
V8_INLINE bool MarkObjectWithoutPush(Object* obj) { V8_INLINE bool MarkObjectWithoutPush(HeapObject* host, Object* obj) {
HeapObject* heap_object = HeapObject::cast(obj); HeapObject* heap_object = HeapObject::cast(obj);
return ObjectMarking::WhiteToBlack<IncrementalMarking::kAtomicity>( return ObjectMarking::WhiteToBlack<IncrementalMarking::kAtomicity>(
heap_object, incremental_marking_->marking_state(heap_object)); heap_object, incremental_marking_->marking_state(heap_object));
......
...@@ -1070,8 +1070,14 @@ class MarkCompactMarkingVisitor final ...@@ -1070,8 +1070,14 @@ class MarkCompactMarkingVisitor final
// Marks the object black without pushing it on the marking stack. Returns // Marks the object black without pushing it on the marking stack. Returns
// true if object needed marking and false otherwise. // true if object needed marking and false otherwise.
V8_INLINE bool MarkObjectWithoutPush(HeapObject* object) { V8_INLINE bool MarkObjectWithoutPush(HeapObject* host, HeapObject* object) {
return ObjectMarking::WhiteToBlack(object, MarkingState::Internal(object)); if (ObjectMarking::WhiteToBlack(object, MarkingState::Internal(object))) {
if (V8_UNLIKELY(FLAG_track_retaining_path)) {
heap_->AddRetainer(host, object);
}
return true;
}
return false;
} }
V8_INLINE void MarkObjectByPointer(HeapObject* host, Object** p) { V8_INLINE void MarkObjectByPointer(HeapObject* host, Object** p) {
......
...@@ -273,7 +273,7 @@ int MarkingVisitor<ConcreteVisitor>::VisitJSWeakCollection( ...@@ -273,7 +273,7 @@ int MarkingVisitor<ConcreteVisitor>::VisitJSWeakCollection(
HeapObject::RawField(weak_collection, JSWeakCollection::kTableOffset); HeapObject::RawField(weak_collection, JSWeakCollection::kTableOffset);
HeapObject* obj = HeapObject::cast(*slot); HeapObject* obj = HeapObject::cast(*slot);
collector_->RecordSlot(weak_collection, slot, obj); collector_->RecordSlot(weak_collection, slot, obj);
visitor->MarkObjectWithoutPush(obj); visitor->MarkObjectWithoutPush(weak_collection, obj);
return size; return size;
} }
...@@ -321,10 +321,7 @@ void MarkingVisitor<ConcreteVisitor>::MarkMapContents(Map* map) { ...@@ -321,10 +321,7 @@ void MarkingVisitor<ConcreteVisitor>::MarkMapContents(Map* map) {
// just mark the entire descriptor array. // just mark the entire descriptor array.
if (!map->is_prototype_map()) { if (!map->is_prototype_map()) {
DescriptorArray* descriptors = map->instance_descriptors(); DescriptorArray* descriptors = map->instance_descriptors();
if (V8_UNLIKELY(FLAG_track_retaining_path)) { if (visitor->MarkObjectWithoutPush(map, descriptors) &&
heap_->AddRetainer(map, descriptors);
}
if (visitor->MarkObjectWithoutPush(descriptors) &&
descriptors->length() > 0) { descriptors->length() > 0) {
visitor->VisitPointers(descriptors, descriptors->GetFirstElementAddress(), visitor->VisitPointers(descriptors, descriptors->GetFirstElementAddress(),
descriptors->GetDescriptorEndSlot(0)); descriptors->GetDescriptorEndSlot(0));
......
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