From c7d679467fbea7a64c5d0b5505a6127e85c6bd4f Mon Sep 17 00:00:00 2001 From: Joel Dice Date: Tue, 22 Apr 2008 09:31:40 -0600 Subject: [PATCH] handle case of visiting thread when it is executing one of the transition procedures --- src/compile.cpp | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) diff --git a/src/compile.cpp b/src/compile.cpp index b1e3c17fd1..2f59212c13 100644 --- a/src/compile.cpp +++ b/src/compile.cpp @@ -4689,6 +4689,11 @@ class SegFaultHandler: public System::SignalHandler { Machine* m; }; +class MyProcessor; + +MyProcessor* +processor(MyThread* t); + class MyProcessor: public Processor { public: class CodeAllocator: public Allocator { @@ -5000,6 +5005,9 @@ class MyProcessor: public Processor { MyThread* t = static_cast(vmt); MyThread* target = static_cast(vmTarget); + processor(t)->getDefaultCompiled(t); + processor(t)->getNativeCompiled(t); + class Visitor: public System::ThreadVisitor { public: Visitor(MyThread* t, MyThread* target): t(t), target(target) { } @@ -5015,6 +5023,30 @@ class MyProcessor: public Processor { target->ip = ip; target->base = base; target->stack = stack; + } else { + MyProcessor* p = processor(t); + + uint8_t* default_ = reinterpret_cast + (&singletonValue(t, p->defaultCompiled, 0)); + unsigned defaultSize = singletonLength(t, p->defaultCompiled); + + uint8_t* native = reinterpret_cast + (&singletonValue(t, p->nativeCompiled, 0)); + unsigned nativeSize = singletonLength(t, p->nativeCompiled); + + if ((static_cast(ip) >= p->indirectCaller + and static_cast(ip) + < p->indirectCaller + p->indirectCallerSize) + + or (static_cast(ip) >= default_ + and static_cast(ip) < default_ + defaultSize) + + or (static_cast(ip) >= native + and static_cast(ip) < native + nativeSize)) + { + target->base = base; + target->stack = stack; + } } t->tracing = true;