| Index: src/ic/x87/handler-compiler-x87.cc
|
| diff --git a/src/ic/x87/handler-compiler-x87.cc b/src/ic/x87/handler-compiler-x87.cc
|
| index 00eb077e43b0976a5c8448e732fd99ad373d4911..2eb10c3a3bce9bfc32e51dd755f9b8286d02cad9 100644
|
| --- a/src/ic/x87/handler-compiler-x87.cc
|
| +++ b/src/ic/x87/handler-compiler-x87.cc
|
| @@ -17,9 +17,8 @@ namespace internal {
|
|
|
|
|
| void NamedLoadHandlerCompiler::GenerateLoadViaGetter(
|
| - MacroAssembler* masm, Handle<HeapType> type, Register receiver,
|
| - Register holder, int accessor_index, int expected_arguments,
|
| - Register scratch) {
|
| + MacroAssembler* masm, Handle<Map> map, Register receiver, Register holder,
|
| + int accessor_index, int expected_arguments, Register scratch) {
|
| {
|
| FrameScope scope(masm, StackFrame::INTERNAL);
|
|
|
| @@ -27,7 +26,7 @@ void NamedLoadHandlerCompiler::GenerateLoadViaGetter(
|
| DCHECK(!holder.is(scratch));
|
| DCHECK(!receiver.is(scratch));
|
| // Call the JavaScript getter with the receiver on the stack.
|
| - if (IC::TypeToMap(*type, masm->isolate())->IsJSGlobalObjectMap()) {
|
| + if (map->IsJSGlobalObjectMap()) {
|
| // Swap in the global receiver.
|
| __ mov(scratch,
|
| FieldOperand(receiver, JSGlobalObject::kGlobalProxyOffset));
|
| @@ -237,9 +236,8 @@ void PropertyHandlerCompiler::GenerateCheckPropertyCell(
|
|
|
|
|
| void NamedStoreHandlerCompiler::GenerateStoreViaSetter(
|
| - MacroAssembler* masm, Handle<HeapType> type, Register receiver,
|
| - Register holder, int accessor_index, int expected_arguments,
|
| - Register scratch) {
|
| + MacroAssembler* masm, Handle<Map> map, Register receiver, Register holder,
|
| + int accessor_index, int expected_arguments, Register scratch) {
|
| // ----------- S t a t e -------------
|
| // -- esp[0] : return address
|
| // -----------------------------------
|
| @@ -254,8 +252,7 @@ void NamedStoreHandlerCompiler::GenerateStoreViaSetter(
|
| DCHECK(!receiver.is(scratch));
|
| DCHECK(!value().is(scratch));
|
| // Call the JavaScript setter with receiver and value on the stack.
|
| - if (IC::TypeToMap(*type, masm->isolate())->IsJSGlobalObjectMap()) {
|
| - // Swap in the global receiver.
|
| + if (map->IsJSGlobalObjectMap()) {
|
| __ mov(scratch,
|
| FieldOperand(receiver, JSGlobalObject::kGlobalProxyOffset));
|
| receiver = scratch;
|
| @@ -419,7 +416,7 @@ Register PropertyHandlerCompiler::CheckPrototypes(
|
| Register object_reg, Register holder_reg, Register scratch1,
|
| Register scratch2, Handle<Name> name, Label* miss,
|
| PrototypeCheckType check) {
|
| - Handle<Map> receiver_map(IC::TypeToMap(*type(), isolate()));
|
| + Handle<Map> receiver_map = map();
|
|
|
| // Make sure there's no overlap between holder and object registers.
|
| DCHECK(!scratch1.is(object_reg) && !scratch1.is(holder_reg));
|
| @@ -431,8 +428,9 @@ Register PropertyHandlerCompiler::CheckPrototypes(
|
| int depth = 0;
|
|
|
| Handle<JSObject> current = Handle<JSObject>::null();
|
| - if (type()->IsConstant())
|
| - current = Handle<JSObject>::cast(type()->AsConstant()->Value());
|
| + if (receiver_map->IsJSGlobalObjectMap()) {
|
| + current = isolate()->global_object();
|
| + }
|
| Handle<JSObject> prototype = Handle<JSObject>::null();
|
| Handle<Map> current_map = receiver_map;
|
| Handle<Map> holder_map(holder()->map());
|
|
|