Commit 422e0c4a authored by mstarzinger's avatar mstarzinger Committed by Commit bot

[turbofan] Cleanup Parameter creation in AstGraphBuilder.

R=bmeurer@chromium.org

Review URL: https://codereview.chromium.org/1222833002

Cr-Commit-Position: refs/heads/master@{#29488}
parent a8a4c364
...@@ -525,20 +525,16 @@ bool AstGraphBuilder::CreateGraph(bool constant_context, bool stack_check) { ...@@ -525,20 +525,16 @@ bool AstGraphBuilder::CreateGraph(bool constant_context, bool stack_check) {
// Build receiver check for sloppy mode if necessary. // Build receiver check for sloppy mode if necessary.
// TODO(mstarzinger/verwaest): Should this be moved back into the CallIC? // TODO(mstarzinger/verwaest): Should this be moved back into the CallIC?
Node* patched_receiver = nullptr;
if (scope->has_this_declaration()) { if (scope->has_this_declaration()) {
Node* original_receiver = NewNode(common()->Parameter(0), graph()->start()); Node* original_receiver = env.RawParameterLookup(0);
patched_receiver = BuildPatchReceiverToGlobalProxy(original_receiver); Node* patched_receiver = BuildPatchReceiverToGlobalProxy(original_receiver);
if (scope->receiver()->IsStackAllocated()) { env.RawParameterBind(0, patched_receiver);
env.Bind(scope->receiver(), patched_receiver);
}
} }
// Build function context only if there are context allocated variables. // Build function context only if there are context allocated variables.
if (info()->num_heap_slots() > 0) { if (info()->num_heap_slots() > 0) {
// Push a new inner context scope for the function. // Push a new inner context scope for the function.
Node* inner_context = Node* inner_context = BuildLocalFunctionContext(function_context_.get());
BuildLocalFunctionContext(function_context_.get(), patched_receiver);
ContextScope top_context(this, scope, inner_context); ContextScope top_context(this, scope, inner_context);
CreateGraphBody(stack_check); CreateGraphBody(stack_check);
} else { } else {
...@@ -685,8 +681,8 @@ AstGraphBuilder::Environment::Environment(AstGraphBuilder* builder, ...@@ -685,8 +681,8 @@ AstGraphBuilder::Environment::Environment(AstGraphBuilder* builder,
// Bind the receiver variable. // Bind the receiver variable.
int param_num = 0; int param_num = 0;
if (builder->info()->is_this_defined()) { if (builder->info()->is_this_defined()) {
Node* receiver = builder->graph()->NewNode( const Operator* op = common()->Parameter(param_num++, "%this");
common()->Parameter(param_num++, "%this"), builder->graph()->start()); Node* receiver = builder->graph()->NewNode(op, builder->graph()->start());
values()->push_back(receiver); values()->push_back(receiver);
} else { } else {
values()->push_back(builder->jsgraph()->UndefinedConstant()); values()->push_back(builder->jsgraph()->UndefinedConstant());
...@@ -696,9 +692,8 @@ AstGraphBuilder::Environment::Environment(AstGraphBuilder* builder, ...@@ -696,9 +692,8 @@ AstGraphBuilder::Environment::Environment(AstGraphBuilder* builder,
// (receiver is parameter index -1 but environment index 0). // (receiver is parameter index -1 but environment index 0).
for (int i = 0; i < scope->num_parameters(); ++i) { for (int i = 0; i < scope->num_parameters(); ++i) {
const char* debug_name = GetDebugParameterName(graph()->zone(), scope, i); const char* debug_name = GetDebugParameterName(graph()->zone(), scope, i);
Node* parameter = const Operator* op = common()->Parameter(param_num++, debug_name);
builder->graph()->NewNode(common()->Parameter(param_num++, debug_name), Node* parameter = builder->graph()->NewNode(op, builder->graph()->start());
builder->graph()->start());
values()->push_back(parameter); values()->push_back(parameter);
} }
...@@ -739,7 +734,6 @@ void AstGraphBuilder::Environment::Bind(Variable* variable, Node* node) { ...@@ -739,7 +734,6 @@ void AstGraphBuilder::Environment::Bind(Variable* variable, Node* node) {
} else { } else {
DCHECK(variable->IsStackLocal()); DCHECK(variable->IsStackLocal());
values()->at(variable->index() + parameters_count_) = node; values()->at(variable->index() + parameters_count_) = node;
DCHECK(IsLivenessBlockConsistent()); DCHECK(IsLivenessBlockConsistent());
if (liveness_block() != nullptr) { if (liveness_block() != nullptr) {
liveness_block()->Bind(variable->index()); liveness_block()->Bind(variable->index());
...@@ -775,6 +769,18 @@ void AstGraphBuilder::Environment::MarkAllLocalsLive() { ...@@ -775,6 +769,18 @@ void AstGraphBuilder::Environment::MarkAllLocalsLive() {
} }
void AstGraphBuilder::Environment::RawParameterBind(int index, Node* node) {
DCHECK_LT(index, parameters_count());
values()->at(index) = node;
}
Node* AstGraphBuilder::Environment::RawParameterLookup(int index) {
DCHECK_LT(index, parameters_count());
return values()->at(index);
}
AstGraphBuilder::Environment* AstGraphBuilder::Environment*
AstGraphBuilder::Environment::CopyForConditional() { AstGraphBuilder::Environment::CopyForConditional() {
LivenessAnalyzerBlock* copy_liveness_block = nullptr; LivenessAnalyzerBlock* copy_liveness_block = nullptr;
...@@ -3069,8 +3075,7 @@ Node* AstGraphBuilder::BuildPatchReceiverToGlobalProxy(Node* receiver) { ...@@ -3069,8 +3075,7 @@ Node* AstGraphBuilder::BuildPatchReceiverToGlobalProxy(Node* receiver) {
} }
Node* AstGraphBuilder::BuildLocalFunctionContext(Node* context, Node* AstGraphBuilder::BuildLocalFunctionContext(Node* context) {
Node* patched_receiver) {
Scope* scope = info()->scope(); Scope* scope = info()->scope();
Node* closure = GetFunctionClosure(); Node* closure = GetFunctionClosure();
...@@ -3081,12 +3086,12 @@ Node* AstGraphBuilder::BuildLocalFunctionContext(Node* context, ...@@ -3081,12 +3086,12 @@ Node* AstGraphBuilder::BuildLocalFunctionContext(Node* context,
: NewNode(javascript()->CreateFunctionContext(), closure); : NewNode(javascript()->CreateFunctionContext(), closure);
if (scope->has_this_declaration() && scope->receiver()->IsContextSlot()) { if (scope->has_this_declaration() && scope->receiver()->IsContextSlot()) {
DCHECK_NOT_NULL(patched_receiver); Node* receiver = environment()->RawParameterLookup(0);
// Context variable (at bottom of the context chain). // Context variable (at bottom of the context chain).
Variable* variable = scope->receiver(); Variable* variable = scope->receiver();
DCHECK_EQ(0, scope->ContextChainLength(variable->scope())); DCHECK_EQ(0, scope->ContextChainLength(variable->scope()));
const Operator* op = javascript()->StoreContext(0, variable->index()); const Operator* op = javascript()->StoreContext(0, variable->index());
NewNode(op, local_context, patched_receiver); NewNode(op, local_context, receiver);
} }
// Copy parameters into context if necessary. // Copy parameters into context if necessary.
...@@ -3094,9 +3099,7 @@ Node* AstGraphBuilder::BuildLocalFunctionContext(Node* context, ...@@ -3094,9 +3099,7 @@ Node* AstGraphBuilder::BuildLocalFunctionContext(Node* context,
for (int i = 0; i < num_parameters; i++) { for (int i = 0; i < num_parameters; i++) {
Variable* variable = scope->parameter(i); Variable* variable = scope->parameter(i);
if (!variable->IsContextSlot()) continue; if (!variable->IsContextSlot()) continue;
// Temporary parameter node. The parameter indices are shifted by 1 Node* parameter = environment()->RawParameterLookup(i + 1);
// (receiver is parameter index -1 but environment index 0).
Node* parameter = NewNode(common()->Parameter(i + 1), graph()->start());
// Context variable (at bottom of the context chain). // Context variable (at bottom of the context chain).
DCHECK_EQ(0, scope->ContextChainLength(variable->scope())); DCHECK_EQ(0, scope->ContextChainLength(variable->scope()));
const Operator* op = javascript()->StoreContext(0, variable->index()); const Operator* op = javascript()->StoreContext(0, variable->index());
......
...@@ -257,7 +257,7 @@ class AstGraphBuilder : public AstVisitor { ...@@ -257,7 +257,7 @@ class AstGraphBuilder : public AstVisitor {
Node* BuildPatchReceiverToGlobalProxy(Node* receiver); Node* BuildPatchReceiverToGlobalProxy(Node* receiver);
// Builders to create local function, script and block contexts. // Builders to create local function, script and block contexts.
Node* BuildLocalFunctionContext(Node* context, Node* patched_receiver); Node* BuildLocalFunctionContext(Node* context);
Node* BuildLocalScriptContext(Scope* scope); Node* BuildLocalScriptContext(Scope* scope);
Node* BuildLocalBlockContext(Scope* scope); Node* BuildLocalBlockContext(Scope* scope);
...@@ -435,6 +435,10 @@ class AstGraphBuilder::Environment : public ZoneObject { ...@@ -435,6 +435,10 @@ class AstGraphBuilder::Environment : public ZoneObject {
Node* Lookup(Variable* variable); Node* Lookup(Variable* variable);
void MarkAllLocalsLive(); void MarkAllLocalsLive();
// Raw operations on parameter variables.
void RawParameterBind(int index, Node* node);
Node* RawParameterLookup(int index);
// Operations on the context chain. // Operations on the context chain.
Node* Context() const { return contexts_.back(); } Node* Context() const { return contexts_.back(); }
void PushContext(Node* context) { contexts()->push_back(context); } void PushContext(Node* context) { contexts()->push_back(context); }
......
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