support JIT compiling methods with unsorted exception handler tables

This commit is contained in:
Joel Dice 2008-01-25 17:17:27 -07:00
parent aa081089ce
commit 8150b957c9

View File

@ -3807,39 +3807,53 @@ compile(MyThread* t, Context* context)
if (eht) { if (eht) {
PROTECT(t, eht); PROTECT(t, eht);
for (unsigned i = 0; i < exceptionHandlerTableLength(t, eht); ++i) { unsigned visitCount = exceptionHandlerTableLength(t, eht);
ExceptionHandler* eh = exceptionHandlerTableBody(t, eht, i); bool visited[visitCount];
unsigned start = exceptionHandlerStart(eh); memset(visited, 0, visitCount);
assert(t, context->visitTable[start]); while (visitCount) {
bool progress = false;
uintptr_t stackMap[stackMapSizeInWords(t, context->method)]; for (unsigned i = 0; i < exceptionHandlerTableLength(t, eht); ++i) {
Frame frame2(&frame, stackMap); ExceptionHandler* eh = exceptionHandlerTableBody(t, eht, i);
unsigned start = exceptionHandlerStart(eh);
uintptr_t* roots = context->rootTable if (not visited[i] and context->visitTable[start]) {
+ (start * frameMapSizeInWords(t, context->method)); -- visitCount;
visited[i] = true;
progress = true;
for (unsigned i = 0; i < localSize(t, context->method); ++ i) { uintptr_t stackMap[stackMapSizeInWords(t, context->method)];
if (getBit(roots, i)) { Frame frame2(&frame, stackMap);
frame2.mark(i);
} else { uintptr_t* roots = context->rootTable
frame2.clear(i); + (start * frameMapSizeInWords(t, context->method));
for (unsigned i = 0; i < localSize(t, context->method); ++ i) {
if (getBit(roots, i)) {
frame2.mark(i);
} else {
frame2.clear(i);
}
}
frame2.pushObject();
for (unsigned i = 1;
i < codeMaxStack(t, methodCode(t, context->method));
++i)
{
frame2.clear(localSize(t, context->method) + i);
}
compile(t, &frame2, exceptionHandlerIp(eh));
if (UNLIKELY(t->exception)) return 0;
eventIndex = calculateFrameMaps(t, context, 0, eventIndex);
} }
} }
frame2.pushObject(); assert(t, progress);
for (unsigned i = 1;
i < codeMaxStack(t, methodCode(t, context->method));
++i)
{
frame2.clear(localSize(t, context->method) + i);
}
compile(t, &frame2, exceptionHandlerIp(eh));
if (UNLIKELY(t->exception)) return 0;
eventIndex = calculateFrameMaps(t, context, 0, eventIndex);
} }
} }