Index: src/ic/ia32/handler-compiler-ia32.cc |
diff --git a/src/ic/ia32/handler-compiler-ia32.cc b/src/ic/ia32/handler-compiler-ia32.cc |
index ca1ea9d7dbe80fcae8a8658a3783e5c5b3de7af3..4961bed95ab00734741cace34ab52fada3131ca3 100644 |
--- a/src/ic/ia32/handler-compiler-ia32.cc |
+++ b/src/ic/ia32/handler-compiler-ia32.cc |
@@ -411,10 +411,9 @@ void NamedStoreHandlerCompiler::GenerateFieldTypeChecks(FieldType* field_type, |
} |
} |
- |
Register PropertyHandlerCompiler::CheckPrototypes( |
Register object_reg, Register holder_reg, Register scratch1, |
- Register scratch2, Handle<Name> name, Label* miss, PrototypeCheckType check, |
+ Register scratch2, Handle<Name> name, Label* miss, |
ReturnHolder return_what) { |
Handle<Map> receiver_map = map(); |
@@ -433,17 +432,6 @@ Register PropertyHandlerCompiler::CheckPrototypes( |
__ j(not_equal, miss); |
} |
- // The prototype chain of primitives (and their JSValue wrappers) depends |
- // on the native context, which can't be guarded by validity cells. |
- // |object_reg| holds the native context specific prototype in this case; |
- // we need to check its map. |
- if (check == CHECK_ALL_MAPS) { |
- __ mov(scratch1, FieldOperand(object_reg, HeapObject::kMapOffset)); |
- Handle<WeakCell> cell = Map::WeakCellForMap(receiver_map); |
- __ CmpWeakValue(scratch1, cell, scratch2); |
- __ j(not_equal, miss); |
- } |
- |
// Keep track of the current object in register reg. |
Register reg = object_reg; |
int depth = 0; |
@@ -453,15 +441,14 @@ Register PropertyHandlerCompiler::CheckPrototypes( |
current = isolate()->global_object(); |
} |
- Handle<JSObject> prototype = Handle<JSObject>::null(); |
- Handle<Map> current_map = receiver_map; |
+ Handle<Map> current_map(receiver_map->GetPrototypeChainRootMap(isolate()), |
+ isolate()); |
Handle<Map> holder_map(holder()->map()); |
// Traverse the prototype chain and check the maps in the prototype chain for |
// fast and global objects or do negative lookup for normal objects. |
while (!current_map.is_identical_to(holder_map)) { |
++depth; |
- prototype = handle(JSObject::cast(current_map->prototype())); |
if (current_map->IsJSGlobalObjectMap()) { |
GenerateCheckPropertyCell(masm(), Handle<JSGlobalObject>::cast(current), |
name, scratch2, miss); |
@@ -483,7 +470,7 @@ Register PropertyHandlerCompiler::CheckPrototypes( |
reg = holder_reg; // From now on the object will be in holder_reg. |
// Go to the next object in the prototype chain. |
- current = prototype; |
+ current = handle(JSObject::cast(current_map->prototype())); |
current_map = handle(current->map()); |
} |