pick only unfrozen frame sites in save

This commit is contained in:
Joel Dice 2008-12-20 11:13:58 -07:00
parent a40ae85588
commit 75b3bf98ab
2 changed files with 47 additions and 14 deletions

View File

@ -1755,17 +1755,22 @@ find(Value* needle, Value* haystack)
return false; return false;
} }
bool
frameIndexAvailable(Context* c, int index)
{
return c->frameResources[index].freezeCount == 0;
}
bool bool
save(Context* c, Site* src, Value* v, unsigned size, Stack* stack, save(Context* c, Site* src, Value* v, unsigned size, Stack* stack,
Local* locals, int avoid, bool includeNeighbor) Local* locals)
{ {
int index = NoFrameIndex; int index = NoFrameIndex;
int avoid2 = (includeNeighbor ? avoid + 1 : NoFrameIndex);
for (unsigned li = 0; li < c->localFootprint; ++li) { for (unsigned li = 0; li < c->localFootprint; ++li) {
Local* local = locals + li; Local* local = locals + li;
if (find(v, local->value)) { if (find(v, local->value)) {
int fi = frameIndex(c, li, local->footprint); int fi = frameIndex(c, li, local->footprint);
if (fi != avoid and fi != avoid2) { if (frameIndexAvailable(c, fi)) {
index = fi; index = fi;
break; break;
} }
@ -1777,7 +1782,7 @@ save(Context* c, Site* src, Value* v, unsigned size, Stack* stack,
if (find(v, s->value)) { if (find(v, s->value)) {
int fi = ::frameIndex int fi = ::frameIndex
(c, s->index + c->localFootprint, s->footprint); (c, s->index + c->localFootprint, s->footprint);
if (fi != avoid and fi != avoid2) { if (frameIndexAvailable(c, fi)) {
index = fi; index = fi;
break; break;
} }
@ -1798,7 +1803,7 @@ save(Context* c, Site* src, Value* v, unsigned size, Stack* stack,
bool bool
trySteal(Context* c, Site* site, Value* thief, Value* victim, unsigned size, trySteal(Context* c, Site* site, Value* thief, Value* victim, unsigned size,
Stack* stack, Local* locals, int avoid, bool includeNeighbor) Stack* stack, Local* locals)
{ {
bool success = true; bool success = true;
if (not hasMoreThanOneSite(victim)) { if (not hasMoreThanOneSite(victim)) {
@ -1813,16 +1818,14 @@ trySteal(Context* c, Site* site, Value* thief, Value* victim, unsigned size,
if (pickSite(c, victim, typeMask, registerMask, frameIndex, true) if (pickSite(c, victim, typeMask, registerMask, frameIndex, true)
or victim->thief) or victim->thief)
{ {
success = save(c, site, victim, size, stack, locals, avoid, success = save(c, site, victim, size, stack, locals);
includeNeighbor);
} else { } else {
Site* s = allocateSite(c, typeMask, registerMask, frameIndex); Site* s = allocateSite(c, typeMask, registerMask, frameIndex);
if (s) { if (s) {
move(c, stack, locals, size, victim, site, s); move(c, stack, locals, size, victim, site, s);
success = true; success = true;
} else { } else {
success = save(c, site, victim, size, stack, locals, avoid, success = save(c, site, victim, size, stack, locals);
includeNeighbor);
} }
} }
@ -1848,8 +1851,7 @@ trySteal(Context* c, Register* r, Value* thief, Stack* stack, Local* locals)
fprintf(stderr, "try steal %d from %p\n", r->number, v); fprintf(stderr, "try steal %d from %p\n", r->number, v);
} }
return trySteal(c, r->site, thief, r->value, r->size, stack, locals, return trySteal(c, r->site, thief, r->value, r->size, stack, locals);
NoFrameIndex, 0);
} }
bool bool
@ -2142,15 +2144,27 @@ trySteal(Context* c, FrameResource* r, Value* thief, Stack* stack,
{ {
assert(c, live(r->value)); assert(c, live(r->value));
if (DebugFrameIndexes) {
int index = r - c->frameResources; int index = r - c->frameResources;
if (DebugFrameIndexes) {
fprintf(stderr, fprintf(stderr,
"try steal frame index %d offset 0x%x from value %p site %p\n", "try steal frame index %d offset 0x%x from value %p site %p\n",
index, frameIndexToOffset(c, index), r->value, r->site); index, frameIndexToOffset(c, index), r->value, r->site);
} }
return trySteal(c, r->site, thief, r->value, r->size, stack, locals, freezeFrameIndex(c, index);
r - c->frameResources, r->includeNeighbor); if (r->includeNeighbor) {
freezeFrameIndex(c, index + 1);
}
bool success = trySteal(c, r->site, thief, r->value, r->size, stack, locals);
if (r->includeNeighbor) {
thawFrameIndex(c, index + 1);
}
thawFrameIndex(c, index);
return success;
} }
void void

View File

@ -3,7 +3,26 @@ public class Integers {
if (! v) throw new RuntimeException(); if (! v) throw new RuntimeException();
} }
private static int gcd(int m, int n) {
int temp;
m = Math.abs(m);
n = Math.abs(n);
if (m < n) {
temp = m;
m = n;
n = temp;
}
while (n != 0) {
temp = m;
m = n;
n = temp % n;
}
return m;
}
public static void main(String[] args) { public static void main(String[] args) {
expect(gcd(12, 4) == 4);
{ int a = 2; { int a = 2;
int b = 2; int b = 2;
int c = a + b; int c = a + b;