| Index: src/objects.cc | 
| diff --git a/src/objects.cc b/src/objects.cc | 
| index cfeecadf7b581b87006fcab43eb6963099e2e5d3..1cec9db35aa31d13a2e6964e9e916b30f8515956 100644 | 
| --- a/src/objects.cc | 
| +++ b/src/objects.cc | 
| @@ -10111,29 +10111,45 @@ SafepointEntry Code::GetSafepointEntry(Address pc) { | 
| } | 
|  | 
|  | 
| -Map* Code::FindFirstMap() { | 
| +Object* Code::FindNthObject(int n, Map* match_map) { | 
| ASSERT(is_inline_cache_stub()); | 
| DisallowHeapAllocation no_allocation; | 
| int mask = RelocInfo::ModeMask(RelocInfo::EMBEDDED_OBJECT); | 
| for (RelocIterator it(this, mask); !it.done(); it.next()) { | 
| RelocInfo* info = it.rinfo(); | 
| Object* object = info->target_object(); | 
| -    if (object->IsMap()) return Map::cast(object); | 
| +    if (object->IsHeapObject()) { | 
| +      if (HeapObject::cast(object)->map() == match_map) { | 
| +        if (--n == 0) return object; | 
| +      } | 
| +    } | 
| } | 
| return NULL; | 
| } | 
|  | 
|  | 
| -void Code::ReplaceFirstMap(Map* replace_with) { | 
| +Map* Code::FindFirstMap() { | 
| +  Object* result = FindNthObject(1, GetHeap()->meta_map()); | 
| +  return (result != NULL) ? Map::cast(result) : NULL; | 
| +} | 
| + | 
| + | 
| +void Code::ReplaceNthObject(int n, | 
| +                            Map* match_map, | 
| +                            Object* replace_with) { | 
| ASSERT(is_inline_cache_stub()); | 
| DisallowHeapAllocation no_allocation; | 
| int mask = RelocInfo::ModeMask(RelocInfo::EMBEDDED_OBJECT); | 
| for (RelocIterator it(this, mask); !it.done(); it.next()) { | 
| RelocInfo* info = it.rinfo(); | 
| Object* object = info->target_object(); | 
| -    if (object->IsMap()) { | 
| -      info->set_target_object(replace_with); | 
| -      return; | 
| +    if (object->IsHeapObject()) { | 
| +      if (HeapObject::cast(object)->map() == match_map) { | 
| +        if (--n == 0) { | 
| +          info->set_target_object(replace_with); | 
| +          return; | 
| +        } | 
| +      } | 
| } | 
| } | 
| UNREACHABLE(); | 
| @@ -10152,6 +10168,11 @@ void Code::FindAllMaps(MapHandleList* maps) { | 
| } | 
|  | 
|  | 
| +void Code::ReplaceFirstMap(Map* replace_with) { | 
| +  ReplaceNthObject(1, GetHeap()->meta_map(), replace_with); | 
| +} | 
| + | 
| + | 
| Code* Code::FindFirstCode() { | 
| ASSERT(is_inline_cache_stub()); | 
| DisallowHeapAllocation no_allocation; | 
| @@ -10193,6 +10214,21 @@ Name* Code::FindFirstName() { | 
| } | 
|  | 
|  | 
| +void Code::ReplaceNthCell(int n, Cell* replace_with) { | 
| +  ASSERT(is_inline_cache_stub()); | 
| +  DisallowHeapAllocation no_allocation; | 
| +  int mask = RelocInfo::ModeMask(RelocInfo::CELL); | 
| +  for (RelocIterator it(this, mask); !it.done(); it.next()) { | 
| +    RelocInfo* info = it.rinfo(); | 
| +    if (--n == 0) { | 
| +      info->set_target_cell(replace_with); | 
| +      return; | 
| +    } | 
| +  } | 
| +  UNREACHABLE(); | 
| +} | 
| + | 
| + | 
| void Code::ClearInlineCaches() { | 
| int mask = RelocInfo::ModeMask(RelocInfo::CODE_TARGET) | | 
| RelocInfo::ModeMask(RelocInfo::CONSTRUCT_CALL) | | 
|  |