| Index: src/ic.cc
|
| diff --git a/src/ic.cc b/src/ic.cc
|
| index 643fa884139fa1d041d94d7d7092feb748a508d9..33d93614cf9a121ceb879b627fd136e059a610d4 100644
|
| --- a/src/ic.cc
|
| +++ b/src/ic.cc
|
| @@ -983,6 +983,7 @@ void LoadIC::UpdateCaches(LookupResult* lookup,
|
| Handle<AccessorInfo> callback =
|
| Handle<AccessorInfo>::cast(callback_object);
|
| if (v8::ToCData<Address>(callback->getter()) == 0) return;
|
| + if (!receiver->HasFastProperties()) return;
|
| code = isolate()->stub_cache()->ComputeLoadCallback(
|
| name, receiver, holder, callback);
|
| break;
|
| @@ -1246,6 +1247,7 @@ void KeyedLoadIC::UpdateCaches(LookupResult* lookup,
|
| Handle<AccessorInfo> callback =
|
| Handle<AccessorInfo>::cast(callback_object);
|
| if (v8::ToCData<Address>(callback->getter()) == 0) return;
|
| + if (!receiver->HasFastProperties()) return;
|
| code = isolate()->stub_cache()->ComputeKeyedLoadCallback(
|
| name, receiver, holder, callback);
|
| break;
|
| @@ -1460,6 +1462,7 @@ void StoreIC::UpdateCaches(LookupResult* lookup,
|
| Handle<AccessorInfo> callback =
|
| Handle<AccessorInfo>::cast(callback_object);
|
| if (v8::ToCData<Address>(callback->setter()) == 0) return;
|
| + if (!receiver->HasFastProperties()) return;
|
| code = isolate()->stub_cache()->ComputeStoreCallback(
|
| name, receiver, callback, strict_mode);
|
| break;
|
|
|