mirror of
https://github.com/corda/corda.git
synced 2025-01-07 13:38:47 +00:00
various bugfixes in new stack trace code
This commit is contained in:
parent
2d6eebf4d1
commit
2cf62a5926
@ -26,9 +26,10 @@ vmCall();
|
|||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
const bool Verbose = false;
|
const bool Verbose = true;
|
||||||
const bool DebugNatives = false;
|
const bool DebugNatives = false;
|
||||||
const bool DebugCallTable = false;
|
const bool DebugCallTable = false;
|
||||||
|
const bool DebugMethodTree = true;
|
||||||
const bool DebugFrameMaps = false;
|
const bool DebugFrameMaps = false;
|
||||||
|
|
||||||
const bool CheckArrayBounds = true;
|
const bool CheckArrayBounds = true;
|
||||||
@ -119,9 +120,18 @@ compareIpToMethodBounds(Thread* t, intptr_t ip, object method)
|
|||||||
{
|
{
|
||||||
intptr_t start = reinterpret_cast<intptr_t>
|
intptr_t start = reinterpret_cast<intptr_t>
|
||||||
(&singletonValue(t, methodCompiled(t, method), 0));
|
(&singletonValue(t, methodCompiled(t, method), 0));
|
||||||
|
|
||||||
|
if (DebugMethodTree) {
|
||||||
|
fprintf(stderr, "find 0x%lx in (0x%lx,0x%lx)\n", ip, start,
|
||||||
|
start + (singletonCount(t, methodCompiled(t, method))
|
||||||
|
* BytesPerWord));
|
||||||
|
}
|
||||||
|
|
||||||
if (ip < start) {
|
if (ip < start) {
|
||||||
return -1;
|
return -1;
|
||||||
} else if (ip < start + singletonCount(t, methodCompiled(t, method))) {
|
} else if (ip < start + (singletonCount(t, methodCompiled(t, method))
|
||||||
|
* BytesPerWord))
|
||||||
|
{
|
||||||
return 0;
|
return 0;
|
||||||
} else {
|
} else {
|
||||||
return 1;
|
return 1;
|
||||||
@ -131,6 +141,10 @@ compareIpToMethodBounds(Thread* t, intptr_t ip, object method)
|
|||||||
object
|
object
|
||||||
methodForIp(MyThread* t, void* ip)
|
methodForIp(MyThread* t, void* ip)
|
||||||
{
|
{
|
||||||
|
if (DebugMethodTree) {
|
||||||
|
fprintf(stderr, "query for method containing %p\n", ip);
|
||||||
|
}
|
||||||
|
|
||||||
return treeQuery(t, methodTree(t), reinterpret_cast<intptr_t>(ip),
|
return treeQuery(t, methodTree(t), reinterpret_cast<intptr_t>(ip),
|
||||||
methodTreeSentinal(t), compareIpToMethodBounds);
|
methodTreeSentinal(t), compareIpToMethodBounds);
|
||||||
}
|
}
|
||||||
@ -153,7 +167,7 @@ class MyStackWalker: public Processor::StackWalker {
|
|||||||
|
|
||||||
MyStackWalker(MyThread* t):
|
MyStackWalker(MyThread* t):
|
||||||
t(t),
|
t(t),
|
||||||
ip_(t->ip ? t->ip : (stack ? *static_cast<void**>(stack) : 0)),
|
ip_(t->ip ? t->ip : (t->stack ? *static_cast<void**>(t->stack) : 0)),
|
||||||
base(t->base),
|
base(t->base),
|
||||||
stack(t->stack),
|
stack(t->stack),
|
||||||
trace(t->trace),
|
trace(t->trace),
|
||||||
@ -164,6 +178,7 @@ class MyStackWalker: public Processor::StackWalker {
|
|||||||
|
|
||||||
MyStackWalker(MyStackWalker* w):
|
MyStackWalker(MyStackWalker* w):
|
||||||
t(w->t),
|
t(w->t),
|
||||||
|
ip_(w->ip_),
|
||||||
base(w->base),
|
base(w->base),
|
||||||
stack(w->stack),
|
stack(w->stack),
|
||||||
trace(w->trace),
|
trace(w->trace),
|
||||||
@ -173,6 +188,8 @@ class MyStackWalker: public Processor::StackWalker {
|
|||||||
{ }
|
{ }
|
||||||
|
|
||||||
virtual void walk(Processor::StackVisitor* v) {
|
virtual void walk(Processor::StackVisitor* v) {
|
||||||
|
fprintf(stderr, "ip: %p stack: %p method: %p\n", ip_, stack, method_);
|
||||||
|
|
||||||
if (stack == 0) {
|
if (stack == 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -3714,6 +3731,12 @@ compareTraceElementPointers(const void* va, const void* vb)
|
|||||||
intptr_t
|
intptr_t
|
||||||
compareMethodBounds(Thread* t, object a, object b)
|
compareMethodBounds(Thread* t, object a, object b)
|
||||||
{
|
{
|
||||||
|
if (DebugMethodTree) {
|
||||||
|
fprintf(stderr, "compare %p to %p\n",
|
||||||
|
&singletonValue(t, methodCompiled(t, a), 0),
|
||||||
|
&singletonValue(t, methodCompiled(t, b), 0));
|
||||||
|
}
|
||||||
|
|
||||||
return reinterpret_cast<intptr_t>
|
return reinterpret_cast<intptr_t>
|
||||||
(&singletonValue(t, methodCompiled(t, a), 0))
|
(&singletonValue(t, methodCompiled(t, a), 0))
|
||||||
- reinterpret_cast<intptr_t>
|
- reinterpret_cast<intptr_t>
|
||||||
@ -3813,13 +3836,6 @@ finish(MyThread* t, Context* context, const char* name)
|
|||||||
updateLineNumberTable(t, c, methodCode(t, context->method),
|
updateLineNumberTable(t, c, methodCode(t, context->method),
|
||||||
reinterpret_cast<intptr_t>(start));
|
reinterpret_cast<intptr_t>(start));
|
||||||
|
|
||||||
{ object node = makeTreeNode
|
|
||||||
(t, context->method, methodTreeSentinal(t), methodTreeSentinal(t));
|
|
||||||
|
|
||||||
methodTree(t) = treeInsert
|
|
||||||
(t, methodTree(t), node, methodTreeSentinal(t), compareMethodBounds);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (Verbose) {
|
if (Verbose) {
|
||||||
logCompile
|
logCompile
|
||||||
(start, c->codeSize(),
|
(start, c->codeSize(),
|
||||||
@ -3836,11 +3852,11 @@ finish(MyThread* t, Context* context, const char* name)
|
|||||||
strcmp
|
strcmp
|
||||||
(reinterpret_cast<const char*>
|
(reinterpret_cast<const char*>
|
||||||
(&byteArrayBody(t, className(t, methodClass(t, context->method)), 0)),
|
(&byteArrayBody(t, className(t, methodClass(t, context->method)), 0)),
|
||||||
"Misc") == 0 and
|
"java/lang/System") == 0 and
|
||||||
strcmp
|
strcmp
|
||||||
(reinterpret_cast<const char*>
|
(reinterpret_cast<const char*>
|
||||||
(&byteArrayBody(t, methodName(t, context->method), 0)),
|
(&byteArrayBody(t, methodName(t, context->method), 0)),
|
||||||
"main") == 0)
|
"getProperty") == 0)
|
||||||
{
|
{
|
||||||
asm("int3");
|
asm("int3");
|
||||||
}
|
}
|
||||||
@ -4223,12 +4239,15 @@ invokeNative(MyThread* t)
|
|||||||
result = invokeNative2(t, t->trace->nativeMethod);
|
result = invokeNative2(t, t->trace->nativeMethod);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
t->trace->nativeMethod = 0;
|
||||||
|
|
||||||
if (UNLIKELY(t->exception)) {
|
if (UNLIKELY(t->exception)) {
|
||||||
unwind(t);
|
unwind(t);
|
||||||
} else {
|
} else {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned
|
unsigned
|
||||||
frameMapIndex(MyThread* t, object method, int32_t offset)
|
frameMapIndex(MyThread* t, object method, int32_t offset)
|
||||||
{
|
{
|
||||||
@ -5001,6 +5020,7 @@ compile(MyThread* t, object method)
|
|||||||
} else {
|
} else {
|
||||||
Context context(t, method, p->indirectCaller);
|
Context context(t, method, p->indirectCaller);
|
||||||
compiled = compile(t, &context);
|
compiled = compile(t, &context);
|
||||||
|
if (UNLIKELY(t->exception)) return;
|
||||||
}
|
}
|
||||||
|
|
||||||
set(t, method, MethodCompiled, compiled);
|
set(t, method, MethodCompiled, compiled);
|
||||||
@ -5009,6 +5029,17 @@ compile(MyThread* t, object method)
|
|||||||
classVtable(t, methodClass(t, method), methodOffset(t, method))
|
classVtable(t, methodClass(t, method), methodOffset(t, method))
|
||||||
= &singletonValue(t, compiled, 0);
|
= &singletonValue(t, compiled, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ((methodFlags(t, method) & ACC_NATIVE) == 0) {
|
||||||
|
if (DebugMethodTree) {
|
||||||
|
fprintf(stderr, "insert method at %p\n",
|
||||||
|
&singletonValue(t, methodCompiled(t, method), 0));
|
||||||
|
}
|
||||||
|
|
||||||
|
methodTree(t) = treeInsert
|
||||||
|
(t, methodTree(t), method, methodTreeSentinal(t),
|
||||||
|
compareMethodBounds);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -40,8 +40,7 @@ inline object
|
|||||||
resolveClassInObject(Thread* t, object container, unsigned classOffset)
|
resolveClassInObject(Thread* t, object container, unsigned classOffset)
|
||||||
{
|
{
|
||||||
object o = cast<object>(container, classOffset);
|
object o = cast<object>(container, classOffset);
|
||||||
if (objectClass(t, o) == arrayBody(t, t->m->types, Machine::ByteArrayType))
|
if (objectClass(t, o) == arrayBody(t, t->m->types, Machine::ByteArrayType)) {
|
||||||
{
|
|
||||||
PROTECT(t, container);
|
PROTECT(t, container);
|
||||||
|
|
||||||
o = resolveClass(t, o);
|
o = resolveClass(t, o);
|
||||||
@ -56,8 +55,7 @@ inline object
|
|||||||
resolveClassInPool(Thread* t, object pool, unsigned index)
|
resolveClassInPool(Thread* t, object pool, unsigned index)
|
||||||
{
|
{
|
||||||
object o = singletonObject(t, pool, index);
|
object o = singletonObject(t, pool, index);
|
||||||
if (objectClass(t, o) == arrayBody(t, t->m->types, Machine::ByteArrayType))
|
if (objectClass(t, o) == arrayBody(t, t->m->types, Machine::ByteArrayType)) {
|
||||||
{
|
|
||||||
PROTECT(t, pool);
|
PROTECT(t, pool);
|
||||||
|
|
||||||
o = resolveClass(t, o);
|
o = resolveClass(t, o);
|
||||||
|
11
src/util.cpp
11
src/util.cpp
@ -77,7 +77,7 @@ treeFind(Thread* t, object old, object node, object sentinal,
|
|||||||
ancestors = makePair(t, new_, ancestors);
|
ancestors = makePair(t, new_, ancestors);
|
||||||
|
|
||||||
intptr_t difference = compare
|
intptr_t difference = compare
|
||||||
(t, getTreeNodeValue(t, node), getTreeNodeValue(t, node));
|
(t, getTreeNodeValue(t, node), getTreeNodeValue(t, old));
|
||||||
|
|
||||||
if (difference < 0) {
|
if (difference < 0) {
|
||||||
old = treeNodeLeft(t, old);
|
old = treeNodeLeft(t, old);
|
||||||
@ -522,7 +522,7 @@ treeQuery(Thread* t, object tree, intptr_t key, object sentinal,
|
|||||||
} else if (difference > 0) {
|
} else if (difference > 0) {
|
||||||
node = treeNodeRight(t, node);
|
node = treeNodeRight(t, node);
|
||||||
} else {
|
} else {
|
||||||
return node;
|
return getTreeNodeValue(t, node);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -530,9 +530,14 @@ treeQuery(Thread* t, object tree, intptr_t key, object sentinal,
|
|||||||
}
|
}
|
||||||
|
|
||||||
object
|
object
|
||||||
treeInsert(Thread* t, object tree, object node, object sentinal,
|
treeInsert(Thread* t, object tree, object value, object sentinal,
|
||||||
intptr_t (*compare)(Thread* t, object a, object b))
|
intptr_t (*compare)(Thread* t, object a, object b))
|
||||||
{
|
{
|
||||||
|
PROTECT(t, tree);
|
||||||
|
PROTECT(t, sentinal);
|
||||||
|
|
||||||
|
object node = makeTreeNode(t, value, sentinal, sentinal);
|
||||||
|
|
||||||
object path = treeFind(t, tree, node, sentinal, compare);
|
object path = treeFind(t, tree, node, sentinal, compare);
|
||||||
if (treePathFresh(t, path)) {
|
if (treePathFresh(t, path)) {
|
||||||
return treeAdd(t, path);
|
return treeAdd(t, path);
|
||||||
|
@ -88,7 +88,7 @@ treeQuery(Thread* t, object tree, intptr_t key, object sentinal,
|
|||||||
intptr_t (*compare)(Thread* t, intptr_t key, object b));
|
intptr_t (*compare)(Thread* t, intptr_t key, object b));
|
||||||
|
|
||||||
object
|
object
|
||||||
treeInsert(Thread* t, object tree, object node, object sentinal,
|
treeInsert(Thread* t, object tree, object value, object sentinal,
|
||||||
intptr_t (*compare)(Thread* t, object a, object b));
|
intptr_t (*compare)(Thread* t, object a, object b));
|
||||||
|
|
||||||
} // vm
|
} // vm
|
||||||
|
Loading…
Reference in New Issue
Block a user