This commit is contained in:
Joel Dice 2008-09-24 18:48:32 -06:00
parent f2bf152eba
commit 11c2afbf91
3 changed files with 99 additions and 50 deletions

View File

@ -1818,19 +1818,19 @@ handleExit(MyThread* t, Frame* frame)
void void
compile(MyThread* t, Frame* initialFrame, unsigned ip, compile(MyThread* t, Frame* initialFrame, unsigned ip,
bool exceptionHandler = false); int exceptionHandlerStart = -1);
void void
saveStateAndCompile(MyThread* t, Frame* initialFrame, unsigned ip, saveStateAndCompile(MyThread* t, Frame* initialFrame, unsigned ip)
bool exceptionHandler = false)
{ {
Compiler::State* state = initialFrame->c->saveState(); Compiler::State* state = initialFrame->c->saveState();
compile(t, initialFrame, ip, exceptionHandler); compile(t, initialFrame, ip);
initialFrame->c->restoreState(state); initialFrame->c->restoreState(state);
} }
void void
compile(MyThread* t, Frame* initialFrame, unsigned ip, bool exceptionHandler) compile(MyThread* t, Frame* initialFrame, unsigned ip,
int exceptionHandlerStart)
{ {
uint8_t stackMap uint8_t stackMap
[codeMaxStack(t, methodCode(t, initialFrame->context->method))]; [codeMaxStack(t, methodCode(t, initialFrame->context->method))];
@ -1856,7 +1856,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip, bool exceptionHandler)
int index = 0; int index = 0;
if ((methodFlags(t, context->method) & ACC_STATIC) == 0) { if ((methodFlags(t, context->method) & ACC_STATIC) == 0) {
c->initParameter(BytesPerWord, index++); c->initLocal(BytesPerWord, index++);
} }
for (MethodSpecIterator it for (MethodSpecIterator it
@ -1867,17 +1867,19 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip, bool exceptionHandler)
switch (*it.next()) { switch (*it.next()) {
case 'J': case 'J':
case 'D': case 'D':
c->initParameter(2 * BytesPerWord, index); c->initLocal(2 * BytesPerWord, index);
index += 2; index += 2;
break; break;
default: default:
c->initParameter(BytesPerWord, index++); c->initLocal(BytesPerWord, index++);
break; break;
} }
} }
} else if (exceptionHandler) { } else if (exceptionHandlerStart >= 0) {
exceptionHandler = false; c->initLocalsFromLogicalIp(exceptionHandlerStart);
exceptionHandlerStart = -1;
frame->pushObject(); frame->pushObject();
@ -3980,7 +3982,7 @@ compile(MyThread* t, Context* context)
frame2.set(localSize(t, context->method) + i, Frame::Integer); frame2.set(localSize(t, context->method) + i, Frame::Integer);
} }
compile(t, &frame2, exceptionHandlerIp(eh), true); compile(t, &frame2, exceptionHandlerIp(eh), start);
if (UNLIKELY(t->exception)) return 0; if (UNLIKELY(t->exception)) return 0;
eventIndex = calculateFrameMaps(t, context, 0, 0, eventIndex); eventIndex = calculateFrameMaps(t, context, 0, 0, eventIndex);

View File

@ -587,6 +587,7 @@ removeMemorySites(Context* c, Value* v)
void void
clearSites(Context* c, Value* v) clearSites(Context* c, Value* v)
{ {
//fprintf(stderr, "clear sites for %p\n", v);
for (Site* s = v->sites; s; s = s->next) { for (Site* s = v->sites; s; s = s->next) {
s->release(c); s->release(c);
} }
@ -606,9 +607,12 @@ live(Value* v)
} }
void void
nextRead(Context* c, Value* v) nextRead(Context* c, Event* e, Value* v)
{ {
// fprintf(stderr, "pop read %p from %p; next: %p\n", v->reads, v, v->reads->next); assert(c, e == v->reads->event);
// fprintf(stderr, "pop read %p from %p; next: %p\n",
// v->reads, v, v->reads->next(c));
v->reads = v->reads->next(c); v->reads = v->reads->next(c);
if (not live(v)) { if (not live(v)) {
@ -1577,6 +1581,8 @@ apply(Context* c, TernaryOperation op,
void void
addRead(Context* c, Event* e, Value* v, Read* r) addRead(Context* c, Event* e, Value* v, Read* r)
{ {
// fprintf(stderr, "add read %p to %p\n", r, v);
r->value = v; r->value = v;
if (e) { if (e) {
r->event = e; r->event = e;
@ -1608,7 +1614,7 @@ clean(Context* c, Value* v)
} }
void void
clean(Context* c, Stack* stack, Local* locals, Read* reads) clean(Context* c, Event* e, Stack* stack, Local* locals, Read* reads)
{ {
for (unsigned i = 0; i < c->localFootprint; ++i) { for (unsigned i = 0; i < c->localFootprint; ++i) {
if (locals[i].value) clean(c, locals[i].value); if (locals[i].value) clean(c, locals[i].value);
@ -1619,7 +1625,7 @@ clean(Context* c, Stack* stack, Local* locals, Read* reads)
} }
for (Read* r = reads; r; r = r->eventNext) { for (Read* r = reads; r; r = r->eventNext) {
nextRead(c, r->value); nextRead(c, e, r->value);
} }
} }
@ -1677,8 +1683,9 @@ class CallEvent: public Event {
for (Stack* s = stack; s; s = s->next) { for (Stack* s = stack; s; s = s->next) {
frameIndex -= s->size; frameIndex -= s->size;
if (footprint > 0) { if (footprint > 0) {
addRead(c, this, s->value, read(c, s->size * BytesPerWord, addRead(c, this, s->value, read
1 << MemoryOperand, 0, frameIndex)); (c, s->size * BytesPerWord,
1 << MemoryOperand, 0, frameIndex));
} else { } else {
unsigned index = s->index + c->localFootprint; unsigned index = s->index + c->localFootprint;
if (footprint == 0) { if (footprint == 0) {
@ -1690,6 +1697,14 @@ class CallEvent: public Event {
} }
footprint -= s->size; footprint -= s->size;
} }
for (unsigned i = 0; i < c->localFootprint; ++i) {
Local* local = locals + i;
if (local->value) {
addRead(c, this, local->value, read
(c, local->size, 1 << MemoryOperand, 0, i));
}
}
} }
virtual const char* name() { virtual const char* name() {
@ -1704,7 +1719,7 @@ class CallEvent: public Event {
traceHandler->handleTrace(codePromise(c, c->assembler->offset())); traceHandler->handleTrace(codePromise(c, c->assembler->offset()));
} }
clean(c, stack, locals, reads); clean(c, this, stack, locals, reads);
if (resultSize and live(result)) { if (resultSize and live(result)) {
addSite(c, 0, 0, resultSize, result, registerSite addSite(c, 0, 0, resultSize, result, registerSite
@ -1752,7 +1767,7 @@ class ReturnEvent: public Event {
virtual void compile(Context* c) { virtual void compile(Context* c) {
if (value) { if (value) {
nextRead(c, value); nextRead(c, this, value);
} }
c->assembler->popFrame(); c->assembler->popFrame();
@ -1833,7 +1848,7 @@ class MoveEvent: public Event {
removeSite(c, dst, target); removeSite(c, dst, target);
} }
nextRead(c, src); nextRead(c, this, src);
} }
BinaryOperation type; BinaryOperation type;
@ -1912,8 +1927,8 @@ class CompareEvent: public Event {
apply(c, Compare, size, first->source, size, second->source); apply(c, Compare, size, first->source, size, second->source);
} }
nextRead(c, first); nextRead(c, this, first);
nextRead(c, second); nextRead(c, this, second);
} }
unsigned size; unsigned size;
@ -1998,8 +2013,8 @@ class CombineEvent: public Event {
apply(c, type, firstSize, first->source, secondSize, second->source, apply(c, type, firstSize, first->source, secondSize, second->source,
resultSize, target); resultSize, target);
nextRead(c, first); nextRead(c, this, first);
nextRead(c, second); nextRead(c, this, second);
if (c->arch->condensedAddressing()) { if (c->arch->condensedAddressing()) {
removeSite(c, second, second->source); removeSite(c, second, second->source);
@ -2130,7 +2145,7 @@ class TranslateEvent: public Event {
Site* target = targetOrRegister(c, result); Site* target = targetOrRegister(c, result);
apply(c, type, size, value->source, size, target); apply(c, type, size, value->source, size, target);
nextRead(c, value); nextRead(c, this, value);
removeSite(c, value, value->source); removeSite(c, value, value->source);
if (live(result)) { if (live(result)) {
@ -2205,13 +2220,13 @@ class MemoryEvent: public Event {
assert(c, base->source->type(c) == RegisterOperand); assert(c, base->source->type(c) == RegisterOperand);
int baseRegister = static_cast<RegisterSite*>(base->source)->register_.low; int baseRegister = static_cast<RegisterSite*>(base->source)->register_.low;
nextRead(c, base); nextRead(c, this, base);
if (index) { if (index) {
if (BytesPerWord == 8 and indexRegister != NoRegister) { if (BytesPerWord == 8 and indexRegister != NoRegister) {
apply(c, Move, 4, index->source, 8, index->source); apply(c, Move, 4, index->source, 8, index->source);
} }
nextRead(c, index); nextRead(c, this, index);
} }
result->target = memorySite result->target = memorySite
@ -2310,7 +2325,7 @@ class BranchEvent: public Event {
apply(c, type, BytesPerWord, address->source); apply(c, type, BytesPerWord, address->source);
} }
nextRead(c, address); nextRead(c, this, address);
} }
UnaryOperation type; UnaryOperation type;
@ -2381,8 +2396,8 @@ class BoundsCheckEvent: public Event {
nextPromise->offset = a->offset(); nextPromise->offset = a->offset();
nextRead(c, object); nextRead(c, this, object);
nextRead(c, index); nextRead(c, this, index);
} }
Value* object; Value* object;
@ -2399,14 +2414,14 @@ appendBoundsCheck(Context* c, Value* object, unsigned lengthOffset,
(c, object, lengthOffset, index, handler); (c, object, lengthOffset, index, handler);
} }
class ParameterEvent: public Event { class FrameSiteEvent: public Event {
public: public:
ParameterEvent(Context* c, Value* value, unsigned size, int index): FrameSiteEvent(Context* c, Value* value, unsigned size, int index):
Event(c), value(value), size(size), index(index) Event(c), value(value), size(size), index(index)
{ } { }
virtual const char* name() { virtual const char* name() {
return "ParameterEvent"; return "FrameSiteEvent";
} }
virtual void compile(Context* c) { virtual void compile(Context* c) {
@ -2419,9 +2434,9 @@ class ParameterEvent: public Event {
}; };
void void
appendParameter(Context* c, Value* value, unsigned size, int index) appendFrameSite(Context* c, Value* value, unsigned size, int index)
{ {
new (c->zone->allocate(sizeof(ParameterEvent))) ParameterEvent new (c->zone->allocate(sizeof(FrameSiteEvent))) FrameSiteEvent
(c, value, size, index); (c, value, size, index);
} }
@ -2494,6 +2509,8 @@ resolveJunctionSite(Context* c, Event* e, Event* successor, Value* v,
assert(c, index < frameFootprint(c, successor->stack)); assert(c, index < frameFootprint(c, successor->stack));
if (live(v)) { if (live(v)) {
assert(c, v->sites);
Read* r = v->reads; Read* r = v->reads;
Site* original = e->junctionSites[index]; Site* original = e->junctionSites[index];
@ -2507,6 +2524,8 @@ resolveJunctionSite(Context* c, Event* e, Event* successor, Value* v,
if (copyCost) { if (copyCost) {
addSite(c, successor->stack, successor->locals, r->size, v, target); addSite(c, successor->stack, successor->locals, r->size, v, target);
apply(c, Move, r->size, site, r->size, target); apply(c, Move, r->size, site, r->size, target);
} else {
target = site;
} }
if (original == 0) { if (original == 0) {
@ -2597,8 +2616,11 @@ populateSiteTables(Context* c, Event* e)
memset(savedSites, 0, size); memset(savedSites, 0, size);
for (unsigned i = 0; i < c->localFootprint; ++i) { for (unsigned i = 0; i < c->localFootprint; ++i) {
if (successor->locals[i].value) { Value* v = successor->locals[i].value;
savedSites[i] = successor->locals[i].value->sites; if (v) {
savedSites[i] = v->sites;
// fprintf(stderr, "save %p for %p at %d\n", savedSites[i], v, i);
} }
} }
@ -2606,8 +2628,8 @@ populateSiteTables(Context* c, Event* e)
unsigned i = successor->stack->index + c->localFootprint; unsigned i = successor->stack->index + c->localFootprint;
for (Stack* stack = successor->stack; stack; stack = stack->next) { for (Stack* stack = successor->stack; stack; stack = stack->next) {
savedSites[i] = stack->value->sites; savedSites[i] = stack->value->sites;
fprintf(stderr, "save %p at %d of %d in %p\n", // fprintf(stderr, "save %p for %p at %d\n",
savedSites[i], i, frameFootprint, savedSites); // savedSites[i], stack->value, i);
i -= stack->size; i -= stack->size;
} }
@ -2625,6 +2647,8 @@ setSites(Context* c, Event* e, Site** sites)
if (v) { if (v) {
clearSites(c, v); clearSites(c, v);
if (live(v)) { if (live(v)) {
// fprintf(stderr, "set sites %p for %p at %d\n", sites[i], v, i);
addSite(c, 0, 0, v->reads->size, v, sites[i]); addSite(c, 0, 0, v->reads->size, v, sites[i]);
} }
} }
@ -2636,6 +2660,8 @@ setSites(Context* c, Event* e, Site** sites)
Value* v = stack->value; Value* v = stack->value;
clearSites(c, v); clearSites(c, v);
if (live(v)) { if (live(v)) {
// fprintf(stderr, "set sites %p for %p at %d\n", sites[i], v, i);
addSite(c, 0, 0, v->reads->size, v, sites[i]); addSite(c, 0, 0, v->reads->size, v, sites[i]);
} }
i -= stack->size; i -= stack->size;
@ -3114,6 +3140,9 @@ class MyCompiler: public Compiler {
virtual void pushed() { virtual void pushed() {
Value* v = value(&c); Value* v = value(&c);
appendFrameSite
(&c, v, BytesPerWord, (c.stack ? c.stack->index + c.stack->size : 0));
c.stack = ::stack(&c, v, 1, c.stack); c.stack = ::stack(&c, v, 1, c.stack);
} }
@ -3207,22 +3236,36 @@ class MyCompiler: public Compiler {
appendReturn(&c, size, static_cast<Value*>(value)); appendReturn(&c, size, static_cast<Value*>(value));
} }
virtual void initParameter(unsigned size, unsigned index) { virtual void initLocal(unsigned size, unsigned index) {
assert(&c, index < c.parameterFootprint); assert(&c, index < c.localFootprint);
//fprintf(stderr, "init parameter of size %d at %d\n", size, index);
Value* v = value(&c); Value* v = value(&c);
appendParameter(&c, v, size, index); // fprintf(stderr, "init local %p of size %d at %d\n", v, size, index);
appendFrameSite(&c, v, size, index);
Local* local = c.locals + index; Local* local = c.locals + index;
local->value = v; local->value = v;
local->size = size; local->size = size;
} }
virtual void storeLocal(unsigned size, Operand* src, unsigned index) { virtual void initLocalsFromLogicalIp(unsigned logicalIp) {
//fprintf(stderr, "store local of size %d at %d\n", size, index); assert(&c, logicalIp < c.logicalCodeLength);
unsigned footprint = sizeof(Local) * c.localFootprint;
Local* newLocals = static_cast<Local*>(c.zone->allocate(footprint));
memset(newLocals, 0, footprint);
c.locals = newLocals;
Event* e = c.logicalCode[logicalIp]->firstEvent;
for (unsigned i = 0; i < c.localFootprint; ++i) {
Local* local = e->locals + i;
if (local->value) {
initLocal(local->size, i);
}
}
}
virtual void storeLocal(unsigned size, Operand* src, unsigned index) {
assert(&c, index < c.localFootprint); assert(&c, index < c.localFootprint);
unsigned footprint = sizeof(Local) * c.localFootprint; unsigned footprint = sizeof(Local) * c.localFootprint;
@ -3230,18 +3273,21 @@ class MyCompiler: public Compiler {
memcpy(newLocals, c.locals, footprint); memcpy(newLocals, c.locals, footprint);
c.locals = newLocals; c.locals = newLocals;
// fprintf(stderr, "store local %p of size %d at %d\n", src, size, index);
Local* local = c.locals + index; Local* local = c.locals + index;
local->value = static_cast<Value*>(src); local->value = static_cast<Value*>(src);
local->size = size; local->size = size;
} }
virtual Operand* loadLocal(unsigned size UNUSED, unsigned index) { virtual Operand* loadLocal(unsigned size UNUSED, unsigned index) {
//fprintf(stderr, "load local of size %d at %d\n", size, index);
assert(&c, index < c.localFootprint); assert(&c, index < c.localFootprint);
assert(&c, c.locals[index].value); assert(&c, c.locals[index].value);
assert(&c, pad(c.locals[index].size) == pad(size)); assert(&c, pad(c.locals[index].size) == pad(size));
// fprintf(stderr, "load local %p of size %d at %d\n",
// c.locals[index].value, size, index);
return c.locals[index].value; return c.locals[index].value;
} }

View File

@ -88,7 +88,8 @@ class Compiler {
virtual void return_(unsigned size, Operand* value) = 0; virtual void return_(unsigned size, Operand* value) = 0;
virtual void initParameter(unsigned size, unsigned index) = 0; virtual void initLocal(unsigned size, unsigned index) = 0;
virtual void initLocalsFromLogicalIp(unsigned logicalIp) = 0;
virtual void storeLocal(unsigned size, Operand* src, unsigned index) = 0; virtual void storeLocal(unsigned size, Operand* src, unsigned index) = 0;
virtual Operand* loadLocal(unsigned size, unsigned index) = 0; virtual Operand* loadLocal(unsigned size, unsigned index) = 0;