| Index: src/arm64/full-codegen-arm64.cc
|
| diff --git a/src/arm64/full-codegen-arm64.cc b/src/arm64/full-codegen-arm64.cc
|
| index f027dc68a4c224dd14c0c6fa2f31470f26d2c900..27a30e89e2aaeb498d31786ef791cc54dd050565 100644
|
| --- a/src/arm64/full-codegen-arm64.cc
|
| +++ b/src/arm64/full-codegen-arm64.cc
|
| @@ -859,7 +859,7 @@ void FullCodeGenerator::VisitVariableDeclaration(
|
| // Pushing 0 (xzr) indicates no initial value.
|
| __ Push(cp, x2, x1, xzr);
|
| }
|
| - __ CallRuntime(Runtime::kDeclareContextSlot, 4);
|
| + __ CallRuntime(Runtime::kDeclareLookupSlot, 4);
|
| break;
|
| }
|
| }
|
| @@ -915,7 +915,7 @@ void FullCodeGenerator::VisitFunctionDeclaration(
|
| __ Push(cp, x2, x1);
|
| // Push initial value for function declaration.
|
| VisitForStackValue(declaration->fun());
|
| - __ CallRuntime(Runtime::kDeclareContextSlot, 4);
|
| + __ CallRuntime(Runtime::kDeclareLookupSlot, 4);
|
| break;
|
| }
|
| }
|
| @@ -2140,19 +2140,6 @@ void FullCodeGenerator::EmitStoreToStackLocalOrContextSlot(
|
| }
|
|
|
|
|
| -void FullCodeGenerator::EmitCallStoreContextSlot(
|
| - Handle<String> name, StrictMode strict_mode) {
|
| - __ Mov(x11, Operand(name));
|
| - __ Mov(x10, Smi::FromInt(strict_mode));
|
| - // jssp[0] : mode.
|
| - // jssp[8] : name.
|
| - // jssp[16] : context.
|
| - // jssp[24] : value.
|
| - __ Push(x0, cp, x11, x10);
|
| - __ CallRuntime(Runtime::kStoreContextSlot, 4);
|
| -}
|
| -
|
| -
|
| void FullCodeGenerator::EmitVariableAssignment(Variable* var,
|
| Token::Value op) {
|
| ASM_LOCATION("FullCodeGenerator::EmitVariableAssignment");
|
| @@ -2168,7 +2155,7 @@ void FullCodeGenerator::EmitVariableAssignment(Variable* var,
|
| if (var->IsLookupSlot()) {
|
| __ Mov(x1, Operand(var->name()));
|
| __ Push(x0, cp, x1);
|
| - __ CallRuntime(Runtime::kInitializeConstContextSlot, 3);
|
| + __ CallRuntime(Runtime::kInitializeLegacyConstLookupSlot, 3);
|
| } else {
|
| ASSERT(var->IsStackLocal() || var->IsContextSlot());
|
| Label skip;
|
| @@ -2181,28 +2168,35 @@ void FullCodeGenerator::EmitVariableAssignment(Variable* var,
|
|
|
| } else if (var->mode() == LET && op != Token::INIT_LET) {
|
| // Non-initializing assignment to let variable needs a write barrier.
|
| - if (var->IsLookupSlot()) {
|
| - EmitCallStoreContextSlot(var->name(), strict_mode());
|
| - } else {
|
| - ASSERT(var->IsStackAllocated() || var->IsContextSlot());
|
| - Label assign;
|
| - MemOperand location = VarOperand(var, x1);
|
| - __ Ldr(x10, location);
|
| - __ JumpIfNotRoot(x10, Heap::kTheHoleValueRootIndex, &assign);
|
| - __ Mov(x10, Operand(var->name()));
|
| - __ Push(x10);
|
| - __ CallRuntime(Runtime::kThrowReferenceError, 1);
|
| - // Perform the assignment.
|
| - __ Bind(&assign);
|
| - EmitStoreToStackLocalOrContextSlot(var, location);
|
| - }
|
| + ASSERT(!var->IsLookupSlot());
|
| + ASSERT(var->IsStackAllocated() || var->IsContextSlot());
|
| + Label assign;
|
| + MemOperand location = VarOperand(var, x1);
|
| + __ Ldr(x10, location);
|
| + __ JumpIfNotRoot(x10, Heap::kTheHoleValueRootIndex, &assign);
|
| + __ Mov(x10, Operand(var->name()));
|
| + __ Push(x10);
|
| + __ CallRuntime(Runtime::kThrowReferenceError, 1);
|
| + // Perform the assignment.
|
| + __ Bind(&assign);
|
| + EmitStoreToStackLocalOrContextSlot(var, location);
|
|
|
| } else if (!var->is_const_mode() || op == Token::INIT_CONST) {
|
| - // Assignment to var or initializing assignment to let/const
|
| - // in harmony mode.
|
| if (var->IsLookupSlot()) {
|
| - EmitCallStoreContextSlot(var->name(), strict_mode());
|
| + ASSERT(op == Token::ASSIGN || op == Token::INIT_VAR ||
|
| + op == Token::ASSIGN_ADD);
|
| + // Assignment to var.
|
| + __ Mov(x11, Operand(var->name()));
|
| + __ Mov(x10, Smi::FromInt(strict_mode()));
|
| + // jssp[0] : mode.
|
| + // jssp[8] : name.
|
| + // jssp[16] : context.
|
| + // jssp[24] : value.
|
| + __ Push(x0, cp, x11, x10);
|
| + __ CallRuntime(Runtime::kStoreLookupSlot, 4);
|
| } else {
|
| + // Assignment to var or initializing assignment to let/const in harmony
|
| + // mode.
|
| ASSERT(var->IsStackAllocated() || var->IsContextSlot());
|
| MemOperand location = VarOperand(var, x1);
|
| if (FLAG_debug_code && op == Token::INIT_LET) {
|
|
|