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