| Index: src/ia32/lithium-codegen-ia32.cc | 
| diff --git a/src/ia32/lithium-codegen-ia32.cc b/src/ia32/lithium-codegen-ia32.cc | 
| index 14d16c018e0f8ceac3cf0ddaa1646bb06f4e48db..37de3ebaf45724d727942ba35cb2d92550033a39 100644 | 
| --- a/src/ia32/lithium-codegen-ia32.cc | 
| +++ b/src/ia32/lithium-codegen-ia32.cc | 
| @@ -1127,26 +1127,31 @@ void LCodeGen::DeoptimizeIf(Condition cc, | 
|  | 
| 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()); | 
| } | 
| } | 
| } | 
| #ifdef VERIFY_HEAP | 
| -  // This disables verification of weak embedded maps after full GC. | 
| +  // This disables verification of weak embedded objects after full GC. | 
| // AddDependentCode can cause a GC, which would observe the state where | 
| // this code is not yet in the depended code lists of the embedded maps. | 
| -  NoWeakEmbeddedMapsVerificationScope disable_verification_of_embedded_maps; | 
| +  NoWeakObjectVerificationScope disable_verification_of_embedded_objects; | 
| #endif | 
| 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); | 
| +  } | 
| } | 
|  | 
|  | 
|  |