diff --git a/src/flag-definitions.h b/src/flag-definitions.h index 3bf32a9b14..0b0332a082 100644 --- a/src/flag-definitions.h +++ b/src/flag-definitions.h @@ -402,6 +402,8 @@ DEFINE_bool(trace_external_memory, false, "it is adjusted.") DEFINE_bool(collect_maps, true, "garbage collect maps from which no objects can be reached") +DEFINE_bool(weak_embedded_maps_in_optimized_code, false, + "make maps embedded in optimized code weak") DEFINE_bool(flush_code, true, "flush code that we expect not to use again (during full gc)") DEFINE_bool(flush_code_incrementally, true, diff --git a/src/lithium.cc b/src/lithium.cc index 81944b2c54..108eb7f777 100644 --- a/src/lithium.cc +++ b/src/lithium.cc @@ -429,7 +429,9 @@ Handle LChunk::Codegen(Code::Kind kind) { Handle code = CodeGenerator::MakeCodeEpilogue(&assembler, flags, info()); generator.FinishCode(code); - RegisterDependentCodeForEmbeddedMaps(code); + if (FLAG_weak_embedded_maps_in_optimized_code) { + RegisterDependentCodeForEmbeddedMaps(code); + } CodeGenerator::PrintCode(code, info()); return code; } diff --git a/src/mark-compact.cc b/src/mark-compact.cc index 7d611c1c1c..bfb4031f3e 100644 --- a/src/mark-compact.cc +++ b/src/mark-compact.cc @@ -85,7 +85,8 @@ class VerifyMarkingVisitor: public ObjectVisitor { void VisitEmbeddedPointer(RelocInfo* rinfo) { ASSERT(rinfo->rmode() == RelocInfo::EMBEDDED_OBJECT); - if (rinfo->host()->kind() != Code::OPTIMIZED_FUNCTION || + if (!FLAG_weak_embedded_maps_in_optimized_code || + rinfo->host()->kind() != Code::OPTIMIZED_FUNCTION || !rinfo->target_object()->IsMap() || !Map::cast(rinfo->target_object())->CanTransition()) { VisitPointer(rinfo->target_object_address()); diff --git a/src/objects-visiting-inl.h b/src/objects-visiting-inl.h index e2b0e255bb..7332a0c8d6 100644 --- a/src/objects-visiting-inl.h +++ b/src/objects-visiting-inl.h @@ -175,7 +175,8 @@ void StaticMarkingVisitor::VisitEmbeddedPointer( ASSERT(rinfo->rmode() == RelocInfo::EMBEDDED_OBJECT); ASSERT(!rinfo->target_object()->IsConsString()); HeapObject* object = HeapObject::cast(rinfo->target_object()); - if (!FLAG_collect_maps || rinfo->host()->kind() != Code::OPTIMIZED_FUNCTION || + 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);