Index: src/full-codegen/mips64/full-codegen-mips64.cc |
diff --git a/src/full-codegen/mips64/full-codegen-mips64.cc b/src/full-codegen/mips64/full-codegen-mips64.cc |
index cdaab1fdb125414cef5bf852535edde384932f19..3fb58d9b89f1b0fb6ab3e5bd645462f9a1631be1 100644 |
--- a/src/full-codegen/mips64/full-codegen-mips64.cc |
+++ b/src/full-codegen/mips64/full-codegen-mips64.cc |
@@ -1927,8 +1927,17 @@ void FullCodeGenerator::VisitYield(Yield* expr) { |
__ jmp(&suspend); |
__ bind(&continuation); |
+ // When we arrive here, the stack top is the resume mode and |
+ // result_register() holds the input value (the argument given to the |
+ // respective resume operation). |
__ RecordGeneratorContinuation(); |
- __ jmp(&resume); |
+ __ pop(a1); |
+ __ Branch(&resume, ne, a1, |
+ Operand(Smi::FromInt(JSGeneratorObject::RETURN))); |
+ __ push(result_register()); |
+ EmitCreateIteratorResult(true); |
+ EmitUnwindBeforeReturn(); |
+ EmitReturnSequence(); |
__ bind(&suspend); |
VisitForAccumulatorValue(expr->generator_object()); |
@@ -1955,9 +1964,6 @@ void FullCodeGenerator::VisitYield(Yield* expr) { |
case Yield::kFinal: { |
VisitForAccumulatorValue(expr->generator_object()); |
- __ li(a1, Operand(Smi::FromInt(JSGeneratorObject::kGeneratorClosed))); |
- __ sd(a1, FieldMemOperand(result_register(), |
- JSGeneratorObject::kContinuationOffset)); |
// Pop value from top-of-stack slot, box result into result register. |
EmitCreateIteratorResult(true); |
EmitUnwindBeforeReturn(); |
@@ -2002,6 +2008,10 @@ void FullCodeGenerator::VisitYield(Yield* expr) { |
__ bind(&l_continuation); |
__ RecordGeneratorContinuation(); |
__ mov(a0, v0); |
+ __ pop(a1); |
+ // TODO(neis): Ignoring the resume mode here is clearly wrong. Currently, |
+ // return is not supported for yield*. The planned desugaring of yield* |
+ // using do-expressions will naturally solve this. |
__ jmp(&l_resume); |
__ bind(&l_suspend); |
@@ -2141,6 +2151,7 @@ void FullCodeGenerator::EmitGeneratorResume(Expression *generator, |
__ Daddu(a3, a3, Operand(a2)); |
__ li(a2, Operand(Smi::FromInt(JSGeneratorObject::kGeneratorExecuting))); |
__ sd(a2, FieldMemOperand(a1, JSGeneratorObject::kContinuationOffset)); |
+ __ Push(Smi::FromInt(resume_mode)); // Consumed in continuation. |
__ Jump(a3); |
__ bind(&slow_resume); |
} |
@@ -2154,6 +2165,7 @@ void FullCodeGenerator::EmitGeneratorResume(Expression *generator, |
__ push(a2); |
__ Branch(&push_operand_holes); |
__ bind(&call_resume); |
+ __ Push(Smi::FromInt(resume_mode)); // Consumed in continuation. |
DCHECK(!result_register().is(a1)); |
__ Push(a1, result_register()); |
__ Push(Smi::FromInt(resume_mode)); |