Commit 99188fc4 authored by Suraj Sharma's avatar Suraj Sharma Committed by Commit Bot

[ic] Add support for StoreSlow() in Global Dispatcher

Global Objects now use the Smi handler StoreSlow() to perform
StoreGlobalIC_Slow.

Bug: chromium:1004037
Change-Id: I365ab918383525278590ca4369a4b1b0d9636d29
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1812657Reviewed-by: 's avatarToon Verwaest <verwaest@chromium.org>
Commit-Queue: Suraj Sharma <surshar@microsoft.com>
Cr-Commit-Position: refs/heads/master@{#63912}
parent f25edf22
...@@ -1033,10 +1033,15 @@ void AccessorAssembler::HandleStoreICHandlerCase( ...@@ -1033,10 +1033,15 @@ void AccessorAssembler::HandleStoreICHandlerCase(
// The slow case calls into the runtime to complete the store without // The slow case calls into the runtime to complete the store without
// causing an IC miss that would otherwise cause a transition to the // causing an IC miss that would otherwise cause a transition to the
// generic stub. // generic stub.
if (ic_mode == ICMode::kGlobalIC) {
TailCallRuntime(Runtime::kStoreGlobalIC_Slow, p->context(), p->value(),
p->slot(), p->vector(), p->receiver(), p->name());
} else {
TailCallRuntime(Runtime::kKeyedStoreIC_Slow, p->context(), p->value(), TailCallRuntime(Runtime::kKeyedStoreIC_Slow, p->context(), p->value(),
p->receiver(), p->name()); p->receiver(), p->name());
} }
} }
}
BIND(&if_nonsmi_handler); BIND(&if_nonsmi_handler);
{ {
...@@ -1530,9 +1535,14 @@ void AccessorAssembler::HandleStoreICProtoHandler( ...@@ -1530,9 +1535,14 @@ void AccessorAssembler::HandleStoreICProtoHandler(
// The slow case calls into the runtime to complete the store without // The slow case calls into the runtime to complete the store without
// causing an IC miss that would otherwise cause a transition to the // causing an IC miss that would otherwise cause a transition to the
// generic stub. // generic stub.
if (ic_mode == ICMode::kGlobalIC) {
TailCallRuntime(Runtime::kStoreGlobalIC_Slow, p->context(), p->value(),
p->slot(), p->vector(), p->receiver(), p->name());
} else {
TailCallRuntime(Runtime::kKeyedStoreIC_Slow, p->context(), p->value(), TailCallRuntime(Runtime::kKeyedStoreIC_Slow, p->context(), p->value(),
p->receiver(), p->name()); p->receiver(), p->name());
} }
}
BIND(&if_interceptor); BIND(&if_interceptor);
{ {
......
...@@ -1499,9 +1499,7 @@ void StoreIC::UpdateCaches(LookupIterator* lookup, Handle<Object> value, ...@@ -1499,9 +1499,7 @@ void StoreIC::UpdateCaches(LookupIterator* lookup, Handle<Object> value,
} else { } else {
set_slow_stub_reason("LookupForWrite said 'false'"); set_slow_stub_reason("LookupForWrite said 'false'");
// TODO(marja): change slow_stub to return MaybeObjectHandle. // TODO(marja): change slow_stub to return MaybeObjectHandle.
handler = IsStoreGlobalIC() handler = MaybeObjectHandle(StoreHandler::StoreSlow(isolate()));
? MaybeObjectHandle(slow_stub())
: MaybeObjectHandle(StoreHandler::StoreSlow(isolate()));
} }
PatchCache(lookup->name(), handler); PatchCache(lookup->name(), handler);
...@@ -1575,9 +1573,7 @@ MaybeObjectHandle StoreIC::ComputeHandler(LookupIterator* lookup) { ...@@ -1575,9 +1573,7 @@ MaybeObjectHandle StoreIC::ComputeHandler(LookupIterator* lookup) {
set_slow_stub_reason("accessor on slow map"); set_slow_stub_reason("accessor on slow map");
TRACE_HANDLER_STATS(isolate(), StoreIC_SlowStub); TRACE_HANDLER_STATS(isolate(), StoreIC_SlowStub);
MaybeObjectHandle handler = MaybeObjectHandle handler =
IsStoreGlobalIC() MaybeObjectHandle(StoreHandler::StoreSlow(isolate()));
? MaybeObjectHandle(slow_stub())
: MaybeObjectHandle(StoreHandler::StoreSlow(isolate()));
return handler; return handler;
} }
Handle<Object> accessors = lookup->GetAccessors(); Handle<Object> accessors = lookup->GetAccessors();
......
// Copyright 2019 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// Flags: --always-opt
"use strict";
var __v_0 = {};
try {
__v_0 = this;
Object.freeze(__v_0);
}
catch (e) {
}
function f() {
x = { [Symbol.toPrimitive]: () => FAIL };
}
try {
f()
} catch (e) { }
assertThrows(() => f(), ReferenceError);
// Copyright 2019 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// Flags: --always-opt
__v_1 = {};
__v_1.__defineGetter__('x', function () { });
__proto__ = __v_1;
function __f_4() {
__v_1 = {};
}
function __f_3() {
'use strict';
x = 42;
}
__f_4()
try {
__f_3();
} catch (e) { }
__proto__ = __v_1;
assertThrows(() => __f_3(), ReferenceError);
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment