| Index: runtime/vm/intermediate_language_ia32.cc
|
| ===================================================================
|
| --- runtime/vm/intermediate_language_ia32.cc (revision 25871)
|
| +++ runtime/vm/intermediate_language_ia32.cc (working copy)
|
| @@ -2102,16 +2102,22 @@
|
| }
|
|
|
|
|
| -LocationSummary* CatchEntryInstr::MakeLocationSummary() const {
|
| - return LocationSummary::Make(0,
|
| - Location::NoLocation(),
|
| - LocationSummary::kNoCall);
|
| +LocationSummary* CatchBlockEntryInstr::MakeLocationSummary() const {
|
| + UNREACHABLE();
|
| + return NULL;
|
| }
|
|
|
|
|
| -// Restore stack and initialize the two exception variables:
|
| -// exception and stack trace variables.
|
| -void CatchEntryInstr::EmitNativeCode(FlowGraphCompiler* compiler) {
|
| +void CatchBlockEntryInstr::EmitNativeCode(FlowGraphCompiler* compiler) {
|
| + __ Bind(compiler->GetJumpLabel(this));
|
| + compiler->AddExceptionHandler(catch_try_index(),
|
| + try_index(),
|
| + compiler->assembler()->CodeSize(),
|
| + catch_handler_types_);
|
| + if (HasParallelMove()) {
|
| + compiler->parallel_move_resolver()->EmitNativeCode(parallel_move());
|
| + }
|
| +
|
| // Restore ESP from EBP as we are coming from a throw and the code for
|
| // popping arguments has not been run.
|
| const intptr_t fp_sp_dist =
|
| @@ -2119,8 +2125,8 @@
|
| ASSERT(fp_sp_dist <= 0);
|
| __ leal(ESP, Address(EBP, fp_sp_dist));
|
|
|
| - ASSERT(!exception_var().is_captured());
|
| - ASSERT(!stacktrace_var().is_captured());
|
| + // Restore stack and initialize the two exception variables:
|
| + // exception and stack trace variables.
|
| __ movl(Address(EBP, exception_var().index() * kWordSize),
|
| kExceptionObjectReg);
|
| __ movl(Address(EBP, stacktrace_var().index() * kWordSize),
|
|
|