mirror of
https://github.com/corda/corda.git
synced 2025-01-07 13:38:47 +00:00
more JIT fixes; all tests now pass on x86-32
This commit is contained in:
parent
a020a3f6bb
commit
15857135c0
2
makefile
2
makefile
@ -28,7 +28,7 @@ src = src
|
|||||||
classpath = classpath
|
classpath = classpath
|
||||||
test = test
|
test = test
|
||||||
|
|
||||||
input = $(test-build)/Reflection.class
|
input = $(test-build)/Threads.class
|
||||||
|
|
||||||
build-cxx = g++
|
build-cxx = g++
|
||||||
build-cc = gcc
|
build-cc = gcc
|
||||||
|
@ -18,7 +18,7 @@ vmJump(void* address, void* base, void* stack, void* thread);
|
|||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
const bool Verbose = true;
|
const bool Verbose = false;
|
||||||
const bool DebugTraces = false;
|
const bool DebugTraces = false;
|
||||||
|
|
||||||
class MyThread: public Thread {
|
class MyThread: public Thread {
|
||||||
|
@ -1540,6 +1540,16 @@ RegisterOperand::accept(Context* c, Operation operation,
|
|||||||
}
|
}
|
||||||
} break;
|
} break;
|
||||||
|
|
||||||
|
case mul: {
|
||||||
|
if (operand->selection == DefaultSelection
|
||||||
|
or operand->selection == Select4)
|
||||||
|
{
|
||||||
|
encode2(c, 0x0faf, value(c), operand, operand->selection);
|
||||||
|
} else {
|
||||||
|
abort(c);
|
||||||
|
}
|
||||||
|
} break;
|
||||||
|
|
||||||
default: abort(c);
|
default: abort(c);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1649,6 +1659,7 @@ AddressOperand::apply(Context* c, Operation operation)
|
|||||||
conditional(c, 0x8d, this);
|
conditional(c, 0x8d, this);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
||||||
case jl:
|
case jl:
|
||||||
conditional(c, 0x8c, this);
|
conditional(c, 0x8c, this);
|
||||||
break;
|
break;
|
||||||
@ -1657,6 +1668,13 @@ AddressOperand::apply(Context* c, Operation operation)
|
|||||||
conditional(c, 0x8e, this);
|
conditional(c, 0x8e, this);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case push: {
|
||||||
|
RegisterOperand* tmp = temporary(c);
|
||||||
|
tmp->accept(c, mov, this);
|
||||||
|
tmp->apply(c, push);
|
||||||
|
tmp->release(c);
|
||||||
|
} break;
|
||||||
|
|
||||||
default: abort(c);
|
default: abort(c);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1986,7 +2004,7 @@ MemoryOperand::accept(Context* c, Operation operation,
|
|||||||
} else {
|
} else {
|
||||||
assert(c, operand->selection == Select8);
|
assert(c, operand->selection == Select8);
|
||||||
|
|
||||||
RegisterOperand* tmp = temporary(c);
|
RegisterOperand* tmp = temporary(c, rcx);
|
||||||
RegisterOperand* ax = temporary(c, rax);
|
RegisterOperand* ax = temporary(c, rax);
|
||||||
RegisterOperand* dx = temporary(c, rdx);
|
RegisterOperand* dx = temporary(c, rdx);
|
||||||
|
|
||||||
@ -2003,7 +2021,11 @@ MemoryOperand::accept(Context* c, Operation operation,
|
|||||||
ax->accept(c, mul, lowSrc);
|
ax->accept(c, mul, lowSrc);
|
||||||
tmp->accept(c, add, ax);
|
tmp->accept(c, add, ax);
|
||||||
ax->accept(c, mov, lowDst);
|
ax->accept(c, mov, lowDst);
|
||||||
ax->accept(c, mul, lowSrc);
|
|
||||||
|
// mul lowSrc,%eax
|
||||||
|
c->code.append(0xf7);
|
||||||
|
c->code.append(0xe8 | lowSrc->value(c));
|
||||||
|
|
||||||
dx->accept(c, add, tmp);
|
dx->accept(c, add, tmp);
|
||||||
|
|
||||||
lowDst->accept(c, mov, ax);
|
lowDst->accept(c, mov, ax);
|
||||||
|
@ -29,9 +29,9 @@ public class GC {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static void main(String[] args) {
|
public static void main(String[] args) {
|
||||||
//small();
|
small();
|
||||||
medium();
|
medium();
|
||||||
//large();
|
large();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user