mirror of
https://github.com/corda/corda.git
synced 2025-01-07 13:38:47 +00:00
various bugfixes
This commit is contained in:
parent
717f359666
commit
3113ae74eb
@ -282,8 +282,6 @@ class Assembler {
|
|||||||
virtual void updateCall(UnaryOperation op, bool assertAlignment,
|
virtual void updateCall(UnaryOperation op, bool assertAlignment,
|
||||||
void* returnAddress, void* newTarget) = 0;
|
void* returnAddress, void* newTarget) = 0;
|
||||||
|
|
||||||
virtual unsigned constantCallSize() = 0;
|
|
||||||
|
|
||||||
virtual uintptr_t getConstant(const void* src) = 0;
|
virtual uintptr_t getConstant(const void* src) = 0;
|
||||||
virtual void setConstant(void* dst, uintptr_t constant) = 0;
|
virtual void setConstant(void* dst, uintptr_t constant) = 0;
|
||||||
|
|
||||||
@ -293,8 +291,8 @@ class Assembler {
|
|||||||
virtual unsigned frameHeaderSize() = 0;
|
virtual unsigned frameHeaderSize() = 0;
|
||||||
virtual unsigned frameReturnAddressSize() = 0;
|
virtual unsigned frameReturnAddressSize() = 0;
|
||||||
virtual unsigned frameFooterSize() = 0;
|
virtual unsigned frameFooterSize() = 0;
|
||||||
virtual unsigned returnAddressOffset() = 0;
|
virtual int returnAddressOffset() = 0;
|
||||||
virtual unsigned framePointerOffset() = 0;
|
virtual int framePointerOffset() = 0;
|
||||||
virtual void nextFrame(void** stack, void** base) = 0;
|
virtual void nextFrame(void** stack, void** base) = 0;
|
||||||
|
|
||||||
virtual void plan
|
virtual void plan
|
||||||
|
@ -487,11 +487,11 @@ class TraceElementPromise: public Promise {
|
|||||||
|
|
||||||
virtual int64_t value() {
|
virtual int64_t value() {
|
||||||
assert(s, resolved());
|
assert(s, resolved());
|
||||||
return reinterpret_cast<uintptr_t>(trace->address);
|
return trace->address->value();
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual bool resolved() {
|
virtual bool resolved() {
|
||||||
return trace->address != 0;
|
return trace->address != 0 and trace->address->resolved();
|
||||||
}
|
}
|
||||||
|
|
||||||
System* s;
|
System* s;
|
||||||
@ -1943,7 +1943,7 @@ compileDirectInvoke(MyThread* t, Frame* frame, object target, bool tailCall,
|
|||||||
Compiler::Operand* result = c->stackCall
|
Compiler::Operand* result = c->stackCall
|
||||||
(returnAddress,
|
(returnAddress,
|
||||||
flags | Compiler::Aligned,
|
flags | Compiler::Aligned,
|
||||||
0,
|
trace,
|
||||||
rSize,
|
rSize,
|
||||||
methodParameterFootprint(t, target));
|
methodParameterFootprint(t, target));
|
||||||
|
|
||||||
@ -1982,14 +1982,16 @@ compileDirectInvoke(MyThread* t, Frame* frame, object target, bool tailCall,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
bool
|
||||||
compileDirectInvoke(MyThread* t, Frame* frame, object target, bool tailCall)
|
compileDirectInvoke(MyThread* t, Frame* frame, object target, bool tailCall)
|
||||||
{
|
{
|
||||||
unsigned rSize = resultSize(t, methodReturnCode(t, target));
|
unsigned rSize = resultSize(t, methodReturnCode(t, target));
|
||||||
|
|
||||||
Compiler::Operand* result = 0;
|
Compiler::Operand* result = 0;
|
||||||
|
|
||||||
if (not emptyMethod(t, target)) {
|
if (emptyMethod(t, target)) {
|
||||||
|
tailCall = false;
|
||||||
|
} else {
|
||||||
BootContext* bc = frame->context->bootContext;
|
BootContext* bc = frame->context->bootContext;
|
||||||
if (bc) {
|
if (bc) {
|
||||||
if (methodClass(t, target) == methodClass(t, frame->context->method)
|
if (methodClass(t, target) == methodClass(t, frame->context->method)
|
||||||
@ -2024,6 +2026,8 @@ compileDirectInvoke(MyThread* t, Frame* frame, object target, bool tailCall)
|
|||||||
if (rSize) {
|
if (rSize) {
|
||||||
pushReturnValue(t, frame, methodReturnCode(t, target), result);
|
pushReturnValue(t, frame, methodReturnCode(t, target), result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return tailCall;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -3157,7 +3161,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip,
|
|||||||
|
|
||||||
tailCall = isTailCall(t, code, ip, context->method, target);
|
tailCall = isTailCall(t, code, ip, context->method, target);
|
||||||
|
|
||||||
compileDirectInvoke(t, frame, target, tailCall);
|
tailCall = compileDirectInvoke(t, frame, target, tailCall);
|
||||||
} break;
|
} break;
|
||||||
|
|
||||||
case invokestatic: {
|
case invokestatic: {
|
||||||
@ -3170,7 +3174,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip,
|
|||||||
|
|
||||||
tailCall = isTailCall(t, code, ip, context->method, target);
|
tailCall = isTailCall(t, code, ip, context->method, target);
|
||||||
|
|
||||||
compileDirectInvoke(t, frame, target, tailCall);
|
tailCall = compileDirectInvoke(t, frame, target, tailCall);
|
||||||
} break;
|
} break;
|
||||||
|
|
||||||
case invokevirtual: {
|
case invokevirtual: {
|
||||||
@ -3199,7 +3203,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip,
|
|||||||
|
|
||||||
Compiler::Operand* result = c->stackCall
|
Compiler::Operand* result = c->stackCall
|
||||||
(c->memory(classOperand, offset, 0, 1),
|
(c->memory(classOperand, offset, 0, 1),
|
||||||
tailCall ? Compiler::TailCall : 0,
|
tailCall ? Compiler::TailJump : 0,
|
||||||
frame->trace(0, 0),
|
frame->trace(0, 0),
|
||||||
rSize,
|
rSize,
|
||||||
parameterFootprint);
|
parameterFootprint);
|
||||||
@ -4594,11 +4598,9 @@ compileMethod2(MyThread* t, void* ip)
|
|||||||
} else {
|
} else {
|
||||||
void* address = reinterpret_cast<void*>(methodAddress(t, target));
|
void* address = reinterpret_cast<void*>(methodAddress(t, target));
|
||||||
uint8_t* updateIp = static_cast<uint8_t*>(ip);
|
uint8_t* updateIp = static_cast<uint8_t*>(ip);
|
||||||
if (callNodeFlags(t, node) & TraceElement::TailCall) {
|
|
||||||
updateIp -= t->arch->constantCallSize();
|
|
||||||
}
|
|
||||||
|
|
||||||
updateCall(t, Call, true, updateIp, address);
|
updateCall(t, (callNodeFlags(t, node) & TraceElement::TailCall)
|
||||||
|
? Jump : Call, true, updateIp, address);
|
||||||
|
|
||||||
return address;
|
return address;
|
||||||
}
|
}
|
||||||
|
@ -649,10 +649,8 @@ int
|
|||||||
frameIndex(Context* c, int localIndex)
|
frameIndex(Context* c, int localIndex)
|
||||||
{
|
{
|
||||||
assert(c, localIndex >= 0);
|
assert(c, localIndex >= 0);
|
||||||
assert(c, localIndex < static_cast<int>
|
|
||||||
(c->parameterFootprint + c->localFootprint));
|
|
||||||
|
|
||||||
int index = c->alignedFrameSize + c->parameterFootprint - localIndex;
|
int index = c->alignedFrameSize + c->parameterFootprint - localIndex - 1;
|
||||||
|
|
||||||
if (localIndex < static_cast<int>(c->parameterFootprint)) {
|
if (localIndex < static_cast<int>(c->parameterFootprint)) {
|
||||||
index += c->arch->frameHeaderSize();
|
index += c->arch->frameHeaderSize();
|
||||||
@ -661,6 +659,7 @@ frameIndex(Context* c, int localIndex)
|
|||||||
}
|
}
|
||||||
|
|
||||||
assert(c, index >= 0);
|
assert(c, index >= 0);
|
||||||
|
assert(c, static_cast<unsigned>(index) < totalFrameSize(c));
|
||||||
|
|
||||||
return index;
|
return index;
|
||||||
}
|
}
|
||||||
@ -668,15 +667,31 @@ frameIndex(Context* c, int localIndex)
|
|||||||
unsigned
|
unsigned
|
||||||
frameIndexToOffset(Context* c, unsigned frameIndex)
|
frameIndexToOffset(Context* c, unsigned frameIndex)
|
||||||
{
|
{
|
||||||
|
assert(c, frameIndex < totalFrameSize(c));
|
||||||
|
|
||||||
return (frameIndex + c->arch->frameFooterSize()) * BytesPerWord;
|
return (frameIndex + c->arch->frameFooterSize()) * BytesPerWord;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned
|
unsigned
|
||||||
offsetToFrameIndex(Context* c, unsigned offset)
|
offsetToFrameIndex(Context* c, unsigned offset)
|
||||||
{
|
{
|
||||||
|
assert(c, static_cast<int>
|
||||||
|
((offset / BytesPerWord) - c->arch->frameFooterSize()) >= 0);
|
||||||
|
|
||||||
|
assert(c, (offset / BytesPerWord) - c->arch->frameFooterSize()
|
||||||
|
< totalFrameSize(c));
|
||||||
|
|
||||||
return (offset / BytesPerWord) - c->arch->frameFooterSize();
|
return (offset / BytesPerWord) - c->arch->frameFooterSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
unsigned
|
||||||
|
frameBase(Context* c)
|
||||||
|
{
|
||||||
|
return c->alignedFrameSize - 1
|
||||||
|
- c->arch->frameFooterSize()
|
||||||
|
+ c->arch->frameHeaderSize();
|
||||||
|
}
|
||||||
|
|
||||||
class FrameIterator {
|
class FrameIterator {
|
||||||
public:
|
public:
|
||||||
class Element {
|
class Element {
|
||||||
@ -2307,10 +2322,10 @@ class CallEvent: public Event {
|
|||||||
int returnAddressIndex = -1;
|
int returnAddressIndex = -1;
|
||||||
int framePointerIndex = -1;
|
int framePointerIndex = -1;
|
||||||
|
|
||||||
if (flags & (Compiler::TailJump | Compiler::TailCall)) {
|
if (flags & Compiler::TailJump) {
|
||||||
assert(c, argumentCount == 0);
|
assert(c, argumentCount == 0);
|
||||||
|
|
||||||
unsigned base = c->alignedFrameSize - c->arch->frameFooterSize();
|
int base = frameBase(c);
|
||||||
returnAddressIndex = base + c->arch->returnAddressOffset();
|
returnAddressIndex = base + c->arch->returnAddressOffset();
|
||||||
framePointerIndex = base + c->arch->framePointerOffset();
|
framePointerIndex = base + c->arch->framePointerOffset();
|
||||||
|
|
||||||
@ -2387,9 +2402,7 @@ class CallEvent: public Event {
|
|||||||
addRead(c, this, s->value, read
|
addRead(c, this, s->value, read
|
||||||
(c, SiteMask(1 << MemoryOperand, 0, frameIndex)));
|
(c, SiteMask(1 << MemoryOperand, 0, frameIndex)));
|
||||||
}
|
}
|
||||||
}
|
} else if ((flags & Compiler::TailJump) == 0) {
|
||||||
else if ((flags & (Compiler::TailJump | Compiler::TailCall)) == 0)
|
|
||||||
{
|
|
||||||
unsigned logicalIndex = ::frameIndex
|
unsigned logicalIndex = ::frameIndex
|
||||||
(c, s->index + c->localFootprint);
|
(c, s->index + c->localFootprint);
|
||||||
|
|
||||||
@ -2405,7 +2418,7 @@ class CallEvent: public Event {
|
|||||||
|
|
||||||
-- footprint;
|
-- footprint;
|
||||||
|
|
||||||
if (footprint == 0) {
|
if (footprint == 0 and (flags & Compiler::TailJump) == 0) {
|
||||||
unsigned logicalIndex = ::frameIndex
|
unsigned logicalIndex = ::frameIndex
|
||||||
(c, s->index + c->localFootprint);
|
(c, s->index + c->localFootprint);
|
||||||
|
|
||||||
@ -2418,7 +2431,7 @@ class CallEvent: public Event {
|
|||||||
++ frameIndex;
|
++ frameIndex;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((flags & (Compiler::TailJump | Compiler::TailCall)) == 0) {
|
if ((flags & Compiler::TailJump) == 0) {
|
||||||
popIndex
|
popIndex
|
||||||
= c->alignedFrameSize
|
= c->alignedFrameSize
|
||||||
- c->arch->frameFooterSize()
|
- c->arch->frameFooterSize()
|
||||||
@ -2438,20 +2451,12 @@ class CallEvent: public Event {
|
|||||||
virtual void compile(Context* c) {
|
virtual void compile(Context* c) {
|
||||||
UnaryOperation op;
|
UnaryOperation op;
|
||||||
|
|
||||||
if (flags & (Compiler::TailJump | Compiler::TailCall)) {
|
|
||||||
if (flags & Compiler::TailJump) {
|
if (flags & Compiler::TailJump) {
|
||||||
if (flags & Compiler::Aligned) {
|
if (flags & Compiler::Aligned) {
|
||||||
op = AlignedJump;
|
op = AlignedJump;
|
||||||
} else {
|
} else {
|
||||||
op = Jump;
|
op = Jump;
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
if (flags & Compiler::Aligned) {
|
|
||||||
op = AlignedCall;
|
|
||||||
} else {
|
|
||||||
op = Call;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
assert(c, returnAddressSurrogate == 0
|
assert(c, returnAddressSurrogate == 0
|
||||||
or returnAddressSurrogate->source->type(c) == RegisterOperand);
|
or returnAddressSurrogate->source->type(c) == RegisterOperand);
|
||||||
@ -2464,8 +2469,8 @@ class CallEvent: public Event {
|
|||||||
(framePointerSurrogate->source)->number : NoRegister);
|
(framePointerSurrogate->source)->number : NoRegister);
|
||||||
|
|
||||||
int offset
|
int offset
|
||||||
= static_cast<int>(c->arch->argumentFootprint(c->parameterFootprint))
|
= static_cast<int>(c->arch->argumentFootprint(stackArgumentFootprint))
|
||||||
- static_cast<int>(c->arch->argumentFootprint(stackArgumentFootprint));
|
- static_cast<int>(c->arch->argumentFootprint(c->parameterFootprint));
|
||||||
|
|
||||||
c->assembler->popFrameForTailCall(c->alignedFrameSize, offset, ras, fps);
|
c->assembler->popFrameForTailCall(c->alignedFrameSize, offset, ras, fps);
|
||||||
} else if (flags & Compiler::Aligned) {
|
} else if (flags & Compiler::Aligned) {
|
||||||
@ -4920,7 +4925,7 @@ class MyCompiler: public Compiler {
|
|||||||
new (c.frameResources + i) FrameResource;
|
new (c.frameResources + i) FrameResource;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned base = alignedFrameSize - c.arch->frameFooterSize();
|
unsigned base = frameBase(&c);
|
||||||
c.frameResources[base + c.arch->returnAddressOffset()].reserved = true;
|
c.frameResources[base + c.arch->returnAddressOffset()].reserved = true;
|
||||||
c.frameResources[base + c.arch->framePointerOffset()].reserved = true;
|
c.frameResources[base + c.arch->framePointerOffset()].reserved = true;
|
||||||
|
|
||||||
|
@ -27,8 +27,7 @@ class Compiler {
|
|||||||
|
|
||||||
static const unsigned Aligned = 1 << 0;
|
static const unsigned Aligned = 1 << 0;
|
||||||
static const unsigned NoReturn = 1 << 1;
|
static const unsigned NoReturn = 1 << 1;
|
||||||
static const unsigned TailCall = 1 << 2;
|
static const unsigned TailJump = 1 << 2;
|
||||||
static const unsigned TailJump = 1 << 3;
|
|
||||||
|
|
||||||
class Operand { };
|
class Operand { };
|
||||||
class StackElement { };
|
class StackElement { };
|
||||||
|
26
src/x86.cpp
26
src/x86.cpp
@ -673,6 +673,13 @@ alignedCallC(Context* c, unsigned size, Assembler::Constant* a)
|
|||||||
callC(c, size, a);
|
callC(c, size, a);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
alignedJumpC(Context* c, unsigned size, Assembler::Constant* a)
|
||||||
|
{
|
||||||
|
new (c->zone->allocate(sizeof(AlignmentPadding))) AlignmentPadding(c);
|
||||||
|
jumpC(c, size, a);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
pushR(Context* c, unsigned size, Assembler::Register* a)
|
pushR(Context* c, unsigned size, Assembler::Register* a)
|
||||||
{
|
{
|
||||||
@ -1938,6 +1945,8 @@ populateTables(ArchitectureContext* c)
|
|||||||
uo[index(Jump, C)] = CAST1(jumpC);
|
uo[index(Jump, C)] = CAST1(jumpC);
|
||||||
uo[index(Jump, M)] = CAST1(jumpM);
|
uo[index(Jump, M)] = CAST1(jumpM);
|
||||||
|
|
||||||
|
uo[index(AlignedJump, C)] = CAST1(alignedJumpC);
|
||||||
|
|
||||||
uo[index(JumpIfEqual, C)] = CAST1(jumpIfEqualC);
|
uo[index(JumpIfEqual, C)] = CAST1(jumpIfEqualC);
|
||||||
uo[index(JumpIfNotEqual, C)] = CAST1(jumpIfNotEqualC);
|
uo[index(JumpIfNotEqual, C)] = CAST1(jumpIfNotEqualC);
|
||||||
uo[index(JumpIfGreater, C)] = CAST1(jumpIfGreaterC);
|
uo[index(JumpIfGreater, C)] = CAST1(jumpIfGreaterC);
|
||||||
@ -2126,10 +2135,6 @@ class MyArchitecture: public Assembler::Architecture {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual unsigned constantCallSize() {
|
|
||||||
return 5;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual uintptr_t getConstant(const void* src) {
|
virtual uintptr_t getConstant(const void* src) {
|
||||||
uintptr_t v;
|
uintptr_t v;
|
||||||
memcpy(&v, src, BytesPerWord);
|
memcpy(&v, src, BytesPerWord);
|
||||||
@ -2162,12 +2167,12 @@ class MyArchitecture: public Assembler::Architecture {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual unsigned returnAddressOffset() {
|
virtual int returnAddressOffset() {
|
||||||
return 1;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual unsigned framePointerOffset() {
|
virtual int framePointerOffset() {
|
||||||
return 0;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void nextFrame(void** stack, void** base) {
|
virtual void nextFrame(void** stack, void** base) {
|
||||||
@ -2427,12 +2432,13 @@ class MyAssembler: public Assembler {
|
|||||||
|
|
||||||
c.client->releaseTemporary(tmp.low);
|
c.client->releaseTemporary(tmp.low);
|
||||||
|
|
||||||
Memory baseSrc(rbp, footprint * BytesPerWord);
|
Memory baseSrc(rsp, footprint * BytesPerWord);
|
||||||
Register base(rbp);
|
Register base(rbp);
|
||||||
moveMR(&c, BytesPerWord, &baseSrc, BytesPerWord, &base);
|
moveMR(&c, BytesPerWord, &baseSrc, BytesPerWord, &base);
|
||||||
|
|
||||||
Register stack(rsp);
|
Register stack(rsp);
|
||||||
Constant footprintConstant(resolved(&c, footprint * BytesPerWord));
|
Constant footprintConstant
|
||||||
|
(resolved(&c, (footprint - offset + 1) * BytesPerWord));
|
||||||
addCR(&c, BytesPerWord, &footprintConstant, BytesPerWord, &stack);
|
addCR(&c, BytesPerWord, &footprintConstant, BytesPerWord, &stack);
|
||||||
|
|
||||||
if (returnAddressSurrogate != NoRegister) {
|
if (returnAddressSurrogate != NoRegister) {
|
||||||
|
Loading…
Reference in New Issue
Block a user