Merge branch 'compiler' of la.merseine.nu:p/avian-compiler into compiler

This commit is contained in:
Joel Dice 2008-05-17 21:34:46 -06:00
commit 392132cb0e
3 changed files with 74 additions and 18 deletions

View File

@ -625,9 +625,13 @@ freeRegisterSite(Context* c, uint64_t mask = ~static_cast<uint64_t>(0))
RegisterSite* RegisterSite*
fixedRegisterSite(Context* c, int low, int high = NoRegister) fixedRegisterSite(Context* c, int low, int high = NoRegister)
{ {
uint64_t mask = static_cast<uint64_t>(1) << low; uint64_t mask;
if (high != NoRegister) { if (high == NoRegister) {
mask |= static_cast<uint64_t>(1) << (high + 32); mask = (~static_cast<uint64_t>(0) << 32)
| (static_cast<uint64_t>(1) << low);
} else {
mask = (static_cast<uint64_t>(1) << (high + 32))
| (static_cast<uint64_t>(1) << low);
} }
return new (c->zone->allocate(sizeof(RegisterSite))) return new (c->zone->allocate(sizeof(RegisterSite)))
@ -953,8 +957,14 @@ trySteal(Context* c, Register* r, Stack* stack)
} }
if (start) { if (start) {
if (DebugRegisters) {
fprintf(stderr, "push %p\n", v);
}
pushNow(c, start, count); pushNow(c, start, count);
} else { } else {
if (DebugRegisters) {
fprintf(stderr, "unable to steal %d from %p\n", r->number, v);
}
return false; return false;
} }
} }
@ -1053,6 +1063,10 @@ replace(Context* c, Stack* stack, Register* r)
Register* s = acquire(c, mask, stack, r->size, r->value, r->site); Register* s = acquire(c, mask, stack, r->size, r->value, r->site);
thaw(r); thaw(r);
if (DebugRegisters) {
fprintf(stderr, "replace %d with %d\n", r->number, s->number);
}
swap(c, r, s); swap(c, r, s);
return s; return s;
@ -1067,8 +1081,8 @@ acquire(Context* c, uint32_t mask, Stack* stack, unsigned newSize,
if (r->reserved) return r; if (r->reserved) return r;
if (DebugRegisters) { if (DebugRegisters) {
fprintf(stderr, "acquire %d, value %p, site %p\n", fprintf(stderr, "acquire %d, value %p, site %p freeze count %d ref count %d used %d used exclusively %d\n",
r->number, newValue, newSite); r->number, newValue, newSite, r->freezeCount, r->refCount, used(c, r), usedExclusively(c, r));
} }
if (r->refCount) { if (r->refCount) {
@ -1118,6 +1132,8 @@ validate(Context* c, uint32_t mask, Stack* stack, unsigned size,
current->value = value; current->value = value;
current->site = site; current->site = site;
return current; return current;
} else {
abort(c);
} }
} }
@ -1430,21 +1446,20 @@ class MoveEvent: public Event {
} else { } else {
target = targetOrRegister(c, dst); target = targetOrRegister(c, dst);
cost = src->source->copyCost(c, target); cost = src->source->copyCost(c, target);
if (type != Move) {
++ cost;
}
if (cost == 0) { if (cost == 0) {
target = src->source; target = src->source;
} }
} }
if (target == src->source) {
nextRead(c, src); nextRead(c, src);
}
if (dst->reads) { if (dst->reads) {
addSite(c, stack, size, dst, target); addSite(c, stack, size, dst, target);
} }
if (cost) { if (cost or type != Move) {
if (match(c, target, dstTarget->typeMask, dstTarget->registerMask)) { if (match(c, target, dstTarget->typeMask, dstTarget->registerMask)) {
apply(c, type, size, src->source, target); apply(c, type, size, src->source, target);
} else { } else {
@ -1455,15 +1470,24 @@ class MoveEvent: public Event {
addSite(c, stack, size, dst, tmpTarget); addSite(c, stack, size, dst, tmpTarget);
apply(c, type, size, src->source, tmpTarget); apply(c, type, size, src->source, tmpTarget);
apply(c, Move, max(size, BytesPerWord), tmpTarget, target);
if (dst->reads == 0) {
removeSite(c, dst, tmpTarget); removeSite(c, dst, tmpTarget);
apply(c, Move, size, tmpTarget, target);
} else {
removeSite(c, dst, target);
}
} }
} }
if (dst->reads == 0) { if (dst->reads == 0) {
removeSite(c, dst, target); removeSite(c, dst, target);
} }
if (target != src->source) {
nextRead(c, src);
}
} }
BinaryOperation type; BinaryOperation type;

View File

@ -1083,7 +1083,7 @@ multiplyRR(Context* c, unsigned size, Assembler::Register* a,
// mul a->low,%eax%edx // mul a->low,%eax%edx
c->code.append(0xf7); c->code.append(0xf7);
c->code.append(0xe8 | a->low); c->code.append(0xe0 | a->low);
addRR(c, 4, b, &bh); addRR(c, 4, b, &bh);
moveRR(c, 4, &axdx, b); moveRR(c, 4, &axdx, b);
@ -1101,8 +1101,6 @@ void
multiplyCR(Context* c, unsigned size, Assembler::Constant* a, multiplyCR(Context* c, unsigned size, Assembler::Constant* a,
Assembler::Register* b) Assembler::Register* b)
{ {
assert(c, BytesPerWord == 8 or size == 4);
if (BytesPerWord == 4 and size == 8) { if (BytesPerWord == 4 and size == 8) {
const uint32_t mask = ~((1 << rax) | (1 << rdx)); const uint32_t mask = ~((1 << rax) | (1 << rdx));
Assembler::Register tmp(c->client->acquireTemporary(mask), Assembler::Register tmp(c->client->acquireTemporary(mask),
@ -1519,9 +1517,9 @@ unsignedShiftRightRR(Context* c, unsigned size, Assembler::Register* a,
assert(c, a->low == rcx); assert(c, a->low == rcx);
if (BytesPerWord == 4 and size == 8) { if (BytesPerWord == 4 and size == 8) {
// shld // shrd
c->code.append(0x0f); c->code.append(0x0f);
c->code.append(0xa5); c->code.append(0xad);
c->code.append(0xc0 | (b->high << 3) | b->low); c->code.append(0xc0 | (b->high << 3) | b->low);
// shr // shr
@ -1965,7 +1963,8 @@ class MyAssembler: public Assembler {
case ShiftRight: case ShiftRight:
case UnsignedShiftRight: { case UnsignedShiftRight: {
*aTypeMask = (1 << RegisterOperand); *aTypeMask = (1 << RegisterOperand);
*aRegisterMask = static_cast<uint64_t>(1) << rcx; *aRegisterMask = (~static_cast<uint64_t>(0) << 32)
| (static_cast<uint64_t>(1) << rcx);
const uint32_t mask = ~(1 << rcx); const uint32_t mask = ~(1 << rcx);
*bRegisterMask = (static_cast<uint64_t>(mask) << 32) | mask; *bRegisterMask = (static_cast<uint64_t>(mask) << 32) | mask;
} break; } break;

View File

@ -125,6 +125,35 @@ public class Misc {
expect(~a == ~5); expect(~a == ~5);
} }
{ long a = -5;
long b = 2;
expect(a >> b == -5L >> 2);
expect(a >>> b == -5L >>> 2);
expect(a << b == -5L << 2);
expect(a * b == -5L * 2L);
expect(a / b == -5L / 2L);
expect(a % b == -5L % 2L);
expect((a & b) == (-5L & 2L));
expect((a | b) == (-5L | 2L));
expect((a ^ b) == (-5L ^ 2L));
expect(-a == 5L);
expect(~a == ~-5L);
a = 5;
b = 2;
expect(a >> b == 5L >> 2);
expect(a >>> b == 5L >>> 2);
expect(a << b == 5L << 2);
expect(a * b == 5L * 2L);
expect(a / b == 5L / 2L);
expect(a % b == 5L % 2L);
expect((a & b) == (5L & 2L));
expect((a | b) == (5L | 2L));
expect((a ^ b) == (5L ^ 2L));
expect(-a == -5L);
expect(~a == ~5L);
}
byte2 = 0; byte2 = 0;
expect(byte2 == 0); expect(byte2 == 0);
@ -174,6 +203,10 @@ public class Misc {
{ Misc m = new Misc(); { Misc m = new Misc();
m.toString(); m.toString();
expect(m.time == 0xffffffffffffffffL);
long t = m.time;
expect(t == 0xffffffffffffffffL);
String s = "hello"; String s = "hello";
m.foo(s); m.foo(s);
m.bar(s); m.bar(s);