| Index: src/arm64/full-codegen-arm64.cc
|
| diff --git a/src/arm64/full-codegen-arm64.cc b/src/arm64/full-codegen-arm64.cc
|
| index a1ed22a700364267c0d41add7b9c33380911668c..388e06aec3694e0eab6510c30f4a8d9a921e7c98 100644
|
| --- a/src/arm64/full-codegen-arm64.cc
|
| +++ b/src/arm64/full-codegen-arm64.cc
|
| @@ -506,10 +506,30 @@
|
| }
|
|
|
|
|
| +void FullCodeGenerator::EffectContext::Plug(Variable* var) const {
|
| + DCHECK(var->IsStackAllocated() || var->IsContextSlot());
|
| +}
|
| +
|
| +
|
| +void FullCodeGenerator::AccumulatorValueContext::Plug(Variable* var) const {
|
| + DCHECK(var->IsStackAllocated() || var->IsContextSlot());
|
| + codegen()->GetVar(result_register(), var);
|
| +}
|
| +
|
| +
|
| void FullCodeGenerator::StackValueContext::Plug(Variable* var) const {
|
| DCHECK(var->IsStackAllocated() || var->IsContextSlot());
|
| codegen()->GetVar(result_register(), var);
|
| __ Push(result_register());
|
| +}
|
| +
|
| +
|
| +void FullCodeGenerator::TestContext::Plug(Variable* var) const {
|
| + DCHECK(var->IsStackAllocated() || var->IsContextSlot());
|
| + // For simplicity we always test the accumulator register.
|
| + codegen()->GetVar(result_register(), var);
|
| + codegen()->PrepareForBailoutBeforeSplit(condition(), false, NULL, NULL);
|
| + codegen()->DoTest(this);
|
| }
|
|
|
|
|
| @@ -667,6 +687,10 @@
|
| Label* materialize_false) const {
|
| DCHECK(materialize_true == true_label_);
|
| DCHECK(materialize_false == false_label_);
|
| +}
|
| +
|
| +
|
| +void FullCodeGenerator::EffectContext::Plug(bool flag) const {
|
| }
|
|
|
|
|
| @@ -940,6 +964,35 @@
|
| break;
|
| }
|
| }
|
| +}
|
| +
|
| +
|
| +void FullCodeGenerator::VisitImportDeclaration(ImportDeclaration* declaration) {
|
| + VariableProxy* proxy = declaration->proxy();
|
| + Variable* variable = proxy->var();
|
| + switch (variable->location()) {
|
| + case VariableLocation::GLOBAL:
|
| + case VariableLocation::UNALLOCATED:
|
| + // TODO(rossberg)
|
| + break;
|
| +
|
| + case VariableLocation::CONTEXT: {
|
| + Comment cmnt(masm_, "[ ImportDeclaration");
|
| + EmitDebugCheckDeclarationContext(variable);
|
| + // TODO(rossberg)
|
| + break;
|
| + }
|
| +
|
| + case VariableLocation::PARAMETER:
|
| + case VariableLocation::LOCAL:
|
| + case VariableLocation::LOOKUP:
|
| + UNREACHABLE();
|
| + }
|
| +}
|
| +
|
| +
|
| +void FullCodeGenerator::VisitExportDeclaration(ExportDeclaration* declaration) {
|
| + // TODO(rossberg)
|
| }
|
|
|
|
|
| @@ -1262,6 +1315,12 @@
|
| __ CallRuntime(Runtime::kNewClosure, 3);
|
| }
|
| context()->Plug(x0);
|
| +}
|
| +
|
| +
|
| +void FullCodeGenerator::VisitVariableProxy(VariableProxy* expr) {
|
| + Comment cmnt(masm_, "[ VariableProxy");
|
| + EmitVariableLoad(expr);
|
| }
|
|
|
|
|
| @@ -3557,6 +3616,33 @@
|
| }
|
|
|
|
|
| +void FullCodeGenerator::EmitSubString(CallRuntime* expr) {
|
| + // Load the arguments on the stack and call the stub.
|
| + SubStringStub stub(isolate());
|
| + ZoneList<Expression*>* args = expr->arguments();
|
| + DCHECK(args->length() == 3);
|
| + VisitForStackValue(args->at(0));
|
| + VisitForStackValue(args->at(1));
|
| + VisitForStackValue(args->at(2));
|
| + __ CallStub(&stub);
|
| + context()->Plug(x0);
|
| +}
|
| +
|
| +
|
| +void FullCodeGenerator::EmitRegExpExec(CallRuntime* expr) {
|
| + // Load the arguments on the stack and call the stub.
|
| + RegExpExecStub stub(isolate());
|
| + ZoneList<Expression*>* args = expr->arguments();
|
| + DCHECK(args->length() == 4);
|
| + VisitForStackValue(args->at(0));
|
| + VisitForStackValue(args->at(1));
|
| + VisitForStackValue(args->at(2));
|
| + VisitForStackValue(args->at(3));
|
| + __ CallStub(&stub);
|
| + context()->Plug(x0);
|
| +}
|
| +
|
| +
|
| void FullCodeGenerator::EmitValueOf(CallRuntime* expr) {
|
| ASM_LOCATION("FullCodeGenerator::EmitValueOf");
|
| ZoneList<Expression*>* args = expr->arguments();
|
| @@ -3696,6 +3782,18 @@
|
| }
|
|
|
|
|
| +void FullCodeGenerator::EmitMathPow(CallRuntime* expr) {
|
| + // Load the arguments on the stack and call the MathPow stub.
|
| + ZoneList<Expression*>* args = expr->arguments();
|
| + DCHECK(args->length() == 2);
|
| + VisitForStackValue(args->at(0));
|
| + VisitForStackValue(args->at(1));
|
| + MathPowStub stub(isolate(), MathPowStub::ON_STACK);
|
| + __ CallStub(&stub);
|
| + context()->Plug(x0);
|
| +}
|
| +
|
| +
|
| void FullCodeGenerator::EmitSetValueOf(CallRuntime* expr) {
|
| ZoneList<Expression*>* args = expr->arguments();
|
| DCHECK(args->length() == 2);
|
| @@ -3721,6 +3819,19 @@
|
| x1, JSValue::kValueOffset, x10, x11, kLRHasBeenSaved, kDontSaveFPRegs);
|
|
|
| __ Bind(&done);
|
| + context()->Plug(x0);
|
| +}
|
| +
|
| +
|
| +void FullCodeGenerator::EmitNumberToString(CallRuntime* expr) {
|
| + ZoneList<Expression*>* args = expr->arguments();
|
| + DCHECK_EQ(args->length(), 1);
|
| +
|
| + // Load the argument into x0 and call the stub.
|
| + VisitForAccumulatorValue(args->at(0));
|
| +
|
| + NumberToStringStub stub(isolate());
|
| + __ CallStub(&stub);
|
| context()->Plug(x0);
|
| }
|
|
|
| @@ -3850,6 +3961,18 @@
|
| StringAddStub stub(isolate(), STRING_ADD_CHECK_BOTH, NOT_TENURED);
|
| __ CallStub(&stub);
|
|
|
| + context()->Plug(x0);
|
| +}
|
| +
|
| +
|
| +void FullCodeGenerator::EmitStringCompare(CallRuntime* expr) {
|
| + ZoneList<Expression*>* args = expr->arguments();
|
| + DCHECK_EQ(2, args->length());
|
| + VisitForStackValue(args->at(0));
|
| + VisitForStackValue(args->at(1));
|
| +
|
| + StringCompareStub stub(isolate());
|
| + __ CallStub(&stub);
|
| context()->Plug(x0);
|
| }
|
|
|
|
|