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) { |