Chromium Code Reviews| Index: src/objects-visiting-inl.h |
| diff --git a/src/objects-visiting-inl.h b/src/objects-visiting-inl.h |
| index 6c3c9d44fe318d77c141a68dc6d562d86563aceb..a4b02832b9e65a036d3fe710ee8533501942bd43 100644 |
| --- a/src/objects-visiting-inl.h |
| +++ b/src/objects-visiting-inl.h |
| @@ -233,13 +233,11 @@ 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); |
| + StaticVisitor::VisitPointer(heap, rinfo->target_object_address()); |
|
Michael Starzinger
2013/06/20 12:40:34
Yes, this approach will work. But it requires a tr
|
| } |
| } |