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)); |