Index: src/ia32/full-codegen-ia32.cc |
diff --git a/src/ia32/full-codegen-ia32.cc b/src/ia32/full-codegen-ia32.cc |
index ab9438ab7ed23ef5c74ba8abdc15a20e80da2045..10b788d0c9ecce4e566a957101430a47d8b22ad0 100644 |
--- a/src/ia32/full-codegen-ia32.cc |
+++ b/src/ia32/full-codegen-ia32.cc |
@@ -2164,15 +2164,6 @@ void FullCodeGenerator::EmitGeneratorResume(Expression *generator, |
VisitForAccumulatorValue(value); |
__ pop(ebx); |
- // Check generator state. |
- Label wrong_state, closed_state, done; |
- STATIC_ASSERT(JSGeneratorObject::kGeneratorExecuting < 0); |
- STATIC_ASSERT(JSGeneratorObject::kGeneratorClosed == 0); |
- __ cmp(FieldOperand(ebx, JSGeneratorObject::kContinuationOffset), |
- Immediate(Smi::FromInt(0))); |
- __ j(equal, &closed_state); |
- __ j(less, &wrong_state); |
- |
// Load suspended function and context. |
__ mov(esi, FieldOperand(ebx, JSGeneratorObject::kContextOffset)); |
__ mov(edi, FieldOperand(ebx, JSGeneratorObject::kFunctionOffset)); |
@@ -2194,7 +2185,7 @@ void FullCodeGenerator::EmitGeneratorResume(Expression *generator, |
// Enter a new JavaScript frame, and initialize its slots as they were when |
// the generator was suspended. |
- Label resume_frame; |
+ Label resume_frame, done; |
__ bind(&push_frame); |
__ call(&resume_frame); |
__ jmp(&done); |
@@ -2241,25 +2232,6 @@ void FullCodeGenerator::EmitGeneratorResume(Expression *generator, |
// Not reached: the runtime call returns elsewhere. |
__ Abort(kGeneratorFailedToResume); |
- // Reach here when generator is closed. |
- __ bind(&closed_state); |
- if (resume_mode == JSGeneratorObject::NEXT) { |
- // Return completed iterator result when generator is closed. |
- __ push(Immediate(isolate()->factory()->undefined_value())); |
- // Pop value from top-of-stack slot; box result into result register. |
- EmitCreateIteratorResult(true); |
- } else { |
- // Throw the provided value. |
- __ push(eax); |
- __ CallRuntime(Runtime::kThrow, 1); |
- } |
- __ jmp(&done); |
- |
- // Throw error if we attempt to operate on a running generator. |
- __ bind(&wrong_state); |
- __ push(ebx); |
- __ CallRuntime(Runtime::kThrowGeneratorStateError, 1); |
- |
__ bind(&done); |
context()->Plug(result_register()); |
} |