[ic] Make sure we don't use a smi-handler for FunctionTemplate getters
BUG=chromium:704110,v8:5561 Change-Id: Ie57bccd2f9da714b179f69c14242bcf056d3065f Reviewed-on: https://chromium-review.googlesource.com/459476 Reviewed-by: Igor Sheludko <ishell@chromium.org> Commit-Queue: Toon Verwaest <verwaest@chromium.org> Cr-Commit-Position: refs/heads/master@{#44091}
This commit is contained in:
parent
b7ac3668ea
commit
810e859300
@ -774,6 +774,8 @@ class RuntimeCallTimer final {
|
|||||||
V(KeyedStoreIC_StoreElementStub) \
|
V(KeyedStoreIC_StoreElementStub) \
|
||||||
V(LoadIC_FunctionPrototypeStub) \
|
V(LoadIC_FunctionPrototypeStub) \
|
||||||
V(LoadIC_HandlerCacheHit_Accessor) \
|
V(LoadIC_HandlerCacheHit_Accessor) \
|
||||||
|
V(LoadIC_LoadAccessorDH) \
|
||||||
|
V(LoadIC_LoadAccessorFromPrototypeDH) \
|
||||||
V(LoadIC_LoadApiGetterDH) \
|
V(LoadIC_LoadApiGetterDH) \
|
||||||
V(LoadIC_LoadApiGetterFromPrototypeDH) \
|
V(LoadIC_LoadApiGetterFromPrototypeDH) \
|
||||||
V(LoadIC_LoadCallback) \
|
V(LoadIC_LoadCallback) \
|
||||||
|
42
src/ic/ic.cc
42
src/ic/ic.cc
@ -1154,28 +1154,46 @@ Handle<Object> LoadIC::GetMapIndependentHandler(LookupIterator* lookup) {
|
|||||||
return slow_stub();
|
return slow_stub();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CallOptimization call_optimization(getter);
|
||||||
|
if (call_optimization.is_simple_api_call()) {
|
||||||
|
if (!call_optimization.IsCompatibleReceiverMap(map, holder) ||
|
||||||
|
!holder->HasFastProperties()) {
|
||||||
|
TRACE_HANDLER_STATS(isolate(), LoadIC_SlowStub);
|
||||||
|
return slow_stub();
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
// FunctionTemplate isn't yet supported as smi-handler.
|
||||||
|
if (getter->IsFunctionTemplateInfo()) {
|
||||||
|
if (!holder->HasFastProperties()) {
|
||||||
|
TRACE_HANDLER_STATS(isolate(), LoadIC_SlowStub);
|
||||||
|
return slow_stub();
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
Handle<Smi> smi_handler;
|
Handle<Smi> smi_handler;
|
||||||
if (holder->HasFastProperties()) {
|
if (holder->HasFastProperties()) {
|
||||||
CallOptimization call_optimization(getter);
|
|
||||||
if (call_optimization.is_simple_api_call()) {
|
|
||||||
if (!call_optimization.IsCompatibleReceiverMap(map, holder)) {
|
|
||||||
return slow_stub();
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
smi_handler =
|
smi_handler =
|
||||||
LoadHandler::LoadAccessor(isolate(), lookup->GetAccessorIndex());
|
LoadHandler::LoadAccessor(isolate(), lookup->GetAccessorIndex());
|
||||||
|
|
||||||
if (receiver_is_holder) return smi_handler;
|
if (receiver_is_holder) {
|
||||||
} else if (receiver_is_holder && !holder->IsJSGlobalObject()) {
|
TRACE_HANDLER_STATS(isolate(), LoadIC_LoadAccessorDH);
|
||||||
TRACE_HANDLER_STATS(isolate(), LoadIC_LoadNormalDH);
|
return smi_handler;
|
||||||
return LoadHandler::LoadNormal(isolate());
|
}
|
||||||
|
TRACE_HANDLER_STATS(isolate(), LoadIC_LoadAccessorFromPrototypeDH);
|
||||||
} else if (holder->IsJSGlobalObject()) {
|
} else if (holder->IsJSGlobalObject()) {
|
||||||
TRACE_HANDLER_STATS(isolate(), LoadIC_LoadGlobalFromPrototypeDH);
|
TRACE_HANDLER_STATS(isolate(), LoadIC_LoadGlobalFromPrototypeDH);
|
||||||
smi_handler = LoadHandler::LoadGlobal(isolate());
|
smi_handler = LoadHandler::LoadGlobal(isolate());
|
||||||
} else {
|
} else {
|
||||||
TRACE_HANDLER_STATS(isolate(), LoadIC_LoadNormalFromPrototypeDH);
|
|
||||||
smi_handler = LoadHandler::LoadNormal(isolate());
|
smi_handler = LoadHandler::LoadNormal(isolate());
|
||||||
|
|
||||||
|
if (receiver_is_holder) {
|
||||||
|
TRACE_HANDLER_STATS(isolate(), LoadIC_LoadNormalDH);
|
||||||
|
return smi_handler;
|
||||||
|
}
|
||||||
|
TRACE_HANDLER_STATS(isolate(), LoadIC_LoadNormalFromPrototypeDH);
|
||||||
}
|
}
|
||||||
|
|
||||||
return LoadFromPrototype(map, holder, lookup->name(), smi_handler);
|
return LoadFromPrototype(map, holder, lookup->name(), smi_handler);
|
||||||
|
Loading…
Reference in New Issue
Block a user