fix register allocation bugs in floating point instructions

This commit is contained in:
Joel Dice 2007-12-22 17:15:46 -07:00
parent f116225933
commit 6c532e2ba4
3 changed files with 41 additions and 41 deletions

View File

@ -28,7 +28,7 @@ src = src
classpath = classpath classpath = classpath
test = test test = test
input = $(test-build)/Exceptions.class input = $(test-build)/Floats.class
build-cxx = g++ build-cxx = g++
build-cc = gcc build-cc = gcc

View File

@ -18,7 +18,7 @@ vmJump(void* address, void* base, void* stack, void* thread);
namespace { namespace {
const bool Verbose = false; const bool Verbose = true;
const bool DebugTraces = false; const bool DebugTraces = false;
class MyThread: public Thread { class MyThread: public Thread {
@ -1523,11 +1523,11 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(doubleToFloat)), 1, a); (c->constant(reinterpret_cast<intptr_t>(doubleToFloat)), 1, a);
c->release(a);
Operand* result = c->select4(c->result()); Operand* result = c->select4(c->result());
frame->pushInt(result); frame->pushInt(result);
c->release(result); c->release(result);
c->release(a);
} break; } break;
case d2i: { case d2i: {
@ -1535,11 +1535,11 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(doubleToInt)), 1, a); (c->constant(reinterpret_cast<intptr_t>(doubleToInt)), 1, a);
c->release(a);
Operand* result = c->select4(c->result()); Operand* result = c->select4(c->result());
frame->pushInt(result); frame->pushInt(result);
c->release(result); c->release(result);
c->release(a);
} break; } break;
case d2l: { case d2l: {
@ -1547,11 +1547,11 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(doubleToLong)), 1, a); (c->constant(reinterpret_cast<intptr_t>(doubleToLong)), 1, a);
c->release(a);
Operand* result = c->select8(c->result()); Operand* result = c->select8(c->result());
frame->pushLong(result); frame->pushLong(result);
c->release(result); c->release(result);
c->release(a);
} break; } break;
case dadd: { case dadd: {
@ -1560,12 +1560,12 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(addDouble)), 2, a, b); (c->constant(reinterpret_cast<intptr_t>(addDouble)), 2, a, b);
c->release(a);
c->release(b);
Operand* result = c->select8(c->result()); Operand* result = c->select8(c->result());
frame->pushLong(result); frame->pushLong(result);
c->release(result); c->release(result);
c->release(a);
c->release(b);
} break; } break;
case dcmpg: { case dcmpg: {
@ -1574,12 +1574,12 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(compareDoublesG)), 2, a, b); (c->constant(reinterpret_cast<intptr_t>(compareDoublesG)), 2, a, b);
c->release(a);
c->release(b);
Operand* result = c->select4(c->result()); Operand* result = c->select4(c->result());
frame->pushInt(result); frame->pushInt(result);
c->release(result); c->release(result);
c->release(a);
c->release(b);
} break; } break;
case dcmpl: { case dcmpl: {
@ -1588,20 +1588,20 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(compareDoublesL)), 2, a, b); (c->constant(reinterpret_cast<intptr_t>(compareDoublesL)), 2, a, b);
c->release(a);
c->release(b);
Operand* result = c->select4(c->result()); Operand* result = c->select4(c->result());
frame->pushInt(result); frame->pushInt(result);
c->release(result); c->release(result);
c->release(a);
c->release(b);
} break; } break;
case dconst_0: case dconst_0:
frame->pushLong(c->constant(doubleToBits(0.0))); frame->pushLong(c->select8(c->constant(doubleToBits(0.0))));
break; break;
case dconst_1: case dconst_1:
frame->pushLong(c->constant(doubleToBits(1.0))); frame->pushLong(c->select8(c->constant(doubleToBits(1.0))));
break; break;
case ddiv: { case ddiv: {
@ -1610,12 +1610,12 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(divideDouble)), 2, a, b); (c->constant(reinterpret_cast<intptr_t>(divideDouble)), 2, a, b);
c->release(a);
c->release(b);
Operand* result = c->select8(c->result()); Operand* result = c->select8(c->result());
frame->pushLong(result); frame->pushLong(result);
c->release(result); c->release(result);
c->release(a);
c->release(b);
} break; } break;
case dmul: { case dmul: {
@ -1624,12 +1624,12 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(multiplyDouble)), 2, a, b); (c->constant(reinterpret_cast<intptr_t>(multiplyDouble)), 2, a, b);
c->release(a);
c->release(b);
Operand* result = c->select8(c->result()); Operand* result = c->select8(c->result());
frame->pushLong(result); frame->pushLong(result);
c->release(result); c->release(result);
c->release(a);
c->release(b);
} break; } break;
case dneg: { case dneg: {
@ -1637,11 +1637,11 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(negateDouble)), 1, a); (c->constant(reinterpret_cast<intptr_t>(negateDouble)), 1, a);
c->release(a);
Operand* result = c->select8(c->result()); Operand* result = c->select8(c->result());
frame->pushLong(result); frame->pushLong(result);
c->release(result); c->release(result);
c->release(a);
} break; } break;
case vm::drem: { case vm::drem: {
@ -1650,12 +1650,12 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(moduloDouble)), 2, a, b); (c->constant(reinterpret_cast<intptr_t>(moduloDouble)), 2, a, b);
c->release(a);
c->release(b);
Operand* result = c->select8(c->result()); Operand* result = c->select8(c->result());
frame->pushLong(result); frame->pushLong(result);
c->release(result); c->release(result);
c->release(a);
c->release(b);
} break; } break;
case dsub: { case dsub: {
@ -1664,12 +1664,12 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(subtractDouble)), 2, a, b); (c->constant(reinterpret_cast<intptr_t>(subtractDouble)), 2, a, b);
c->release(a);
c->release(b);
Operand* result = c->select8(c->result()); Operand* result = c->select8(c->result());
frame->pushLong(result); frame->pushLong(result);
c->release(result); c->release(result);
c->release(a);
c->release(b);
} break; } break;
case dup: case dup:
@ -1701,11 +1701,11 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(floatToDouble)), 1, a); (c->constant(reinterpret_cast<intptr_t>(floatToDouble)), 1, a);
c->release(a);
Operand* result = c->select8(c->result()); Operand* result = c->select8(c->result());
frame->pushLong(result); frame->pushLong(result);
c->release(result); c->release(result);
c->release(a);
} break; } break;
case f2i: { case f2i: {
@ -1713,11 +1713,11 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(floatToInt)), 1, a); (c->constant(reinterpret_cast<intptr_t>(floatToInt)), 1, a);
c->release(a);
Operand* result = c->select4(c->result()); Operand* result = c->select4(c->result());
frame->pushInt(result); frame->pushInt(result);
c->release(result); c->release(result);
c->release(a);
} break; } break;
case f2l: { case f2l: {
@ -1725,11 +1725,11 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(floatToLong)), 1, a); (c->constant(reinterpret_cast<intptr_t>(floatToLong)), 1, a);
c->release(a);
Operand* result = c->select8(c->result()); Operand* result = c->select8(c->result());
frame->pushLong(result); frame->pushLong(result);
c->release(result); c->release(result);
c->release(a);
} break; } break;
case fadd: { case fadd: {
@ -1738,12 +1738,12 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(addFloat)), 2, a, b); (c->constant(reinterpret_cast<intptr_t>(addFloat)), 2, a, b);
c->release(a);
c->release(b);
Operand* result = c->select4(c->result()); Operand* result = c->select4(c->result());
frame->pushInt(result); frame->pushInt(result);
c->release(result); c->release(result);
c->release(a);
c->release(b);
} break; } break;
case fcmpg: { case fcmpg: {
@ -1752,12 +1752,12 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(compareFloatsG)), 2, a, b); (c->constant(reinterpret_cast<intptr_t>(compareFloatsG)), 2, a, b);
c->release(a);
c->release(b);
Operand* result = c->select4(c->result()); Operand* result = c->select4(c->result());
frame->pushInt(result); frame->pushInt(result);
c->release(result); c->release(result);
c->release(a);
c->release(b);
} break; } break;
case fcmpl: { case fcmpl: {
@ -1766,12 +1766,12 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(compareFloatsL)), 2, a, b); (c->constant(reinterpret_cast<intptr_t>(compareFloatsL)), 2, a, b);
c->release(a);
c->release(b);
Operand* result = c->select4(c->result()); Operand* result = c->select4(c->result());
frame->pushInt(result); frame->pushInt(result);
c->release(result); c->release(result);
c->release(a);
c->release(b);
} break; } break;
case fconst_0: case fconst_0:
@ -1792,12 +1792,12 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(divideFloat)), 2, a, b); (c->constant(reinterpret_cast<intptr_t>(divideFloat)), 2, a, b);
c->release(a);
c->release(b);
Operand* result = c->select4(c->result()); Operand* result = c->select4(c->result());
frame->pushInt(result); frame->pushInt(result);
c->release(result); c->release(result);
c->release(a);
c->release(b);
} break; } break;
case fmul: { case fmul: {
@ -1806,12 +1806,12 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(multiplyFloat)), 2, a, b); (c->constant(reinterpret_cast<intptr_t>(multiplyFloat)), 2, a, b);
c->release(a);
c->release(b);
Operand* result = c->select4(c->result()); Operand* result = c->select4(c->result());
frame->pushInt(result); frame->pushInt(result);
c->release(result); c->release(result);
c->release(a);
c->release(b);
} break; } break;
case fneg: { case fneg: {
@ -1819,11 +1819,11 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(negateFloat)), 1, a); (c->constant(reinterpret_cast<intptr_t>(negateFloat)), 1, a);
c->release(a);
Operand* result = c->select8(c->result()); Operand* result = c->select8(c->result());
frame->pushLong(result); frame->pushLong(result);
c->release(result); c->release(result);
c->release(a);
} break; } break;
case vm::frem: { case vm::frem: {
@ -1832,12 +1832,12 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(moduloFloat)), 2, a, b); (c->constant(reinterpret_cast<intptr_t>(moduloFloat)), 2, a, b);
c->release(a);
c->release(b);
Operand* result = c->select4(c->result()); Operand* result = c->select4(c->result());
frame->pushInt(result); frame->pushInt(result);
c->release(result); c->release(result);
c->release(a);
c->release(b);
} break; } break;
case fsub: { case fsub: {
@ -1846,12 +1846,12 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip)
c->directCall c->directCall
(c->constant(reinterpret_cast<intptr_t>(subtractFloat)), 2, a, b); (c->constant(reinterpret_cast<intptr_t>(subtractFloat)), 2, a, b);
c->release(a);
c->release(b);
Operand* result = c->select4(c->result()); Operand* result = c->select4(c->result());
frame->pushInt(result); frame->pushInt(result);
c->release(result); c->release(result);
c->release(a);
c->release(b);
} break; } break;
case getfield: case getfield:

View File

@ -2428,7 +2428,7 @@ class MyCompiler: public Compiler {
} }
virtual void return_(Operand* v) { virtual void return_(Operand* v) {
mov(v, register_(&c, rax)); mov(v, register_(&c, rax, rdx));
epilogue(); epilogue();
ret(); ret();
} }