| Index: src/full-codegen/s390/full-codegen-s390.cc
|
| diff --git a/src/full-codegen/s390/full-codegen-s390.cc b/src/full-codegen/s390/full-codegen-s390.cc
|
| index 04155ba42d6b9e8c204a2f37c7b12d428254632f..2a96d293a7932af229a635b147d915adf026aa60 100644
|
| --- a/src/full-codegen/s390/full-codegen-s390.cc
|
| +++ b/src/full-codegen/s390/full-codegen-s390.cc
|
| @@ -1348,34 +1348,6 @@ void FullCodeGenerator::VisitAssignment(Assignment* expr) {
|
| VisitForStackValue(property->obj());
|
| }
|
| break;
|
| - case NAMED_SUPER_PROPERTY:
|
| - VisitForStackValue(
|
| - property->obj()->AsSuperPropertyReference()->this_var());
|
| - VisitForAccumulatorValue(
|
| - property->obj()->AsSuperPropertyReference()->home_object());
|
| - PushOperand(result_register());
|
| - if (expr->is_compound()) {
|
| - const Register scratch = r3;
|
| - __ LoadP(scratch, MemOperand(sp, kPointerSize));
|
| - PushOperands(scratch, result_register());
|
| - }
|
| - break;
|
| - case KEYED_SUPER_PROPERTY: {
|
| - VisitForStackValue(
|
| - property->obj()->AsSuperPropertyReference()->this_var());
|
| - VisitForStackValue(
|
| - property->obj()->AsSuperPropertyReference()->home_object());
|
| - VisitForAccumulatorValue(property->key());
|
| - PushOperand(result_register());
|
| - if (expr->is_compound()) {
|
| - const Register scratch1 = r4;
|
| - const Register scratch2 = r3;
|
| - __ LoadP(scratch1, MemOperand(sp, 2 * kPointerSize));
|
| - __ LoadP(scratch2, MemOperand(sp, 1 * kPointerSize));
|
| - PushOperands(scratch1, scratch2, result_register());
|
| - }
|
| - break;
|
| - }
|
| case KEYED_PROPERTY:
|
| if (expr->is_compound()) {
|
| VisitForStackValue(property->obj());
|
| @@ -1388,6 +1360,10 @@ void FullCodeGenerator::VisitAssignment(Assignment* expr) {
|
| VisitForStackValue(property->key());
|
| }
|
| break;
|
| + case NAMED_SUPER_PROPERTY:
|
| + case KEYED_SUPER_PROPERTY:
|
| + UNREACHABLE();
|
| + break;
|
| }
|
|
|
| // For compound assignments we need another deoptimization point after the
|
| @@ -1405,21 +1381,15 @@ void FullCodeGenerator::VisitAssignment(Assignment* expr) {
|
| PrepareForBailoutForId(property->LoadId(),
|
| BailoutState::TOS_REGISTER);
|
| break;
|
| - case NAMED_SUPER_PROPERTY:
|
| - EmitNamedSuperPropertyLoad(property);
|
| - PrepareForBailoutForId(property->LoadId(),
|
| - BailoutState::TOS_REGISTER);
|
| - break;
|
| - case KEYED_SUPER_PROPERTY:
|
| - EmitKeyedSuperPropertyLoad(property);
|
| - PrepareForBailoutForId(property->LoadId(),
|
| - BailoutState::TOS_REGISTER);
|
| - break;
|
| case KEYED_PROPERTY:
|
| EmitKeyedPropertyLoad(property);
|
| PrepareForBailoutForId(property->LoadId(),
|
| BailoutState::TOS_REGISTER);
|
| break;
|
| + case NAMED_SUPER_PROPERTY:
|
| + case KEYED_SUPER_PROPERTY:
|
| + UNREACHABLE();
|
| + break;
|
| }
|
| }
|
|
|
| @@ -1456,17 +1426,13 @@ void FullCodeGenerator::VisitAssignment(Assignment* expr) {
|
| case NAMED_PROPERTY:
|
| EmitNamedPropertyAssignment(expr);
|
| break;
|
| - case NAMED_SUPER_PROPERTY:
|
| - EmitNamedSuperPropertyStore(property);
|
| - context()->Plug(r2);
|
| - break;
|
| - case KEYED_SUPER_PROPERTY:
|
| - EmitKeyedSuperPropertyStore(property);
|
| - context()->Plug(r2);
|
| - break;
|
| case KEYED_PROPERTY:
|
| EmitKeyedPropertyAssignment(expr);
|
| break;
|
| + case NAMED_SUPER_PROPERTY:
|
| + case KEYED_SUPER_PROPERTY:
|
| + UNREACHABLE();
|
| + break;
|
| }
|
| }
|
|
|
| @@ -1690,43 +1656,6 @@ void FullCodeGenerator::EmitAssignment(Expression* expr,
|
| CallStoreIC(slot, prop->key()->AsLiteral()->value());
|
| break;
|
| }
|
| - case NAMED_SUPER_PROPERTY: {
|
| - PushOperand(r2);
|
| - VisitForStackValue(prop->obj()->AsSuperPropertyReference()->this_var());
|
| - VisitForAccumulatorValue(
|
| - prop->obj()->AsSuperPropertyReference()->home_object());
|
| - // stack: value, this; r2: home_object
|
| - Register scratch = r4;
|
| - Register scratch2 = r5;
|
| - __ LoadRR(scratch, result_register()); // home_object
|
| - __ LoadP(r2, MemOperand(sp, kPointerSize)); // value
|
| - __ LoadP(scratch2, MemOperand(sp, 0)); // this
|
| - __ StoreP(scratch2, MemOperand(sp, kPointerSize)); // this
|
| - __ StoreP(scratch, MemOperand(sp, 0)); // home_object
|
| - // stack: this, home_object; r2: value
|
| - EmitNamedSuperPropertyStore(prop);
|
| - break;
|
| - }
|
| - case KEYED_SUPER_PROPERTY: {
|
| - PushOperand(r2);
|
| - VisitForStackValue(prop->obj()->AsSuperPropertyReference()->this_var());
|
| - VisitForStackValue(
|
| - prop->obj()->AsSuperPropertyReference()->home_object());
|
| - VisitForAccumulatorValue(prop->key());
|
| - Register scratch = r4;
|
| - Register scratch2 = r5;
|
| - __ LoadP(scratch2, MemOperand(sp, 2 * kPointerSize)); // value
|
| - // stack: value, this, home_object; r3: key, r6: value
|
| - __ LoadP(scratch, MemOperand(sp, kPointerSize)); // this
|
| - __ StoreP(scratch, MemOperand(sp, 2 * kPointerSize));
|
| - __ LoadP(scratch, MemOperand(sp, 0)); // home_object
|
| - __ StoreP(scratch, MemOperand(sp, kPointerSize));
|
| - __ StoreP(r2, MemOperand(sp, 0));
|
| - __ Move(r2, scratch2);
|
| - // stack: this, home_object, key; r2: value.
|
| - EmitKeyedSuperPropertyStore(prop);
|
| - break;
|
| - }
|
| case KEYED_PROPERTY: {
|
| PushOperand(r2); // Preserve value.
|
| VisitForStackValue(prop->obj());
|
| @@ -1737,6 +1666,10 @@ void FullCodeGenerator::EmitAssignment(Expression* expr,
|
| CallKeyedStoreIC(slot);
|
| break;
|
| }
|
| + case NAMED_SUPER_PROPERTY:
|
| + case KEYED_SUPER_PROPERTY:
|
| + UNREACHABLE();
|
| + break;
|
| }
|
| context()->Plug(r2);
|
| }
|
| @@ -1825,33 +1758,6 @@ void FullCodeGenerator::EmitNamedPropertyAssignment(Assignment* expr) {
|
| context()->Plug(r2);
|
| }
|
|
|
| -void FullCodeGenerator::EmitNamedSuperPropertyStore(Property* prop) {
|
| - // Assignment to named property of super.
|
| - // r2 : value
|
| - // stack : receiver ('this'), home_object
|
| - DCHECK(prop != NULL);
|
| - Literal* key = prop->key()->AsLiteral();
|
| - DCHECK(key != NULL);
|
| -
|
| - PushOperand(key->value());
|
| - PushOperand(r2);
|
| - CallRuntimeWithOperands((is_strict(language_mode())
|
| - ? Runtime::kStoreToSuper_Strict
|
| - : Runtime::kStoreToSuper_Sloppy));
|
| -}
|
| -
|
| -void FullCodeGenerator::EmitKeyedSuperPropertyStore(Property* prop) {
|
| - // Assignment to named property of super.
|
| - // r2 : value
|
| - // stack : receiver ('this'), home_object, key
|
| - DCHECK(prop != NULL);
|
| -
|
| - PushOperand(r2);
|
| - CallRuntimeWithOperands((is_strict(language_mode())
|
| - ? Runtime::kStoreKeyedToSuper_Strict
|
| - : Runtime::kStoreKeyedToSuper_Sloppy));
|
| -}
|
| -
|
| void FullCodeGenerator::EmitKeyedPropertyAssignment(Assignment* expr) {
|
| // Assignment to a property, using a keyed store IC.
|
| PopOperands(StoreDescriptor::ReceiverRegister(),
|
| @@ -1899,42 +1805,6 @@ void FullCodeGenerator::EmitCallWithLoadIC(Call* expr) {
|
| EmitCall(expr, convert_mode);
|
| }
|
|
|
| -void FullCodeGenerator::EmitSuperCallWithLoadIC(Call* expr) {
|
| - Expression* callee = expr->expression();
|
| - DCHECK(callee->IsProperty());
|
| - Property* prop = callee->AsProperty();
|
| - DCHECK(prop->IsSuperAccess());
|
| - SetExpressionPosition(prop);
|
| -
|
| - Literal* key = prop->key()->AsLiteral();
|
| - DCHECK(!key->value()->IsSmi());
|
| - // Load the function from the receiver.
|
| - const Register scratch = r3;
|
| - SuperPropertyReference* super_ref = prop->obj()->AsSuperPropertyReference();
|
| - VisitForAccumulatorValue(super_ref->home_object());
|
| - __ LoadRR(scratch, r2);
|
| - VisitForAccumulatorValue(super_ref->this_var());
|
| - PushOperands(scratch, r2, r2, scratch);
|
| - PushOperand(key->value());
|
| -
|
| - // Stack here:
|
| - // - home_object
|
| - // - this (receiver)
|
| - // - this (receiver) <-- LoadFromSuper will pop here and below.
|
| - // - home_object
|
| - // - key
|
| - CallRuntimeWithOperands(Runtime::kLoadFromSuper);
|
| - PrepareForBailoutForId(prop->LoadId(), BailoutState::TOS_REGISTER);
|
| -
|
| - // Replace home_object with target function.
|
| - __ StoreP(r2, MemOperand(sp, kPointerSize));
|
| -
|
| - // Stack here:
|
| - // - target function
|
| - // - this (receiver)
|
| - EmitCall(expr);
|
| -}
|
| -
|
| // Code common for calls using the IC.
|
| void FullCodeGenerator::EmitKeyedCallWithLoadIC(Call* expr, Expression* key) {
|
| // Load the key.
|
| @@ -1958,40 +1828,6 @@ void FullCodeGenerator::EmitKeyedCallWithLoadIC(Call* expr, Expression* key) {
|
| EmitCall(expr, ConvertReceiverMode::kNotNullOrUndefined);
|
| }
|
|
|
| -void FullCodeGenerator::EmitKeyedSuperCallWithLoadIC(Call* expr) {
|
| - Expression* callee = expr->expression();
|
| - DCHECK(callee->IsProperty());
|
| - Property* prop = callee->AsProperty();
|
| - DCHECK(prop->IsSuperAccess());
|
| -
|
| - SetExpressionPosition(prop);
|
| - // Load the function from the receiver.
|
| - const Register scratch = r3;
|
| - SuperPropertyReference* super_ref = prop->obj()->AsSuperPropertyReference();
|
| - VisitForAccumulatorValue(super_ref->home_object());
|
| - __ LoadRR(scratch, r2);
|
| - VisitForAccumulatorValue(super_ref->this_var());
|
| - PushOperands(scratch, r2, r2, scratch);
|
| - VisitForStackValue(prop->key());
|
| -
|
| - // Stack here:
|
| - // - home_object
|
| - // - this (receiver)
|
| - // - this (receiver) <-- LoadKeyedFromSuper will pop here and below.
|
| - // - home_object
|
| - // - key
|
| - CallRuntimeWithOperands(Runtime::kLoadKeyedFromSuper);
|
| - PrepareForBailoutForId(prop->LoadId(), BailoutState::TOS_REGISTER);
|
| -
|
| - // Replace home_object with target function.
|
| - __ StoreP(r2, MemOperand(sp, kPointerSize));
|
| -
|
| - // Stack here:
|
| - // - target function
|
| - // - this (receiver)
|
| - EmitCall(expr);
|
| -}
|
| -
|
| void FullCodeGenerator::EmitCall(Call* expr, ConvertReceiverMode mode) {
|
| // Load the arguments.
|
| ZoneList<Expression*>* args = expr->arguments();
|
| @@ -2501,31 +2337,6 @@ void FullCodeGenerator::VisitCountOperation(CountOperation* expr) {
|
| break;
|
| }
|
|
|
| - case NAMED_SUPER_PROPERTY: {
|
| - VisitForStackValue(prop->obj()->AsSuperPropertyReference()->this_var());
|
| - VisitForAccumulatorValue(
|
| - prop->obj()->AsSuperPropertyReference()->home_object());
|
| - const Register scratch = r3;
|
| - __ LoadP(scratch, MemOperand(sp, 0)); // this
|
| - PushOperands(result_register(), scratch, result_register());
|
| - EmitNamedSuperPropertyLoad(prop);
|
| - break;
|
| - }
|
| -
|
| - case KEYED_SUPER_PROPERTY: {
|
| - VisitForStackValue(prop->obj()->AsSuperPropertyReference()->this_var());
|
| - VisitForStackValue(
|
| - prop->obj()->AsSuperPropertyReference()->home_object());
|
| - VisitForAccumulatorValue(prop->key());
|
| - const Register scratch1 = r3;
|
| - const Register scratch2 = r4;
|
| - __ LoadP(scratch1, MemOperand(sp, 1 * kPointerSize)); // this
|
| - __ LoadP(scratch2, MemOperand(sp, 0 * kPointerSize)); // home object
|
| - PushOperands(result_register(), scratch1, scratch2, result_register());
|
| - EmitKeyedSuperPropertyLoad(prop);
|
| - break;
|
| - }
|
| -
|
| case KEYED_PROPERTY: {
|
| VisitForStackValue(prop->obj());
|
| VisitForStackValue(prop->key());
|
| @@ -2536,6 +2347,8 @@ void FullCodeGenerator::VisitCountOperation(CountOperation* expr) {
|
| break;
|
| }
|
|
|
| + case NAMED_SUPER_PROPERTY:
|
| + case KEYED_SUPER_PROPERTY:
|
| case VARIABLE:
|
| UNREACHABLE();
|
| }
|
| @@ -2571,14 +2384,12 @@ void FullCodeGenerator::VisitCountOperation(CountOperation* expr) {
|
| case NAMED_PROPERTY:
|
| __ StoreP(r2, MemOperand(sp, kPointerSize));
|
| break;
|
| - case NAMED_SUPER_PROPERTY:
|
| - __ StoreP(r2, MemOperand(sp, 2 * kPointerSize));
|
| - break;
|
| case KEYED_PROPERTY:
|
| __ StoreP(r2, MemOperand(sp, 2 * kPointerSize));
|
| break;
|
| + case NAMED_SUPER_PROPERTY:
|
| case KEYED_SUPER_PROPERTY:
|
| - __ StoreP(r2, MemOperand(sp, 3 * kPointerSize));
|
| + UNREACHABLE();
|
| break;
|
| }
|
| }
|
| @@ -2613,14 +2424,12 @@ void FullCodeGenerator::VisitCountOperation(CountOperation* expr) {
|
| case NAMED_PROPERTY:
|
| __ StoreP(r2, MemOperand(sp, kPointerSize));
|
| break;
|
| - case NAMED_SUPER_PROPERTY:
|
| - __ StoreP(r2, MemOperand(sp, 2 * kPointerSize));
|
| - break;
|
| case KEYED_PROPERTY:
|
| __ StoreP(r2, MemOperand(sp, 2 * kPointerSize));
|
| break;
|
| + case NAMED_SUPER_PROPERTY:
|
| case KEYED_SUPER_PROPERTY:
|
| - __ StoreP(r2, MemOperand(sp, 3 * kPointerSize));
|
| + UNREACHABLE();
|
| break;
|
| }
|
| }
|
| @@ -2677,30 +2486,6 @@ void FullCodeGenerator::VisitCountOperation(CountOperation* expr) {
|
| }
|
| break;
|
| }
|
| - case NAMED_SUPER_PROPERTY: {
|
| - EmitNamedSuperPropertyStore(prop);
|
| - PrepareForBailoutForId(expr->AssignmentId(), BailoutState::TOS_REGISTER);
|
| - if (expr->is_postfix()) {
|
| - if (!context()->IsEffect()) {
|
| - context()->PlugTOS();
|
| - }
|
| - } else {
|
| - context()->Plug(r2);
|
| - }
|
| - break;
|
| - }
|
| - case KEYED_SUPER_PROPERTY: {
|
| - EmitKeyedSuperPropertyStore(prop);
|
| - PrepareForBailoutForId(expr->AssignmentId(), BailoutState::TOS_REGISTER);
|
| - if (expr->is_postfix()) {
|
| - if (!context()->IsEffect()) {
|
| - context()->PlugTOS();
|
| - }
|
| - } else {
|
| - context()->Plug(r2);
|
| - }
|
| - break;
|
| - }
|
| case KEYED_PROPERTY: {
|
| PopOperands(StoreDescriptor::ReceiverRegister(),
|
| StoreDescriptor::NameRegister());
|
| @@ -2715,6 +2500,10 @@ void FullCodeGenerator::VisitCountOperation(CountOperation* expr) {
|
| }
|
| break;
|
| }
|
| + case NAMED_SUPER_PROPERTY:
|
| + case KEYED_SUPER_PROPERTY:
|
| + UNREACHABLE();
|
| + break;
|
| }
|
| }
|
|
|
|
|