Index: src/objects-visiting-inl.h |
diff --git a/src/objects-visiting-inl.h b/src/objects-visiting-inl.h |
index 6c3c9d44fe318d77c141a68dc6d562d86563aceb..b56e6ec2f0308b2c6859d831e8f90b26a23463ea 100644 |
--- a/src/objects-visiting-inl.h |
+++ b/src/objects-visiting-inl.h |
@@ -233,13 +233,16 @@ template<typename StaticVisitor> |
void StaticMarkingVisitor<StaticVisitor>::VisitEmbeddedPointer( |
Heap* heap, RelocInfo* rinfo) { |
ASSERT(rinfo->rmode() == RelocInfo::EMBEDDED_OBJECT); |
- ASSERT(!rinfo->target_object()->IsConsString()); |
HeapObject* object = HeapObject::cast(rinfo->target_object()); |
if (!FLAG_weak_embedded_maps_in_optimized_code || !FLAG_collect_maps || |
rinfo->host()->kind() != Code::OPTIMIZED_FUNCTION || |
!object->IsMap() || !Map::cast(object)->CanTransition()) { |
- heap->mark_compact_collector()->RecordRelocSlot(rinfo, object); |
- StaticVisitor::MarkObject(heap, object); |
+ Object** target_address = rinfo->target_object_address(); |
Michael Starzinger
2013/06/20 23:25:27
This change is missing the slot recording for the
|
+ Object* old_target = *target_address; |
+ StaticVisitor::VisitPointer(heap, target_address); |
+ if (*target_address != old_target) { |
+ rinfo->set_target_object(*target_address); |
+ } |
} |
} |