mirror of
https://github.com/corda/corda.git
synced 2025-01-07 13:38:47 +00:00
pick only unfrozen frame sites in save
This commit is contained in:
parent
a40ae85588
commit
75b3bf98ab
@ -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
|
||||||
|
@ -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;
|
||||||
|
Loading…
Reference in New Issue
Block a user