fix stack unwinding from native methods for tails=true build

We can't clear t->trace->targetMethod until after findUnwindTarget has
been called or we'll lose track of where we are on the stack.
This commit is contained in:
Joel Dice 2011-07-13 18:06:02 -06:00
parent e3662f13a9
commit 3ec4ef9bd2

View File

@ -2190,6 +2190,9 @@ unwind(MyThread* t)
object continuation; object continuation;
findUnwindTarget(t, &ip, &frame, &stack, &continuation); findUnwindTarget(t, &ip, &frame, &stack, &continuation);
t->trace->targetMethod = 0;
t->trace->nativeMethod = 0;
transition(t, ip, stack, continuation, t->trace); transition(t, ip, stack, continuation, t->trace);
vmJump(ip, frame, stack, t, 0, 0); vmJump(ip, frame, stack, t, 0, 0);
@ -7329,11 +7332,6 @@ invokeNative(MyThread* t)
t->trace->targetMethod = t->trace->nativeMethod; t->trace->targetMethod = t->trace->nativeMethod;
THREAD_RESOURCE0(t, {
static_cast<MyThread*>(t)->trace->targetMethod = 0;
static_cast<MyThread*>(t)->trace->nativeMethod = 0;
});
t->m->classpath->resolveNative(t, t->trace->nativeMethod); t->m->classpath->resolveNative(t, t->trace->nativeMethod);
result = invokeNative2(t, t->trace->nativeMethod); result = invokeNative2(t, t->trace->nativeMethod);
@ -7355,6 +7353,9 @@ invokeNative(MyThread* t)
transition(t, getIp(t), stack, t->continuation, t->trace); transition(t, getIp(t), stack, t->continuation, t->trace);
t->trace->targetMethod = 0;
t->trace->nativeMethod = 0;
return result; return result;
} }