Commit b21cda74 authored by Leszek Swirski's avatar Leszek Swirski Committed by Commit Bot

Reland "[ic] Load name/context lazily in LdaNamedProperty"

This reverts commit 5377e72c.

Reason for revert: Looks like the relevant graphs didn't recover after
this revert, which suggests that the regression was an unrelated
secondary effect. Relanding the original change since the revert did
cause some microbenchmark regressions.

Original change's description:
> Revert "[ic] Load name/context lazily in LdaNamedProperty"
> 
> This reverts commit 347092ac.
> 
> Not a clean revert, since other changes got baked on top, but rather
> a manual removal of LoadLazyICParameters.
> 
> Reason for revert: Seems to actually regress bindings perf tests (see
> bugs and https://chromeperf.appspot.com/group_report?rev=62539), doesn't
> seem to improve performance elsewhere, and increases complexity.
> 
> Original change's description:
> > [ic] Load name/context lazily in LdaNamedProperty
> >
> > Introduces LazyLoadICParameters which allow a LazyNode for context and
> > name. These aren't used on the fast path, so we want to avoid reading
> > them for both performance and register pressure reasons.
> >
> > Change-Id: Ifb637cf4782ce984feee9af503998e7539beb823
> > Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1686665
> > Commit-Queue: Leszek Swirski <leszeks@chromium.org>
> > Reviewed-by: Toon Verwaest <verwaest@chromium.org>
> > Cr-Commit-Position: refs/heads/master@{#62539}
> 
> # Not skipping CQ checks because original CL landed > 1 day ago.
> 
> Bug: chromium:981797
> Bug: chromium:982630
> Change-Id: I88af764d17afb76d6e64b95a3d1e4aaa1c6c8978
> Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1934327
> Auto-Submit: Leszek Swirski <leszeks@chromium.org>
> Reviewed-by: Toon Verwaest <verwaest@chromium.org>
> Commit-Queue: Toon Verwaest <verwaest@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#65205}

TBR=leszeks@chromium.org,verwaest@chromium.org

# Not skipping CQ checks because original CL landed > 1 day ago.

Bug: chromium:981797, chromium:982630, v8:10059
Change-Id: I13754de06c83439e03e22cfaa7a14ce454076db9
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1973730Reviewed-by: 's avatarLeszek Swirski <leszeks@chromium.org>
Commit-Queue: Leszek Swirski <leszeks@chromium.org>
Cr-Commit-Position: refs/heads/master@{#65499}
parent eae14b55
...@@ -134,7 +134,7 @@ void AccessorAssembler::HandlePolymorphicCase( ...@@ -134,7 +134,7 @@ void AccessorAssembler::HandlePolymorphicCase(
} }
void AccessorAssembler::HandleLoadICHandlerCase( void AccessorAssembler::HandleLoadICHandlerCase(
const LoadICParameters* p, TNode<Object> handler, Label* miss, const LazyLoadICParameters* p, TNode<Object> handler, Label* miss,
ExitPoint* exit_point, ICMode ic_mode, OnNonExistent on_nonexistent, ExitPoint* exit_point, ICMode ic_mode, OnNonExistent on_nonexistent,
ElementSupport support_elements, LoadAccessMode access_mode) { ElementSupport support_elements, LoadAccessMode access_mode) {
Comment("have_handler"); Comment("have_handler");
...@@ -173,10 +173,9 @@ void AccessorAssembler::HandleLoadICHandlerCase( ...@@ -173,10 +173,9 @@ void AccessorAssembler::HandleLoadICHandlerCase(
} }
} }
void AccessorAssembler::HandleLoadCallbackProperty(const LoadICParameters* p, void AccessorAssembler::HandleLoadCallbackProperty(
TNode<JSObject> holder, const LazyLoadICParameters* p, TNode<JSObject> holder,
TNode<WordT> handler_word, TNode<WordT> handler_word, ExitPoint* exit_point) {
ExitPoint* exit_point) {
Comment("native_data_property_load"); Comment("native_data_property_load");
TNode<IntPtrT> descriptor = TNode<IntPtrT> descriptor =
Signed(DecodeWord<LoadHandler::DescriptorBits>(handler_word)); Signed(DecodeWord<LoadHandler::DescriptorBits>(handler_word));
...@@ -190,7 +189,7 @@ void AccessorAssembler::HandleLoadCallbackProperty(const LoadICParameters* p, ...@@ -190,7 +189,7 @@ void AccessorAssembler::HandleLoadCallbackProperty(const LoadICParameters* p,
} }
void AccessorAssembler::HandleLoadAccessor( void AccessorAssembler::HandleLoadAccessor(
const LoadICParameters* p, TNode<CallHandlerInfo> call_handler_info, const LazyLoadICParameters* p, TNode<CallHandlerInfo> call_handler_info,
TNode<WordT> handler_word, TNode<DataHandler> handler, TNode<WordT> handler_word, TNode<DataHandler> handler,
TNode<IntPtrT> handler_kind, ExitPoint* exit_point) { TNode<IntPtrT> handler_kind, ExitPoint* exit_point) {
Comment("api_getter"); Comment("api_getter");
...@@ -300,7 +299,7 @@ TNode<MaybeObject> AccessorAssembler::LoadDescriptorValueOrFieldType( ...@@ -300,7 +299,7 @@ TNode<MaybeObject> AccessorAssembler::LoadDescriptorValueOrFieldType(
} }
void AccessorAssembler::HandleLoadICSmiHandlerCase( void AccessorAssembler::HandleLoadICSmiHandlerCase(
const LoadICParameters* p, TNode<Object> holder, TNode<Smi> smi_handler, const LazyLoadICParameters* p, TNode<Object> holder, TNode<Smi> smi_handler,
TNode<Object> handler, Label* miss, ExitPoint* exit_point, ICMode ic_mode, TNode<Object> handler, Label* miss, ExitPoint* exit_point, ICMode ic_mode,
OnNonExistent on_nonexistent, ElementSupport support_elements, OnNonExistent on_nonexistent, ElementSupport support_elements,
LoadAccessMode access_mode) { LoadAccessMode access_mode) {
...@@ -463,7 +462,7 @@ void AccessorAssembler::HandleLoadICSmiHandlerCase( ...@@ -463,7 +462,7 @@ void AccessorAssembler::HandleLoadICSmiHandlerCase(
} }
void AccessorAssembler::HandleLoadICSmiHandlerLoadNamedCase( void AccessorAssembler::HandleLoadICSmiHandlerLoadNamedCase(
const LoadICParameters* p, TNode<Object> holder, const LazyLoadICParameters* p, TNode<Object> holder,
TNode<IntPtrT> handler_kind, TNode<WordT> handler_word, Label* rebox_double, TNode<IntPtrT> handler_kind, TNode<WordT> handler_word, Label* rebox_double,
TVariable<Float64T>* var_double_value, TNode<Object> handler, Label* miss, TVariable<Float64T>* var_double_value, TNode<Object> handler, Label* miss,
ExitPoint* exit_point, ICMode ic_mode, OnNonExistent on_nonexistent, ExitPoint* exit_point, ICMode ic_mode, OnNonExistent on_nonexistent,
...@@ -685,7 +684,7 @@ void AccessorAssembler::HandleLoadICSmiHandlerLoadNamedCase( ...@@ -685,7 +684,7 @@ void AccessorAssembler::HandleLoadICSmiHandlerLoadNamedCase(
} }
void AccessorAssembler::HandleLoadICSmiHandlerHasNamedCase( void AccessorAssembler::HandleLoadICSmiHandlerHasNamedCase(
const LoadICParameters* p, TNode<Object> holder, const LazyLoadICParameters* p, TNode<Object> holder,
TNode<IntPtrT> handler_kind, Label* miss, ExitPoint* exit_point, TNode<IntPtrT> handler_kind, Label* miss, ExitPoint* exit_point,
ICMode ic_mode) { ICMode ic_mode) {
Label return_true(this), return_false(this), return_lookup(this), Label return_true(this), return_false(this), return_lookup(this),
...@@ -891,7 +890,7 @@ TNode<Object> AccessorAssembler::HandleProtoHandler( ...@@ -891,7 +890,7 @@ TNode<Object> AccessorAssembler::HandleProtoHandler(
} }
void AccessorAssembler::HandleLoadICProtoHandler( void AccessorAssembler::HandleLoadICProtoHandler(
const LoadICParameters* p, TNode<DataHandler> handler, const LazyLoadICParameters* p, TNode<DataHandler> handler,
TVariable<Object>* var_holder, TVariable<Object>* var_smi_handler, TVariable<Object>* var_holder, TVariable<Object>* var_smi_handler,
Label* if_smi_handler, Label* miss, ExitPoint* exit_point, ICMode ic_mode, Label* if_smi_handler, Label* miss, ExitPoint* exit_point, ICMode ic_mode,
LoadAccessMode access_mode) { LoadAccessMode access_mode) {
...@@ -2423,8 +2422,9 @@ void AccessorAssembler::GenericPropertyLoad(TNode<HeapObject> receiver, ...@@ -2423,8 +2422,9 @@ void AccessorAssembler::GenericPropertyLoad(TNode<HeapObject> receiver,
&found_handler, &var_handler, &stub_cache_miss); &found_handler, &var_handler, &stub_cache_miss);
BIND(&found_handler); BIND(&found_handler);
{ {
HandleLoadICHandlerCase(p, CAST(var_handler.value()), &stub_cache_miss, LazyLoadICParameters lazy_p(p);
&direct_exit); HandleLoadICHandlerCase(&lazy_p, CAST(var_handler.value()),
&stub_cache_miss, &direct_exit);
} }
BIND(&stub_cache_miss); BIND(&stub_cache_miss);
...@@ -2656,7 +2656,7 @@ void AccessorAssembler::TryProbeStubCache(StubCache* stub_cache, ...@@ -2656,7 +2656,7 @@ void AccessorAssembler::TryProbeStubCache(StubCache* stub_cache,
//////////////////// Entry points into private implementation (one per stub). //////////////////// Entry points into private implementation (one per stub).
void AccessorAssembler::LoadIC_BytecodeHandler(const LoadICParameters* p, void AccessorAssembler::LoadIC_BytecodeHandler(const LazyLoadICParameters* p,
ExitPoint* exit_point) { ExitPoint* exit_point) {
// Must be kept in sync with LoadIC. // Must be kept in sync with LoadIC.
...@@ -2750,7 +2750,9 @@ void AccessorAssembler::LoadIC(const LoadICParameters* p) { ...@@ -2750,7 +2750,9 @@ void AccessorAssembler::LoadIC(const LoadICParameters* p) {
&if_handler, &var_handler, &try_polymorphic); &if_handler, &var_handler, &try_polymorphic);
BIND(&if_handler); BIND(&if_handler);
{ {
HandleLoadICHandlerCase(p, CAST(var_handler.value()), &miss, &direct_exit); LazyLoadICParameters lazy_p(p);
HandleLoadICHandlerCase(&lazy_p, CAST(var_handler.value()), &miss,
&direct_exit);
} }
BIND(&try_polymorphic); BIND(&try_polymorphic);
...@@ -2832,8 +2834,10 @@ void AccessorAssembler::LoadIC_NoFeedback(const LoadICParameters* p, ...@@ -2832,8 +2834,10 @@ void AccessorAssembler::LoadIC_NoFeedback(const LoadICParameters* p,
} }
void AccessorAssembler::LoadGlobalIC(TNode<HeapObject> maybe_feedback_vector, void AccessorAssembler::LoadGlobalIC(TNode<HeapObject> maybe_feedback_vector,
TNode<Smi> smi_slot, TNode<UintPtrT> slot, const LazyNode<Smi>& lazy_smi_slot,
TNode<Context> context, TNode<Name> name, const LazyNode<UintPtrT>& lazy_slot,
const LazyNode<Context>& lazy_context,
const LazyNode<Name>& lazy_name,
TypeofMode typeof_mode, TypeofMode typeof_mode,
ExitPoint* exit_point) { ExitPoint* exit_point) {
Label try_handler(this, Label::kDeferred), miss(this, Label::kDeferred), Label try_handler(this, Label::kDeferred), miss(this, Label::kDeferred),
...@@ -2842,19 +2846,22 @@ void AccessorAssembler::LoadGlobalIC(TNode<HeapObject> maybe_feedback_vector, ...@@ -2842,19 +2846,22 @@ void AccessorAssembler::LoadGlobalIC(TNode<HeapObject> maybe_feedback_vector,
GotoIf(IsUndefined(maybe_feedback_vector), &no_feedback); GotoIf(IsUndefined(maybe_feedback_vector), &no_feedback);
{ {
TNode<FeedbackVector> vector = CAST(maybe_feedback_vector); TNode<FeedbackVector> vector = CAST(maybe_feedback_vector);
LoadGlobalIC_TryPropertyCellCase(vector, slot, context, exit_point, TNode<UintPtrT> slot = lazy_slot();
LoadGlobalIC_TryPropertyCellCase(vector, slot, lazy_context, exit_point,
&try_handler, &miss); &try_handler, &miss);
BIND(&try_handler); BIND(&try_handler);
LoadGlobalIC_TryHandlerCase(vector, slot, smi_slot, context, name, LoadGlobalIC_TryHandlerCase(vector, slot, lazy_smi_slot, lazy_context,
typeof_mode, exit_point, &miss); lazy_name, typeof_mode, exit_point, &miss);
} }
BIND(&miss); BIND(&miss);
{ {
Comment("LoadGlobalIC_MissCase"); Comment("LoadGlobalIC_MissCase");
TNode<Context> context = lazy_context();
TNode<Name> name = lazy_name();
exit_point->ReturnCallRuntime(Runtime::kLoadGlobalIC_Miss, context, name, exit_point->ReturnCallRuntime(Runtime::kLoadGlobalIC_Miss, context, name,
smi_slot, maybe_feedback_vector, lazy_smi_slot(), maybe_feedback_vector,
SmiConstant(typeof_mode)); SmiConstant(typeof_mode));
} }
...@@ -2866,13 +2873,14 @@ void AccessorAssembler::LoadGlobalIC(TNode<HeapObject> maybe_feedback_vector, ...@@ -2866,13 +2873,14 @@ void AccessorAssembler::LoadGlobalIC(TNode<HeapObject> maybe_feedback_vector,
: FeedbackSlotKind::kLoadGlobalNotInsideTypeof); : FeedbackSlotKind::kLoadGlobalNotInsideTypeof);
exit_point->ReturnCallStub( exit_point->ReturnCallStub(
Builtins::CallableFor(isolate(), Builtins::kLoadGlobalIC_NoFeedback), Builtins::CallableFor(isolate(), Builtins::kLoadGlobalIC_NoFeedback),
context, name, SmiConstant(ic_kind)); lazy_context(), lazy_name(), SmiConstant(ic_kind));
} }
} }
void AccessorAssembler::LoadGlobalIC_TryPropertyCellCase( void AccessorAssembler::LoadGlobalIC_TryPropertyCellCase(
TNode<FeedbackVector> vector, TNode<UintPtrT> slot, TNode<Context> context, TNode<FeedbackVector> vector, TNode<UintPtrT> slot,
ExitPoint* exit_point, Label* try_handler, Label* miss) { const LazyNode<Context>& lazy_context, ExitPoint* exit_point,
Label* try_handler, Label* miss) {
Comment("LoadGlobalIC_TryPropertyCellCase"); Comment("LoadGlobalIC_TryPropertyCellCase");
Label if_lexical_var(this), if_property_cell(this); Label if_lexical_var(this), if_property_cell(this);
...@@ -2899,6 +2907,7 @@ void AccessorAssembler::LoadGlobalIC_TryPropertyCellCase( ...@@ -2899,6 +2907,7 @@ void AccessorAssembler::LoadGlobalIC_TryPropertyCellCase(
Signed(DecodeWord<FeedbackNexus::ContextIndexBits>(lexical_handler)); Signed(DecodeWord<FeedbackNexus::ContextIndexBits>(lexical_handler));
TNode<IntPtrT> slot_index = TNode<IntPtrT> slot_index =
Signed(DecodeWord<FeedbackNexus::SlotIndexBits>(lexical_handler)); Signed(DecodeWord<FeedbackNexus::SlotIndexBits>(lexical_handler));
TNode<Context> context = lazy_context();
TNode<Context> script_context = LoadScriptContext(context, context_index); TNode<Context> script_context = LoadScriptContext(context, context_index);
TNode<Object> result = LoadContextElement(script_context, slot_index); TNode<Object> result = LoadContextElement(script_context, slot_index);
exit_point->Return(result); exit_point->Return(result);
...@@ -2906,8 +2915,9 @@ void AccessorAssembler::LoadGlobalIC_TryPropertyCellCase( ...@@ -2906,8 +2915,9 @@ void AccessorAssembler::LoadGlobalIC_TryPropertyCellCase(
} }
void AccessorAssembler::LoadGlobalIC_TryHandlerCase( void AccessorAssembler::LoadGlobalIC_TryHandlerCase(
TNode<FeedbackVector> vector, TNode<UintPtrT> slot, TNode<Smi> smi_slot, TNode<FeedbackVector> vector, TNode<UintPtrT> slot,
TNode<Context> context, TNode<Name> name, TypeofMode typeof_mode, const LazyNode<Smi>& lazy_smi_slot, const LazyNode<Context>& lazy_context,
const LazyNode<Name>& lazy_name, TypeofMode typeof_mode,
ExitPoint* exit_point, Label* miss) { ExitPoint* exit_point, Label* miss) {
Comment("LoadGlobalIC_TryHandlerCase"); Comment("LoadGlobalIC_TryHandlerCase");
...@@ -2922,13 +2932,15 @@ void AccessorAssembler::LoadGlobalIC_TryHandlerCase( ...@@ -2922,13 +2932,15 @@ void AccessorAssembler::LoadGlobalIC_TryHandlerCase(
? OnNonExistent::kThrowReferenceError ? OnNonExistent::kThrowReferenceError
: OnNonExistent::kReturnUndefined; : OnNonExistent::kReturnUndefined;
TNode<Context> context = lazy_context();
TNode<NativeContext> native_context = LoadNativeContext(context); TNode<NativeContext> native_context = LoadNativeContext(context);
TNode<JSGlobalProxy> receiver = TNode<JSGlobalProxy> receiver =
CAST(LoadContextElement(native_context, Context::GLOBAL_PROXY_INDEX)); CAST(LoadContextElement(native_context, Context::GLOBAL_PROXY_INDEX));
TNode<Object> holder = TNode<Object> holder =
LoadContextElement(native_context, Context::EXTENSION_INDEX); LoadContextElement(native_context, Context::EXTENSION_INDEX);
LoadICParameters p(context, receiver, name, smi_slot, vector, holder); LazyLoadICParameters p([=] { return context; }, receiver, lazy_name,
lazy_smi_slot, vector, holder);
HandleLoadICHandlerCase(&p, handler, miss, exit_point, ICMode::kGlobalIC, HandleLoadICHandlerCase(&p, handler, miss, exit_point, ICMode::kGlobalIC,
on_nonexistent); on_nonexistent);
...@@ -3031,9 +3043,11 @@ void AccessorAssembler::KeyedLoadIC(const LoadICParameters* p, ...@@ -3031,9 +3043,11 @@ void AccessorAssembler::KeyedLoadIC(const LoadICParameters* p,
&if_handler, &var_handler, &try_polymorphic); &if_handler, &var_handler, &try_polymorphic);
BIND(&if_handler); BIND(&if_handler);
{ {
HandleLoadICHandlerCase( LazyLoadICParameters lazy_p(p);
p, CAST(var_handler.value()), &miss, &direct_exit, ICMode::kNonGlobalIC, HandleLoadICHandlerCase(&lazy_p, CAST(var_handler.value()), &miss,
OnNonExistent::kReturnUndefined, kSupportElements, access_mode); &direct_exit, ICMode::kNonGlobalIC,
OnNonExistent::kReturnUndefined, kSupportElements,
access_mode);
} }
BIND(&try_polymorphic); BIND(&try_polymorphic);
...@@ -3241,9 +3255,11 @@ void AccessorAssembler::KeyedLoadICPolymorphicName(const LoadICParameters* p, ...@@ -3241,9 +3255,11 @@ void AccessorAssembler::KeyedLoadICPolymorphicName(const LoadICParameters* p,
BIND(&if_handler); BIND(&if_handler);
{ {
ExitPoint direct_exit(this); ExitPoint direct_exit(this);
HandleLoadICHandlerCase( LazyLoadICParameters lazy_p(p);
p, CAST(var_handler.value()), &miss, &direct_exit, ICMode::kNonGlobalIC, HandleLoadICHandlerCase(&lazy_p, CAST(var_handler.value()), &miss,
OnNonExistent::kReturnUndefined, kOnlyProperties, access_mode); &direct_exit, ICMode::kNonGlobalIC,
OnNonExistent::kReturnUndefined, kOnlyProperties,
access_mode);
} }
BIND(&miss); BIND(&miss);
...@@ -3646,7 +3662,8 @@ void AccessorAssembler::GenerateLoadIC_Megamorphic() { ...@@ -3646,7 +3662,8 @@ void AccessorAssembler::GenerateLoadIC_Megamorphic() {
&if_handler, &var_handler, &miss); &if_handler, &var_handler, &miss);
BIND(&if_handler); BIND(&if_handler);
LoadICParameters p(context, receiver, name, slot, vector); LazyLoadICParameters p([=] { return context; }, receiver,
[=] { return name; }, [=] { return slot; }, vector);
HandleLoadICHandlerCase(&p, CAST(var_handler.value()), &miss, &direct_exit); HandleLoadICHandlerCase(&p, CAST(var_handler.value()), &miss, &direct_exit);
BIND(&miss); BIND(&miss);
...@@ -3677,7 +3694,9 @@ void AccessorAssembler::GenerateLoadIC_Noninlined() { ...@@ -3677,7 +3694,9 @@ void AccessorAssembler::GenerateLoadIC_Noninlined() {
BIND(&if_handler); BIND(&if_handler);
{ {
HandleLoadICHandlerCase(&p, CAST(var_handler.value()), &miss, &direct_exit); LazyLoadICParameters lazy_p(&p);
HandleLoadICHandlerCase(&lazy_p, CAST(var_handler.value()), &miss,
&direct_exit);
} }
BIND(&miss); BIND(&miss);
...@@ -3744,8 +3763,16 @@ void AccessorAssembler::GenerateLoadGlobalIC(TypeofMode typeof_mode) { ...@@ -3744,8 +3763,16 @@ void AccessorAssembler::GenerateLoadGlobalIC(TypeofMode typeof_mode) {
TNode<Context> context = CAST(Parameter(Descriptor::kContext)); TNode<Context> context = CAST(Parameter(Descriptor::kContext));
ExitPoint direct_exit(this); ExitPoint direct_exit(this);
LoadGlobalIC(vector, slot, Unsigned(SmiUntag(slot)), context, name, LoadGlobalIC(
typeof_mode, &direct_exit); vector,
// lazy_smi_slot
[=] { return slot; },
// lazy_slot
[=] { return Unsigned(SmiUntag(slot)); },
// lazy_context
[=] { return context; },
// lazy_name
[=] { return name; }, typeof_mode, &direct_exit);
} }
void AccessorAssembler::GenerateLoadGlobalICTrampoline(TypeofMode typeof_mode) { void AccessorAssembler::GenerateLoadGlobalICTrampoline(TypeofMode typeof_mode) {
......
...@@ -105,14 +105,54 @@ class V8_EXPORT_PRIVATE AccessorAssembler : public CodeStubAssembler { ...@@ -105,14 +105,54 @@ class V8_EXPORT_PRIVATE AccessorAssembler : public CodeStubAssembler {
base::Optional<TNode<Object>> holder_; base::Optional<TNode<Object>> holder_;
}; };
struct LazyLoadICParameters {
LazyLoadICParameters(LazyNode<Context> context, TNode<Object> receiver,
LazyNode<Object> name, LazyNode<Smi> slot,
TNode<HeapObject> vector,
base::Optional<TNode<Object>> holder = base::nullopt)
: context_(context),
receiver_(receiver),
name_(name),
slot_(slot),
vector_(vector),
holder_(holder ? holder.value() : receiver) {}
explicit LazyLoadICParameters(const LoadICParameters* p)
: receiver_(p->receiver()),
vector_(p->vector()),
holder_(p->holder()) {
slot_ = [=] { return p->slot(); };
context_ = [=] { return p->context(); };
name_ = [=] { return p->name(); };
}
TNode<Context> context() const { return context_(); }
TNode<Object> receiver() const { return receiver_; }
TNode<Object> name() const { return name_(); }
TNode<Smi> slot() const { return slot_(); }
TNode<HeapObject> vector() const { return vector_; }
TNode<Object> holder() const { return holder_; }
private:
LazyNode<Context> context_;
TNode<Object> receiver_;
LazyNode<Object> name_;
LazyNode<Smi> slot_;
TNode<HeapObject> vector_;
TNode<Object> holder_;
};
void LoadGlobalIC(TNode<HeapObject> maybe_feedback_vector, void LoadGlobalIC(TNode<HeapObject> maybe_feedback_vector,
TNode<Smi> smi_slot, TNode<UintPtrT> slot, const LazyNode<Smi>& lazy_smi_slot,
TNode<Context> context, TNode<Name> name, const LazyNode<UintPtrT>& lazy_slot,
TypeofMode typeof_mode, ExitPoint* exit_point); const LazyNode<Context>& lazy_context,
const LazyNode<Name>& lazy_name, TypeofMode typeof_mode,
ExitPoint* exit_point);
// Specialized LoadIC for inlined bytecode handler, hand-tuned to omit frame // Specialized LoadIC for inlined bytecode handler, hand-tuned to omit frame
// construction on common paths. // construction on common paths.
void LoadIC_BytecodeHandler(const LoadICParameters* p, ExitPoint* exit_point); void LoadIC_BytecodeHandler(const LazyLoadICParameters* p,
ExitPoint* exit_point);
// Loads dataX field from the DataHandler object. // Loads dataX field from the DataHandler object.
TNode<MaybeObject> LoadHandlerDataField(TNode<DataHandler> handler, TNode<MaybeObject> LoadHandlerDataField(TNode<DataHandler> handler,
...@@ -213,13 +253,13 @@ class V8_EXPORT_PRIVATE AccessorAssembler : public CodeStubAssembler { ...@@ -213,13 +253,13 @@ class V8_EXPORT_PRIVATE AccessorAssembler : public CodeStubAssembler {
// LoadIC implementation. // LoadIC implementation.
void HandleLoadICHandlerCase( void HandleLoadICHandlerCase(
const LoadICParameters* p, TNode<Object> handler, Label* miss, const LazyLoadICParameters* p, TNode<Object> handler, Label* miss,
ExitPoint* exit_point, ICMode ic_mode = ICMode::kNonGlobalIC, ExitPoint* exit_point, ICMode ic_mode = ICMode::kNonGlobalIC,
OnNonExistent on_nonexistent = OnNonExistent::kReturnUndefined, OnNonExistent on_nonexistent = OnNonExistent::kReturnUndefined,
ElementSupport support_elements = kOnlyProperties, ElementSupport support_elements = kOnlyProperties,
LoadAccessMode access_mode = LoadAccessMode::kLoad); LoadAccessMode access_mode = LoadAccessMode::kLoad);
void HandleLoadICSmiHandlerCase(const LoadICParameters* p, void HandleLoadICSmiHandlerCase(const LazyLoadICParameters* p,
TNode<Object> holder, TNode<Smi> smi_handler, TNode<Object> holder, TNode<Smi> smi_handler,
TNode<Object> handler, Label* miss, TNode<Object> handler, Label* miss,
ExitPoint* exit_point, ICMode ic_mode, ExitPoint* exit_point, ICMode ic_mode,
...@@ -227,7 +267,7 @@ class V8_EXPORT_PRIVATE AccessorAssembler : public CodeStubAssembler { ...@@ -227,7 +267,7 @@ class V8_EXPORT_PRIVATE AccessorAssembler : public CodeStubAssembler {
ElementSupport support_elements, ElementSupport support_elements,
LoadAccessMode access_mode); LoadAccessMode access_mode);
void HandleLoadICProtoHandler(const LoadICParameters* p, void HandleLoadICProtoHandler(const LazyLoadICParameters* p,
TNode<DataHandler> handler, TNode<DataHandler> handler,
TVariable<Object>* var_holder, TVariable<Object>* var_holder,
TVariable<Object>* var_smi_handler, TVariable<Object>* var_smi_handler,
...@@ -235,12 +275,12 @@ class V8_EXPORT_PRIVATE AccessorAssembler : public CodeStubAssembler { ...@@ -235,12 +275,12 @@ class V8_EXPORT_PRIVATE AccessorAssembler : public CodeStubAssembler {
ExitPoint* exit_point, ICMode ic_mode, ExitPoint* exit_point, ICMode ic_mode,
LoadAccessMode access_mode); LoadAccessMode access_mode);
void HandleLoadCallbackProperty(const LoadICParameters* p, void HandleLoadCallbackProperty(const LazyLoadICParameters* p,
TNode<JSObject> holder, TNode<JSObject> holder,
TNode<WordT> handler_word, TNode<WordT> handler_word,
ExitPoint* exit_point); ExitPoint* exit_point);
void HandleLoadAccessor(const LoadICParameters* p, void HandleLoadAccessor(const LazyLoadICParameters* p,
TNode<CallHandlerInfo> call_handler_info, TNode<CallHandlerInfo> call_handler_info,
TNode<WordT> handler_word, TNode<DataHandler> handler, TNode<WordT> handler_word, TNode<DataHandler> handler,
TNode<IntPtrT> handler_kind, ExitPoint* exit_point); TNode<IntPtrT> handler_kind, ExitPoint* exit_point);
...@@ -254,13 +294,13 @@ class V8_EXPORT_PRIVATE AccessorAssembler : public CodeStubAssembler { ...@@ -254,13 +294,13 @@ class V8_EXPORT_PRIVATE AccessorAssembler : public CodeStubAssembler {
Label* can_access, Label* miss); Label* can_access, Label* miss);
void HandleLoadICSmiHandlerLoadNamedCase( void HandleLoadICSmiHandlerLoadNamedCase(
const LoadICParameters* p, TNode<Object> holder, const LazyLoadICParameters* p, TNode<Object> holder,
TNode<IntPtrT> handler_kind, TNode<WordT> handler_word, TNode<IntPtrT> handler_kind, TNode<WordT> handler_word,
Label* rebox_double, TVariable<Float64T>* var_double_value, Label* rebox_double, TVariable<Float64T>* var_double_value,
TNode<Object> handler, Label* miss, ExitPoint* exit_point, ICMode ic_mode, TNode<Object> handler, Label* miss, ExitPoint* exit_point, ICMode ic_mode,
OnNonExistent on_nonexistent, ElementSupport support_elements); OnNonExistent on_nonexistent, ElementSupport support_elements);
void HandleLoadICSmiHandlerHasNamedCase(const LoadICParameters* p, void HandleLoadICSmiHandlerHasNamedCase(const LazyLoadICParameters* p,
TNode<Object> holder, TNode<Object> holder,
TNode<IntPtrT> handler_kind, TNode<IntPtrT> handler_kind,
Label* miss, ExitPoint* exit_point, Label* miss, ExitPoint* exit_point,
...@@ -270,13 +310,15 @@ class V8_EXPORT_PRIVATE AccessorAssembler : public CodeStubAssembler { ...@@ -270,13 +310,15 @@ class V8_EXPORT_PRIVATE AccessorAssembler : public CodeStubAssembler {
void LoadGlobalIC_TryPropertyCellCase(TNode<FeedbackVector> vector, void LoadGlobalIC_TryPropertyCellCase(TNode<FeedbackVector> vector,
TNode<UintPtrT> slot, TNode<UintPtrT> slot,
TNode<Context> context, const LazyNode<Context>& lazy_context,
ExitPoint* exit_point, ExitPoint* exit_point,
Label* try_handler, Label* miss); Label* try_handler, Label* miss);
void LoadGlobalIC_TryHandlerCase(TNode<FeedbackVector> vector, void LoadGlobalIC_TryHandlerCase(TNode<FeedbackVector> vector,
TNode<UintPtrT> slot, TNode<Smi> smi_slot, TNode<UintPtrT> slot,
TNode<Context> context, TNode<Name> name, const LazyNode<Smi>& lazy_smi_slot,
const LazyNode<Context>& lazy_context,
const LazyNode<Name>& lazy_name,
TypeofMode typeof_mode, TypeofMode typeof_mode,
ExitPoint* exit_point, Label* miss); ExitPoint* exit_point, Label* miss);
......
...@@ -167,15 +167,25 @@ class InterpreterLoadGlobalAssembler : public InterpreterAssembler { ...@@ -167,15 +167,25 @@ class InterpreterLoadGlobalAssembler : public InterpreterAssembler {
Dispatch(); Dispatch();
}); });
TNode<Smi> smi_slot = LazyNode<Smi> lazy_smi_slot = [=] {
SmiTag(Signed(BytecodeOperandIdx(slot_operand_index))); return SmiTag(Signed(BytecodeOperandIdx(slot_operand_index)));
TNode<UintPtrT> slot = BytecodeOperandIdx(slot_operand_index); };
TNode<Context> context = GetContext();
TNode<Name> name = LazyNode<UintPtrT> lazy_slot = [=] {
CAST(LoadConstantPoolEntryAtOperandIndex(name_operand_index)); return BytecodeOperandIdx(slot_operand_index);
};
LazyNode<Context> lazy_context = [=] { return GetContext(); };
accessor_asm.LoadGlobalIC(maybe_feedback_vector, smi_slot, slot, context, LazyNode<Name> lazy_name = [=] {
name, typeof_mode, &exit_point); TNode<Name> name =
CAST(LoadConstantPoolEntryAtOperandIndex(name_operand_index));
return name;
};
accessor_asm.LoadGlobalIC(maybe_feedback_vector, lazy_smi_slot, lazy_slot,
lazy_context, lazy_name, typeof_mode,
&exit_point);
} }
}; };
...@@ -509,16 +519,18 @@ IGNITION_HANDLER(LdaNamedProperty, InterpreterAssembler) { ...@@ -509,16 +519,18 @@ IGNITION_HANDLER(LdaNamedProperty, InterpreterAssembler) {
TNode<Object> recv = LoadRegisterAtOperandIndex(0); TNode<Object> recv = LoadRegisterAtOperandIndex(0);
// Load the name and context lazily. // Load the name and context lazily.
TNode<Smi> smi_slot = SmiTag(Signed(feedback_slot)); LazyNode<Smi> lazy_smi_slot = [=] { return SmiTag(Signed(feedback_slot)); };
TNode<Name> name = CAST(LoadConstantPoolEntryAtOperandIndex(1)); LazyNode<Name> lazy_name = [=] {
TNode<Context> context = GetContext(); return CAST(LoadConstantPoolEntryAtOperandIndex(1));
};
LazyNode<Context> lazy_context = [=] { return GetContext(); };
Label done(this); Label done(this);
TVARIABLE(Object, var_result); TVARIABLE(Object, var_result);
ExitPoint exit_point(this, &done, &var_result); ExitPoint exit_point(this, &done, &var_result);
AccessorAssembler::LoadICParameters params(context, recv, name, smi_slot, AccessorAssembler::LazyLoadICParameters params(
feedback_vector); lazy_context, recv, lazy_name, lazy_smi_slot, feedback_vector);
AccessorAssembler accessor_asm(state()); AccessorAssembler accessor_asm(state());
accessor_asm.LoadIC_BytecodeHandler(&params, &exit_point); accessor_asm.LoadIC_BytecodeHandler(&params, &exit_point);
......
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