From 377e2864d9d671ba7fa3b8d82df06ad7bb30035b Mon Sep 17 00:00:00 2001 From: Joel Dice Date: Tue, 29 Apr 2008 10:40:44 -0600 Subject: [PATCH] fix argument marshalling for floating point helper functions on 32-bit systems --- src/compile.cpp | 20 ++++++++++---------- src/compiler.cpp | 2 +- 2 files changed, 11 insertions(+), 11 deletions(-) diff --git a/src/compile.cpp b/src/compile.cpp index c95b4021ae..03e8f7401e 100644 --- a/src/compile.cpp +++ b/src/compile.cpp @@ -2147,7 +2147,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip, frame->pushLong (c->call (c->constant(reinterpret_cast(addDouble)), - context->indirection, 0, 0, 8, 2, a, b)); + context->indirection, 0, 0, 8, 4, 0, a, 0, b)); } break; case dcmpg: { @@ -2157,7 +2157,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip, frame->pushInt (c->call (c->constant(reinterpret_cast(compareDoublesG)), - context->indirection, 0, 0, 4, 2, a, b)); + context->indirection, 0, 0, 4, 4, 0, a, 0, b)); } break; case dcmpl: { @@ -2167,7 +2167,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip, frame->pushInt (c->call (c->constant(reinterpret_cast(compareDoublesL)), - context->indirection, 0, 0, 4, 2, a, b)); + context->indirection, 0, 0, 4, 4, 0, a, 0, b)); } break; case dconst_0: @@ -2185,7 +2185,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip, frame->pushLong (c->call (c->constant(reinterpret_cast(divideDouble)), - context->indirection, 0, 0, 8, 2, a, b)); + context->indirection, 0, 0, 8, 4, 0, a, 0, b)); } break; case dmul: { @@ -2195,14 +2195,14 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip, frame->pushLong (c->call (c->constant(reinterpret_cast(multiplyDouble)), - context->indirection, 0, 0, 8, 2, a, b)); + context->indirection, 0, 0, 8, 4, 0, a, 0, b)); } break; case dneg: { frame->pushLong (c->call (c->constant(reinterpret_cast(negateDouble)), - context->indirection, 0, 0, 8, 1, frame->popLong())); + context->indirection, 0, 0, 8, 2, 0, frame->popLong())); } break; case vm::drem: { @@ -2212,7 +2212,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip, frame->pushLong (c->call (c->constant(reinterpret_cast(moduloDouble)), - context->indirection, 0, 0, 8, 2, a, b)); + context->indirection, 0, 0, 8, 4, 0, a, 0, b)); } break; case dsub: { @@ -2222,7 +2222,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip, frame->pushLong (c->call (c->constant(reinterpret_cast(subtractDouble)), - context->indirection, 0, 0, 8, 2, a, b)); + context->indirection, 0, 0, 8, 4, 0, a, 0, b)); } break; case dup: @@ -3875,11 +3875,11 @@ finish(MyThread* t, Context* context) strcmp (reinterpret_cast (&byteArrayBody(t, className(t, methodClass(t, context->method)), 0)), - "java/nio/ByteBuffer") == 0 and + "Floats") == 0 and strcmp (reinterpret_cast (&byteArrayBody(t, methodName(t, context->method), 0)), - "get") == 0) + "multiply") == 0) { asm("int3"); } diff --git a/src/compiler.cpp b/src/compiler.cpp index a06e8c93aa..99d45120db 100644 --- a/src/compiler.cpp +++ b/src/compiler.cpp @@ -2255,7 +2255,7 @@ class MyCompiler: public Compiler { Stack* oldStack = c.state->stack; - for (int i = argumentCount - 1; i >= 0; --i) { + for (int i = index - 1; i >= 0; --i) { ::push(&c, argumentSizes[i], arguments[i]); }