| Index: runtime/vm/simulator_arm64.cc
|
| diff --git a/runtime/vm/simulator_arm64.cc b/runtime/vm/simulator_arm64.cc
|
| index 39af0e75819178ac02394cfc6ecaadb5700d3401..f9339c5737e3c5f8db7e16a7756af448a72a6316 100644
|
| --- a/runtime/vm/simulator_arm64.cc
|
| +++ b/runtime/vm/simulator_arm64.cc
|
| @@ -3025,7 +3025,8 @@ void Simulator::Longjmp(uword pc,
|
| uword sp,
|
| uword fp,
|
| RawObject* raw_exception,
|
| - RawObject* raw_stacktrace) {
|
| + RawObject* raw_stacktrace,
|
| + Isolate* isolate) {
|
| // Walk over all setjmp buffers (simulated --> C++ transitions)
|
| // and try to find the setjmp associated with the simulated stack pointer.
|
| SimulatorSetjmpBuffer* buf = last_setjmp_buffer();
|
| @@ -3038,7 +3039,6 @@ void Simulator::Longjmp(uword pc,
|
| // Prepare for unwinding frames by destroying all the stack resources
|
| // in the previous C++ frames.
|
| uword native_sp = buf->native_sp();
|
| - Isolate* isolate = Isolate::Current();
|
| while (isolate->top_resource() != NULL &&
|
| (reinterpret_cast<uword>(isolate->top_resource()) < native_sp)) {
|
| isolate->top_resource()->~StackResource();
|
| @@ -3048,6 +3048,10 @@ void Simulator::Longjmp(uword pc,
|
| set_pc(static_cast<int64_t>(pc));
|
| set_register(NULL, SP, static_cast<int64_t>(sp));
|
| set_register(NULL, FP, static_cast<int64_t>(fp));
|
| + // Set the tag.
|
| + isolate->set_vm_tag(VMTag::kScriptTagId);
|
| + // Clear top exit frame.
|
| + isolate->set_top_exit_frame_info(0);
|
|
|
| ASSERT(raw_exception != Object::null());
|
| set_register(NULL, kExceptionObjectReg, bit_cast<int64_t>(raw_exception));
|
|
|