mirror of
https://github.com/corda/corda.git
synced 2025-01-22 20:38:05 +00:00
don't steal sites in pickJunctionSite
This commit is contained in:
parent
b9b7ae4003
commit
b23f7374e9
@ -1853,15 +1853,13 @@ trySteal(Context* c, Site* site, Value* thief, Value* victim, unsigned size,
|
|||||||
or victim->thief)
|
or victim->thief)
|
||||||
{
|
{
|
||||||
success = save(c, site, victim, size, stack, locals);
|
success = save(c, site, victim, size, stack, locals);
|
||||||
} else {
|
} else if (available(c, size, typeMask, registerMask, frameIndex)) {
|
||||||
if (available(c, size, typeMask, registerMask, frameIndex)) {
|
|
||||||
Site* s = allocateSite(c, typeMask, registerMask, frameIndex);
|
Site* s = allocateSite(c, typeMask, registerMask, frameIndex);
|
||||||
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);
|
success = save(c, site, victim, size, stack, locals);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
thief->thief = false;
|
thief->thief = false;
|
||||||
}
|
}
|
||||||
@ -2103,10 +2101,10 @@ acquire(Context* c, uint32_t mask, Stack* stack, Local* locals,
|
|||||||
and oldValue != newValue
|
and oldValue != newValue
|
||||||
and findSite(c, oldValue, r->site))
|
and findSite(c, oldValue, r->site))
|
||||||
{
|
{
|
||||||
|
assert(c, r->freezeCount == 0);
|
||||||
|
|
||||||
if (buddies(oldValue, newValue)) {
|
if (buddies(oldValue, newValue)) {
|
||||||
removeSite(c, oldValue, r->site);
|
removeSite(c, oldValue, r->site);
|
||||||
} else if (r->freezeCount) {
|
|
||||||
abort(c);
|
|
||||||
} else if (not trySteal(c, r, newValue, stack, locals)) {
|
} else if (not trySteal(c, r, newValue, stack, locals)) {
|
||||||
r = replace(c, r, newValue, stack, locals);
|
r = replace(c, r, newValue, stack, locals);
|
||||||
}
|
}
|
||||||
@ -2230,10 +2228,10 @@ acquireFrameIndex(Context* c, int frameIndex, Stack* stack, Local* locals,
|
|||||||
and oldValue != newValue
|
and oldValue != newValue
|
||||||
and findSite(c, oldValue, r->site))
|
and findSite(c, oldValue, r->site))
|
||||||
{
|
{
|
||||||
|
assert(c, r->freezeCount == 0);
|
||||||
|
|
||||||
if (buddies(oldValue, newValue)) {
|
if (buddies(oldValue, newValue)) {
|
||||||
removeSite(c, oldValue, r->site);
|
removeSite(c, oldValue, r->site);
|
||||||
} else if (r->freezeCount) {
|
|
||||||
abort(c);
|
|
||||||
} else if (not trySteal(c, r, newValue, stack, locals)) {
|
} else if (not trySteal(c, r, newValue, stack, locals)) {
|
||||||
abort(c);
|
abort(c);
|
||||||
}
|
}
|
||||||
@ -3685,6 +3683,42 @@ acceptJunctionSite(Context* c, Site* s)
|
|||||||
and (c->availableRegisterCount > 1 or s->type(c) != RegisterOperand);
|
and (c->availableRegisterCount > 1 or s->type(c) != RegisterOperand);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool
|
||||||
|
registerUnused(Context* c, uint32_t mask)
|
||||||
|
{
|
||||||
|
for (int i = c->arch->registerCount() - 1; i >= 0; --i) {
|
||||||
|
if ((1 << i) & mask) {
|
||||||
|
Register* r = c->registers[i];
|
||||||
|
if (not (r->reserved or r->value or r->refCount)) {
|
||||||
|
return true;
|
||||||
|
} else if ((static_cast<uint32_t>(1) << i) == mask) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool
|
||||||
|
frameIndexUnused(Context* c, int index)
|
||||||
|
{
|
||||||
|
return c->frameResources[index].value == 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool
|
||||||
|
unused(Context* c, unsigned size, uint8_t typeMask, uint64_t registerMask,
|
||||||
|
int frameIndex)
|
||||||
|
{
|
||||||
|
return
|
||||||
|
((typeMask & (1 << RegisterOperand))
|
||||||
|
and registerMask
|
||||||
|
and (size <= BytesPerWord or registerUnused(c, registerMask >> 32))
|
||||||
|
and registerUnused(c, registerMask))
|
||||||
|
or ((typeMask & (1 << MemoryOperand))
|
||||||
|
and (frameIndex == AnyFrameIndex
|
||||||
|
or (frameIndex >= 0 and frameIndexUnused(c, frameIndex))));
|
||||||
|
}
|
||||||
|
|
||||||
Site*
|
Site*
|
||||||
pickJunctionSite(Context* c, Value* v, Read* r, unsigned frameIndex)
|
pickJunctionSite(Context* c, Value* v, Read* r, unsigned frameIndex)
|
||||||
{
|
{
|
||||||
@ -3694,17 +3728,24 @@ pickJunctionSite(Context* c, Value* v, Read* r, unsigned frameIndex)
|
|||||||
s = pick(c, v, 0, 0, false);
|
s = pick(c, v, 0, 0, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (acceptJunctionSite(c, s) and s->match
|
if (acceptJunctionSite(c, s)
|
||||||
(c, (1 << RegisterOperand) | (1 << MemoryOperand), ~0, AnyFrameIndex))
|
and s->match(c, (1 << RegisterOperand)
|
||||||
|
| (1 << MemoryOperand), ~0, AnyFrameIndex))
|
||||||
{
|
{
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
s = r->allocateSite(c);
|
uint8_t typeMask = ~static_cast<uint8_t>(0);
|
||||||
|
uint64_t registerMask = ~static_cast<uint64_t>(0);
|
||||||
|
int frameIndexDesired = AnyFrameIndex;
|
||||||
|
r->intersect(&typeMask, ®isterMask, &frameIndexDesired);
|
||||||
|
|
||||||
|
if (unused(c, r->size, typeMask, registerMask, frameIndexDesired)) {
|
||||||
|
s = allocateSite(c, typeMask, registerMask, frameIndexDesired);
|
||||||
if (acceptJunctionSite(c, s)) {
|
if (acceptJunctionSite(c, s)) {
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (c->availableRegisterCount > 1) {
|
if (c->availableRegisterCount > 1) {
|
||||||
return freeRegisterSite(c);
|
return freeRegisterSite(c);
|
||||||
|
@ -76,7 +76,18 @@ public class Misc {
|
|||||||
return a + b + c;
|
return a + b + c;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static Object gimmeNull() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Object queryDefault(Object default_) {
|
||||||
|
Object o = gimmeNull();
|
||||||
|
return (o == null ? default_ : o);
|
||||||
|
}
|
||||||
|
|
||||||
public static void main(String[] args) {
|
public static void main(String[] args) {
|
||||||
|
expect(queryDefault(new Object()) != null);
|
||||||
|
|
||||||
{ Foo foo = new Foo();
|
{ Foo foo = new Foo();
|
||||||
int x = foo.a + foo.b + foo.c;
|
int x = foo.a + foo.b + foo.c;
|
||||||
bar(foo.a, foo.b, foo.c);
|
bar(foo.a, foo.b, foo.c);
|
||||||
|
Loading…
Reference in New Issue
Block a user