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) | |