From 2cda0007253ec50de5681d985ca03b9fe91a801a Mon Sep 17 00:00:00 2001 From: Joel Dice Date: Mon, 7 Jan 2008 15:04:53 -0700 Subject: [PATCH] fix code ordering bug in compile() which caused us to calculate the stack map incorrectly; logging tweak --- src/compile.cpp | 19 +++++++++++-------- 1 file changed, 11 insertions(+), 8 deletions(-) diff --git a/src/compile.cpp b/src/compile.cpp index 4bb068af83..874b427f54 100644 --- a/src/compile.cpp +++ b/src/compile.cpp @@ -3385,11 +3385,12 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip) void logCompile(const void* code, unsigned size, const char* class_, - const char* name) + const char* name, const char* spec) { if (Verbose) { - fprintf(stderr, "%s.%s from %p to %p\n", - class_, name, code, static_cast(code) + size); + fprintf(stderr, "%s.%s%s from %p to %p\n", + class_, name, spec, code, + static_cast(code) + size); } } @@ -3698,7 +3699,9 @@ finish(MyThread* t, Context* context, const char* name) reinterpret_cast (&byteArrayBody(t, className(t, methodClass(t, context->method)), 0)), reinterpret_cast - (&byteArrayBody(t, methodName(t, context->method), 0))); + (&byteArrayBody(t, methodName(t, context->method), 0)), + reinterpret_cast + (&byteArrayBody(t, methodSpec(t, context->method), 0))); } // for debugging: @@ -3716,7 +3719,7 @@ finish(MyThread* t, Context* context, const char* name) } } else { if (Verbose) { - logCompile(start, c->codeSize(), 0, name); + logCompile(start, c->codeSize(), 0, name, 0); } } @@ -3740,8 +3743,6 @@ compile(MyThread* t, Context* context) uintptr_t stackMap[stackMapSizeInWords(t, context->method)]; Frame frame(context, stackMap); - handleEntrance(t, &frame); - unsigned index = 0; if ((methodFlags(t, context->method) & ACC_STATIC) == 0) { frame.mark(index++); @@ -3769,6 +3770,8 @@ compile(MyThread* t, Context* context) } } + handleEntrance(t, &frame); + compile(t, &frame, 0); if (UNLIKELY(t->exception)) return 0; @@ -4628,7 +4631,7 @@ processor(MyThread* t) c->writeTo(p->indirectCaller); if (Verbose) { - logCompile(p->indirectCaller, c->codeSize(), 0, "indirect caller"); + logCompile(p->indirectCaller, c->codeSize(), 0, "indirect caller", 0); } }