| Index: src/arm/lithium-codegen-arm.cc
 | 
| diff --git a/src/arm/lithium-codegen-arm.cc b/src/arm/lithium-codegen-arm.cc
 | 
| index 97d763714b3646ca417d198fffafb771941f8bc0..6a3acad7b5a135ff38ce20c0df42894b8bcad557 100644
 | 
| --- a/src/arm/lithium-codegen-arm.cc
 | 
| +++ b/src/arm/lithium-codegen-arm.cc
 | 
| @@ -883,14 +883,16 @@ void LCodeGen::DeoptimizeIf(Condition condition,
 | 
|  
 | 
|  void LCodeGen::RegisterDependentCodeForEmbeddedMaps(Handle<Code> code) {
 | 
|    ZoneList<Handle<Map> > maps(1, zone());
 | 
| +  ZoneList<Handle<JSObject> > objects(1, zone());
 | 
|    int mode_mask = RelocInfo::ModeMask(RelocInfo::EMBEDDED_OBJECT);
 | 
|    for (RelocIterator it(*code, mode_mask); !it.done(); it.next()) {
 | 
| -    RelocInfo::Mode mode = it.rinfo()->rmode();
 | 
| -    if (mode == RelocInfo::EMBEDDED_OBJECT &&
 | 
| -        it.rinfo()->target_object()->IsMap()) {
 | 
| -      Handle<Map> map(Map::cast(it.rinfo()->target_object()));
 | 
| -      if (map->CanTransition()) {
 | 
| +    if (Code::IsWeakEmbeddedObject(code->kind(), it.rinfo()->target_object())) {
 | 
| +      if (it.rinfo()->target_object()->IsMap()) {
 | 
| +        Handle<Map> map(Map::cast(it.rinfo()->target_object()));
 | 
|          maps.Add(map, zone());
 | 
| +      } else if (it.rinfo()->target_object()->IsJSObject()) {
 | 
| +        Handle<JSObject> object(JSObject::cast(it.rinfo()->target_object()));
 | 
| +        objects.Add(object, zone());
 | 
|        }
 | 
|      }
 | 
|    }
 | 
| @@ -903,6 +905,9 @@ void LCodeGen::RegisterDependentCodeForEmbeddedMaps(Handle<Code> code) {
 | 
|    for (int i = 0; i < maps.length(); i++) {
 | 
|      maps.at(i)->AddDependentCode(DependentCode::kWeaklyEmbeddedGroup, code);
 | 
|    }
 | 
| +  for (int i = 0; i < objects.length(); i++) {
 | 
| +    AddWeakObjectToCodeDependency(isolate()->heap(), objects.at(i), code);
 | 
| +  }
 | 
|  }
 | 
|  
 | 
|  
 | 
| 
 |