| Index: src/accessors.cc | 
| diff --git a/src/accessors.cc b/src/accessors.cc | 
| index 9b24ee37ecf433b50062e20cb541bbda239ba337..50df0dd382ad31626c4fc274168e57a4c8131afc 100644 | 
| --- a/src/accessors.cc | 
| +++ b/src/accessors.cc | 
| @@ -32,6 +32,7 @@ Handle<AccessorInfo> Accessors::MakeAccessor( | 
| info->set_property_attributes(attributes); | 
| info->set_all_can_read(false); | 
| info->set_all_can_write(false); | 
| +  info->set_is_special_data_property(true); | 
| info->set_name(*name); | 
| Handle<Object> get = v8::FromCData(isolate, getter); | 
| Handle<Object> set = v8::FromCData(isolate, setter); | 
| @@ -126,31 +127,6 @@ bool Accessors::IsJSArrayBufferViewFieldAccessor(Handle<Map> map, | 
| } | 
|  | 
|  | 
| -bool SetPropertyOnInstanceIfInherited( | 
| -    Isolate* isolate, const v8::PropertyCallbackInfo<void>& info, | 
| -    v8::Local<v8::Name> name, Handle<Object> value) { | 
| -  Handle<Object> holder = Utils::OpenHandle(*info.Holder()); | 
| -  Handle<Object> receiver = Utils::OpenHandle(*info.This()); | 
| -  if (*holder == *receiver) return false; | 
| -  if (receiver->IsJSObject()) { | 
| -    Handle<JSObject> object = Handle<JSObject>::cast(receiver); | 
| -    // This behaves sloppy since we lost the actual strict-mode. | 
| -    // TODO(verwaest): Fix by making ExecutableAccessorInfo behave like data | 
| -    // properties. | 
| -    if (object->IsJSGlobalProxy()) { | 
| -      PrototypeIterator iter(isolate, object); | 
| -      if (iter.IsAtEnd()) return true; | 
| -      DCHECK(PrototypeIterator::GetCurrent(iter)->IsJSGlobalObject()); | 
| -      object = Handle<JSObject>::cast(PrototypeIterator::GetCurrent(iter)); | 
| -    } | 
| -    if (!object->map()->is_extensible()) return true; | 
| -    JSObject::SetOwnPropertyIgnoreAttributes(object, Utils::OpenHandle(*name), | 
| -                                             value, NONE).Check(); | 
| -  } | 
| -  return true; | 
| -} | 
| - | 
| - | 
| // | 
| // Accessors::ArgumentsIterator | 
| // | 
| @@ -174,8 +150,6 @@ void Accessors::ArgumentsIteratorSetter( | 
| Handle<JSObject> object = Utils::OpenHandle(*info.This()); | 
| Handle<Object> value = Utils::OpenHandle(*val); | 
|  | 
| -  if (SetPropertyOnInstanceIfInherited(isolate, info, name, value)) return; | 
| - | 
| LookupIterator it(object, Utils::OpenHandle(*name)); | 
| CHECK_EQ(LookupIterator::ACCESSOR, it.state()); | 
| DCHECK(it.HolderIsReceiverOrHiddenPrototype()); | 
| @@ -234,9 +208,6 @@ void Accessors::ArrayLengthSetter( | 
| HandleScope scope(isolate); | 
| Handle<JSObject> object = Utils::OpenHandle(*info.This()); | 
| Handle<Object> value = Utils::OpenHandle(*val); | 
| -  if (SetPropertyOnInstanceIfInherited(isolate, info, name, value)) { | 
| -    return; | 
| -  } | 
|  | 
| value = FlattenNumber(isolate, value); | 
|  | 
| @@ -970,9 +941,6 @@ void Accessors::FunctionPrototypeSetter( | 
| i::Isolate* isolate = reinterpret_cast<i::Isolate*>(info.GetIsolate()); | 
| HandleScope scope(isolate); | 
| Handle<Object> value = Utils::OpenHandle(*val); | 
| -  if (SetPropertyOnInstanceIfInherited(isolate, info, name, value)) { | 
| -    return; | 
| -  } | 
| Handle<JSFunction> object = | 
| Handle<JSFunction>::cast(Utils::OpenHandle(*info.Holder())); | 
| if (SetFunctionPrototype(isolate, object, value).is_null()) { | 
| @@ -1061,8 +1029,6 @@ void Accessors::FunctionLengthSetter( | 
| HandleScope scope(isolate); | 
| Handle<Object> value = Utils::OpenHandle(*val); | 
|  | 
| -  if (SetPropertyOnInstanceIfInherited(isolate, info, name, value)) return; | 
| - | 
| Handle<JSFunction> object = | 
| Handle<JSFunction>::cast(Utils::OpenHandle(*info.Holder())); | 
| if (SetFunctionLength(isolate, object, value).is_null()) { | 
| @@ -1120,8 +1086,6 @@ void Accessors::FunctionNameSetter( | 
| HandleScope scope(isolate); | 
| Handle<Object> value = Utils::OpenHandle(*val); | 
|  | 
| -  if (SetPropertyOnInstanceIfInherited(isolate, info, name, value)) return; | 
| - | 
| Handle<JSFunction> object = | 
| Handle<JSFunction>::cast(Utils::OpenHandle(*info.Holder())); | 
| if (SetFunctionName(isolate, object, value).is_null()) { | 
|  |