mirror of
https://github.com/corda/corda.git
synced 2025-01-23 04:48:09 +00:00
rename lir::Register to lir::RegisterPair
This commit is contained in:
parent
10442dc7d6
commit
02d1a83ad9
@ -149,9 +149,9 @@ class Address : public Operand {
|
|||||||
Promise* address;
|
Promise* address;
|
||||||
};
|
};
|
||||||
|
|
||||||
class Register : public Operand {
|
class RegisterPair : public Operand {
|
||||||
public:
|
public:
|
||||||
Register(int low, int high = NoRegister) : low(low), high(high)
|
RegisterPair(int low, int high = NoRegister) : low(low), high(high)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -349,7 +349,7 @@ void RegisterSite::asAssemblerOperand(Context* c UNUSED,
|
|||||||
highNumber = lir::NoRegister;
|
highNumber = lir::NoRegister;
|
||||||
}
|
}
|
||||||
|
|
||||||
new (result) lir::Register(number, highNumber);
|
new (result) lir::RegisterPair(number, highNumber);
|
||||||
}
|
}
|
||||||
|
|
||||||
Site* RegisterSite::copy(Context* c)
|
Site* RegisterSite::copy(Context* c)
|
||||||
|
@ -656,7 +656,7 @@ class MyAssembler : public Assembler {
|
|||||||
virtual void checkStackOverflow(uintptr_t handler,
|
virtual void checkStackOverflow(uintptr_t handler,
|
||||||
unsigned stackLimitOffsetFromThread)
|
unsigned stackLimitOffsetFromThread)
|
||||||
{
|
{
|
||||||
lir::Register stack(StackRegister);
|
lir::RegisterPair stack(StackRegister);
|
||||||
lir::Memory stackLimit(ThreadRegister, stackLimitOffsetFromThread);
|
lir::Memory stackLimit(ThreadRegister, stackLimitOffsetFromThread);
|
||||||
lir::Constant handlerConstant(new (con.zone) ResolvedPromise(handler));
|
lir::Constant handlerConstant(new (con.zone) ResolvedPromise(handler));
|
||||||
branchRM(&con,
|
branchRM(&con,
|
||||||
@ -669,11 +669,11 @@ class MyAssembler : public Assembler {
|
|||||||
|
|
||||||
virtual void saveFrame(unsigned stackOffset, unsigned ipOffset)
|
virtual void saveFrame(unsigned stackOffset, unsigned ipOffset)
|
||||||
{
|
{
|
||||||
lir::Register link(LinkRegister);
|
lir::RegisterPair link(LinkRegister);
|
||||||
lir::Memory linkDst(ThreadRegister, ipOffset);
|
lir::Memory linkDst(ThreadRegister, ipOffset);
|
||||||
moveRM(&con, TargetBytesPerWord, &link, TargetBytesPerWord, &linkDst);
|
moveRM(&con, TargetBytesPerWord, &link, TargetBytesPerWord, &linkDst);
|
||||||
|
|
||||||
lir::Register stack(StackRegister);
|
lir::RegisterPair stack(StackRegister);
|
||||||
lir::Memory stackDst(ThreadRegister, stackOffset);
|
lir::Memory stackDst(ThreadRegister, stackOffset);
|
||||||
moveRM(&con, TargetBytesPerWord, &stack, TargetBytesPerWord, &stackDst);
|
moveRM(&con, TargetBytesPerWord, &stack, TargetBytesPerWord, &stackDst);
|
||||||
}
|
}
|
||||||
@ -705,7 +705,7 @@ class MyAssembler : public Assembler {
|
|||||||
unsigned offset = 0;
|
unsigned offset = 0;
|
||||||
for (unsigned i = 0; i < argumentCount; ++i) {
|
for (unsigned i = 0; i < argumentCount; ++i) {
|
||||||
if (i < arch_->argumentRegisterCount()) {
|
if (i < arch_->argumentRegisterCount()) {
|
||||||
lir::Register dst(arch_->argumentRegister(i));
|
lir::RegisterPair dst(arch_->argumentRegister(i));
|
||||||
|
|
||||||
apply(lir::Move,
|
apply(lir::Move,
|
||||||
OperandInfo(RUNTIME_ARRAY_BODY(arguments)[i].size,
|
OperandInfo(RUNTIME_ARRAY_BODY(arguments)[i].size,
|
||||||
@ -745,12 +745,12 @@ class MyAssembler : public Assembler {
|
|||||||
// how to handle them:
|
// how to handle them:
|
||||||
assertT(&con, footprint < 256);
|
assertT(&con, footprint < 256);
|
||||||
|
|
||||||
lir::Register stack(StackRegister);
|
lir::RegisterPair stack(StackRegister);
|
||||||
ResolvedPromise footprintPromise(footprint * TargetBytesPerWord);
|
ResolvedPromise footprintPromise(footprint * TargetBytesPerWord);
|
||||||
lir::Constant footprintConstant(&footprintPromise);
|
lir::Constant footprintConstant(&footprintPromise);
|
||||||
subC(&con, TargetBytesPerWord, &footprintConstant, &stack, &stack);
|
subC(&con, TargetBytesPerWord, &footprintConstant, &stack, &stack);
|
||||||
|
|
||||||
lir::Register returnAddress(LinkRegister);
|
lir::RegisterPair returnAddress(LinkRegister);
|
||||||
lir::Memory returnAddressDst(StackRegister,
|
lir::Memory returnAddressDst(StackRegister,
|
||||||
(footprint - 1) * TargetBytesPerWord);
|
(footprint - 1) * TargetBytesPerWord);
|
||||||
moveRM(&con,
|
moveRM(&con,
|
||||||
@ -762,7 +762,7 @@ class MyAssembler : public Assembler {
|
|||||||
|
|
||||||
virtual void adjustFrame(unsigned difference)
|
virtual void adjustFrame(unsigned difference)
|
||||||
{
|
{
|
||||||
lir::Register stack(StackRegister);
|
lir::RegisterPair stack(StackRegister);
|
||||||
ResolvedPromise differencePromise(difference * TargetBytesPerWord);
|
ResolvedPromise differencePromise(difference * TargetBytesPerWord);
|
||||||
lir::Constant differenceConstant(&differencePromise);
|
lir::Constant differenceConstant(&differencePromise);
|
||||||
subC(&con, TargetBytesPerWord, &differenceConstant, &stack, &stack);
|
subC(&con, TargetBytesPerWord, &differenceConstant, &stack, &stack);
|
||||||
@ -772,7 +772,7 @@ class MyAssembler : public Assembler {
|
|||||||
{
|
{
|
||||||
footprint += FrameHeaderSize;
|
footprint += FrameHeaderSize;
|
||||||
|
|
||||||
lir::Register returnAddress(LinkRegister);
|
lir::RegisterPair returnAddress(LinkRegister);
|
||||||
lir::Memory returnAddressSrc(StackRegister,
|
lir::Memory returnAddressSrc(StackRegister,
|
||||||
(footprint - 1) * TargetBytesPerWord);
|
(footprint - 1) * TargetBytesPerWord);
|
||||||
moveMR(&con,
|
moveMR(&con,
|
||||||
@ -781,7 +781,7 @@ class MyAssembler : public Assembler {
|
|||||||
TargetBytesPerWord,
|
TargetBytesPerWord,
|
||||||
&returnAddress);
|
&returnAddress);
|
||||||
|
|
||||||
lir::Register stack(StackRegister);
|
lir::RegisterPair stack(StackRegister);
|
||||||
ResolvedPromise footprintPromise(footprint * TargetBytesPerWord);
|
ResolvedPromise footprintPromise(footprint * TargetBytesPerWord);
|
||||||
lir::Constant footprintConstant(&footprintPromise);
|
lir::Constant footprintConstant(&footprintPromise);
|
||||||
addC(&con, TargetBytesPerWord, &footprintConstant, &stack, &stack);
|
addC(&con, TargetBytesPerWord, &footprintConstant, &stack, &stack);
|
||||||
@ -798,7 +798,7 @@ class MyAssembler : public Assembler {
|
|||||||
if (offset) {
|
if (offset) {
|
||||||
footprint += FrameHeaderSize;
|
footprint += FrameHeaderSize;
|
||||||
|
|
||||||
lir::Register link(LinkRegister);
|
lir::RegisterPair link(LinkRegister);
|
||||||
lir::Memory returnAddressSrc(StackRegister,
|
lir::Memory returnAddressSrc(StackRegister,
|
||||||
(footprint - 1) * TargetBytesPerWord);
|
(footprint - 1) * TargetBytesPerWord);
|
||||||
moveMR(&con,
|
moveMR(&con,
|
||||||
@ -807,7 +807,7 @@ class MyAssembler : public Assembler {
|
|||||||
TargetBytesPerWord,
|
TargetBytesPerWord,
|
||||||
&link);
|
&link);
|
||||||
|
|
||||||
lir::Register stack(StackRegister);
|
lir::RegisterPair stack(StackRegister);
|
||||||
ResolvedPromise footprintPromise((footprint - offset)
|
ResolvedPromise footprintPromise((footprint - offset)
|
||||||
* TargetBytesPerWord);
|
* TargetBytesPerWord);
|
||||||
lir::Constant footprintConstant(&footprintPromise);
|
lir::Constant footprintConstant(&footprintPromise);
|
||||||
@ -816,7 +816,7 @@ class MyAssembler : public Assembler {
|
|||||||
if (returnAddressSurrogate != lir::NoRegister) {
|
if (returnAddressSurrogate != lir::NoRegister) {
|
||||||
assertT(&con, offset > 0);
|
assertT(&con, offset > 0);
|
||||||
|
|
||||||
lir::Register ras(returnAddressSurrogate);
|
lir::RegisterPair ras(returnAddressSurrogate);
|
||||||
lir::Memory dst(StackRegister, (offset - 1) * TargetBytesPerWord);
|
lir::Memory dst(StackRegister, (offset - 1) * TargetBytesPerWord);
|
||||||
moveRM(&con, TargetBytesPerWord, &ras, TargetBytesPerWord, &dst);
|
moveRM(&con, TargetBytesPerWord, &ras, TargetBytesPerWord, &dst);
|
||||||
}
|
}
|
||||||
@ -840,7 +840,7 @@ class MyAssembler : public Assembler {
|
|||||||
if (TailCalls and argumentFootprint > StackAlignmentInWords) {
|
if (TailCalls and argumentFootprint > StackAlignmentInWords) {
|
||||||
offset = argumentFootprint - StackAlignmentInWords;
|
offset = argumentFootprint - StackAlignmentInWords;
|
||||||
|
|
||||||
lir::Register stack(StackRegister);
|
lir::RegisterPair stack(StackRegister);
|
||||||
ResolvedPromise adjustmentPromise(offset * TargetBytesPerWord);
|
ResolvedPromise adjustmentPromise(offset * TargetBytesPerWord);
|
||||||
lir::Constant adjustment(&adjustmentPromise);
|
lir::Constant adjustment(&adjustmentPromise);
|
||||||
addC(&con, TargetBytesPerWord, &adjustment, &stack, &stack);
|
addC(&con, TargetBytesPerWord, &adjustment, &stack, &stack);
|
||||||
@ -856,7 +856,7 @@ class MyAssembler : public Assembler {
|
|||||||
{
|
{
|
||||||
popFrame(frameFootprint);
|
popFrame(frameFootprint);
|
||||||
|
|
||||||
lir::Register stack(StackRegister);
|
lir::RegisterPair stack(StackRegister);
|
||||||
lir::Memory newStackSrc(ThreadRegister, stackOffsetFromThread);
|
lir::Memory newStackSrc(ThreadRegister, stackOffsetFromThread);
|
||||||
moveMR(&con, TargetBytesPerWord, &newStackSrc, TargetBytesPerWord, &stack);
|
moveMR(&con, TargetBytesPerWord, &newStackSrc, TargetBytesPerWord, &stack);
|
||||||
|
|
||||||
|
@ -35,20 +35,20 @@ inline unsigned lo8(int64_t i)
|
|||||||
void andC(Context* con,
|
void andC(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* dst);
|
lir::RegisterPair* dst);
|
||||||
|
|
||||||
void shiftLeftR(Context* con,
|
void shiftLeftR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t)
|
lir::RegisterPair* t)
|
||||||
{
|
{
|
||||||
if (size == 8) {
|
if (size == 8) {
|
||||||
int tmp1 = newTemp(con), tmp2 = newTemp(con), tmp3 = newTemp(con);
|
int tmp1 = newTemp(con), tmp2 = newTemp(con), tmp3 = newTemp(con);
|
||||||
ResolvedPromise maskPromise(0x3F);
|
ResolvedPromise maskPromise(0x3F);
|
||||||
lir::Constant mask(&maskPromise);
|
lir::Constant mask(&maskPromise);
|
||||||
lir::Register dst(tmp3);
|
lir::RegisterPair dst(tmp3);
|
||||||
andC(con, 4, &mask, a, &dst);
|
andC(con, 4, &mask, a, &dst);
|
||||||
emit(con, lsl(tmp1, b->high, tmp3));
|
emit(con, lsl(tmp1, b->high, tmp3));
|
||||||
emit(con, rsbi(tmp2, tmp3, 32));
|
emit(con, rsbi(tmp2, tmp3, 32));
|
||||||
@ -64,7 +64,7 @@ void shiftLeftR(Context* con,
|
|||||||
int tmp = newTemp(con);
|
int tmp = newTemp(con);
|
||||||
ResolvedPromise maskPromise(0x1F);
|
ResolvedPromise maskPromise(0x1F);
|
||||||
lir::Constant mask(&maskPromise);
|
lir::Constant mask(&maskPromise);
|
||||||
lir::Register dst(tmp);
|
lir::RegisterPair dst(tmp);
|
||||||
andC(con, size, &mask, a, &dst);
|
andC(con, size, &mask, a, &dst);
|
||||||
emit(con, lsl(t->low, b->low, tmp));
|
emit(con, lsl(t->low, b->low, tmp));
|
||||||
freeTemp(con, tmp);
|
freeTemp(con, tmp);
|
||||||
@ -73,15 +73,15 @@ void shiftLeftR(Context* con,
|
|||||||
|
|
||||||
void moveRR(Context* con,
|
void moveRR(Context* con,
|
||||||
unsigned srcSize,
|
unsigned srcSize,
|
||||||
lir::Register* src,
|
lir::RegisterPair* src,
|
||||||
unsigned dstSize,
|
unsigned dstSize,
|
||||||
lir::Register* dst);
|
lir::RegisterPair* dst);
|
||||||
|
|
||||||
void shiftLeftC(Context* con,
|
void shiftLeftC(Context* con,
|
||||||
unsigned size UNUSED,
|
unsigned size UNUSED,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t)
|
lir::RegisterPair* t)
|
||||||
{
|
{
|
||||||
assertT(con, size == vm::TargetBytesPerWord);
|
assertT(con, size == vm::TargetBytesPerWord);
|
||||||
if (getValue(a) & 0x1F) {
|
if (getValue(a) & 0x1F) {
|
||||||
@ -93,15 +93,15 @@ void shiftLeftC(Context* con,
|
|||||||
|
|
||||||
void shiftRightR(Context* con,
|
void shiftRightR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t)
|
lir::RegisterPair* t)
|
||||||
{
|
{
|
||||||
if (size == 8) {
|
if (size == 8) {
|
||||||
int tmp1 = newTemp(con), tmp2 = newTemp(con), tmp3 = newTemp(con);
|
int tmp1 = newTemp(con), tmp2 = newTemp(con), tmp3 = newTemp(con);
|
||||||
ResolvedPromise maskPromise(0x3F);
|
ResolvedPromise maskPromise(0x3F);
|
||||||
lir::Constant mask(&maskPromise);
|
lir::Constant mask(&maskPromise);
|
||||||
lir::Register dst(tmp3);
|
lir::RegisterPair dst(tmp3);
|
||||||
andC(con, 4, &mask, a, &dst);
|
andC(con, 4, &mask, a, &dst);
|
||||||
emit(con, lsr(tmp1, b->low, tmp3));
|
emit(con, lsr(tmp1, b->low, tmp3));
|
||||||
emit(con, rsbi(tmp2, tmp3, 32));
|
emit(con, rsbi(tmp2, tmp3, 32));
|
||||||
@ -117,7 +117,7 @@ void shiftRightR(Context* con,
|
|||||||
int tmp = newTemp(con);
|
int tmp = newTemp(con);
|
||||||
ResolvedPromise maskPromise(0x1F);
|
ResolvedPromise maskPromise(0x1F);
|
||||||
lir::Constant mask(&maskPromise);
|
lir::Constant mask(&maskPromise);
|
||||||
lir::Register dst(tmp);
|
lir::RegisterPair dst(tmp);
|
||||||
andC(con, size, &mask, a, &dst);
|
andC(con, size, &mask, a, &dst);
|
||||||
emit(con, asr(t->low, b->low, tmp));
|
emit(con, asr(t->low, b->low, tmp));
|
||||||
freeTemp(con, tmp);
|
freeTemp(con, tmp);
|
||||||
@ -127,8 +127,8 @@ void shiftRightR(Context* con,
|
|||||||
void shiftRightC(Context* con,
|
void shiftRightC(Context* con,
|
||||||
unsigned size UNUSED,
|
unsigned size UNUSED,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t)
|
lir::RegisterPair* t)
|
||||||
{
|
{
|
||||||
assertT(con, size == vm::TargetBytesPerWord);
|
assertT(con, size == vm::TargetBytesPerWord);
|
||||||
if (getValue(a) & 0x1F) {
|
if (getValue(a) & 0x1F) {
|
||||||
@ -140,14 +140,14 @@ void shiftRightC(Context* con,
|
|||||||
|
|
||||||
void unsignedShiftRightR(Context* con,
|
void unsignedShiftRightR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t)
|
lir::RegisterPair* t)
|
||||||
{
|
{
|
||||||
int tmpShift = newTemp(con);
|
int tmpShift = newTemp(con);
|
||||||
ResolvedPromise maskPromise(size == 8 ? 0x3F : 0x1F);
|
ResolvedPromise maskPromise(size == 8 ? 0x3F : 0x1F);
|
||||||
lir::Constant mask(&maskPromise);
|
lir::Constant mask(&maskPromise);
|
||||||
lir::Register dst(tmpShift);
|
lir::RegisterPair dst(tmpShift);
|
||||||
andC(con, 4, &mask, a, &dst);
|
andC(con, 4, &mask, a, &dst);
|
||||||
emit(con, lsr(t->low, b->low, tmpShift));
|
emit(con, lsr(t->low, b->low, tmpShift));
|
||||||
if (size == 8) {
|
if (size == 8) {
|
||||||
@ -168,8 +168,8 @@ void unsignedShiftRightR(Context* con,
|
|||||||
void unsignedShiftRightC(Context* con,
|
void unsignedShiftRightC(Context* con,
|
||||||
unsigned size UNUSED,
|
unsigned size UNUSED,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t)
|
lir::RegisterPair* t)
|
||||||
{
|
{
|
||||||
assertT(con, size == vm::TargetBytesPerWord);
|
assertT(con, size == vm::TargetBytesPerWord);
|
||||||
if (getValue(a) & 0x1F) {
|
if (getValue(a) & 0x1F) {
|
||||||
@ -274,7 +274,7 @@ void resolve(MyBlock* b)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void jumpR(Context* con, unsigned size UNUSED, lir::Register* target)
|
void jumpR(Context* con, unsigned size UNUSED, lir::RegisterPair* target)
|
||||||
{
|
{
|
||||||
assertT(con, size == vm::TargetBytesPerWord);
|
assertT(con, size == vm::TargetBytesPerWord);
|
||||||
emit(con, bx(target->low));
|
emit(con, bx(target->low));
|
||||||
@ -282,14 +282,14 @@ void jumpR(Context* con, unsigned size UNUSED, lir::Register* target)
|
|||||||
|
|
||||||
void swapRR(Context* con,
|
void swapRR(Context* con,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(con, aSize == vm::TargetBytesPerWord);
|
assertT(con, aSize == vm::TargetBytesPerWord);
|
||||||
assertT(con, bSize == vm::TargetBytesPerWord);
|
assertT(con, bSize == vm::TargetBytesPerWord);
|
||||||
|
|
||||||
lir::Register tmp(con->client->acquireTemporary(GPR_MASK));
|
lir::RegisterPair tmp(con->client->acquireTemporary(GPR_MASK));
|
||||||
moveRR(con, aSize, a, bSize, &tmp);
|
moveRR(con, aSize, a, bSize, &tmp);
|
||||||
moveRR(con, bSize, b, aSize, a);
|
moveRR(con, bSize, b, aSize, a);
|
||||||
moveRR(con, bSize, &tmp, bSize, b);
|
moveRR(con, bSize, &tmp, bSize, b);
|
||||||
@ -298,9 +298,9 @@ void swapRR(Context* con,
|
|||||||
|
|
||||||
void moveRR(Context* con,
|
void moveRR(Context* con,
|
||||||
unsigned srcSize,
|
unsigned srcSize,
|
||||||
lir::Register* src,
|
lir::RegisterPair* src,
|
||||||
unsigned dstSize,
|
unsigned dstSize,
|
||||||
lir::Register* dst)
|
lir::RegisterPair* dst)
|
||||||
{
|
{
|
||||||
bool srcIsFpr = isFpr(src);
|
bool srcIsFpr = isFpr(src);
|
||||||
bool dstIsFpr = isFpr(dst);
|
bool dstIsFpr = isFpr(dst);
|
||||||
@ -343,8 +343,8 @@ void moveRR(Context* con,
|
|||||||
moveRR(con, 4, src, 4, dst);
|
moveRR(con, 4, src, 4, dst);
|
||||||
emit(con, asri(dst->high, src->low, 31));
|
emit(con, asri(dst->high, src->low, 31));
|
||||||
} else if (srcSize == 8 and dstSize == 8) {
|
} else if (srcSize == 8 and dstSize == 8) {
|
||||||
lir::Register srcHigh(src->high);
|
lir::RegisterPair srcHigh(src->high);
|
||||||
lir::Register dstHigh(dst->high);
|
lir::RegisterPair dstHigh(dst->high);
|
||||||
|
|
||||||
if (src->high == dst->low) {
|
if (src->high == dst->low) {
|
||||||
if (src->low == dst->high) {
|
if (src->low == dst->high) {
|
||||||
@ -369,9 +369,9 @@ void moveRR(Context* con,
|
|||||||
|
|
||||||
void moveZRR(Context* con,
|
void moveZRR(Context* con,
|
||||||
unsigned srcSize,
|
unsigned srcSize,
|
||||||
lir::Register* src,
|
lir::RegisterPair* src,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register* dst)
|
lir::RegisterPair* dst)
|
||||||
{
|
{
|
||||||
switch (srcSize) {
|
switch (srcSize) {
|
||||||
case 2:
|
case 2:
|
||||||
@ -388,16 +388,16 @@ void moveCR(Context* con,
|
|||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Constant* src,
|
lir::Constant* src,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register* dst);
|
lir::RegisterPair* dst);
|
||||||
|
|
||||||
void moveCR2(Context* con,
|
void moveCR2(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Constant* src,
|
lir::Constant* src,
|
||||||
lir::Register* dst,
|
lir::RegisterPair* dst,
|
||||||
Promise* callOffset)
|
Promise* callOffset)
|
||||||
{
|
{
|
||||||
if (isFpr(dst)) { // floating-point
|
if (isFpr(dst)) { // floating-point
|
||||||
lir::Register tmp = size > 4 ? makeTemp64(con) : makeTemp(con);
|
lir::RegisterPair tmp = size > 4 ? makeTemp64(con) : makeTemp(con);
|
||||||
moveCR(con, size, src, size, &tmp);
|
moveCR(con, size, src, size, &tmp);
|
||||||
moveRR(con, size, &tmp, size, dst);
|
moveRR(con, size, &tmp, size, dst);
|
||||||
freeTemp(con, tmp);
|
freeTemp(con, tmp);
|
||||||
@ -407,7 +407,7 @@ void moveCR2(Context* con,
|
|||||||
lir::Constant srcLo(&loBits);
|
lir::Constant srcLo(&loBits);
|
||||||
ResolvedPromise hiBits(value >> 32);
|
ResolvedPromise hiBits(value >> 32);
|
||||||
lir::Constant srcHi(&hiBits);
|
lir::Constant srcHi(&hiBits);
|
||||||
lir::Register dstHi(dst->high);
|
lir::RegisterPair dstHi(dst->high);
|
||||||
moveCR(con, 4, &srcLo, 4, dst);
|
moveCR(con, 4, &srcLo, 4, dst);
|
||||||
moveCR(con, 4, &srcHi, 4, &dstHi);
|
moveCR(con, 4, &srcHi, 4, &dstHi);
|
||||||
} else if (src->value->resolved() and isOfWidth(getValue(src), 8)) {
|
} else if (src->value->resolved() and isOfWidth(getValue(src), 8)) {
|
||||||
@ -422,16 +422,16 @@ void moveCR(Context* con,
|
|||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Constant* src,
|
lir::Constant* src,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register* dst)
|
lir::RegisterPair* dst)
|
||||||
{
|
{
|
||||||
moveCR2(con, size, src, dst, 0);
|
moveCR2(con, size, src, dst, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void addR(Context* con,
|
void addR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t)
|
lir::RegisterPair* t)
|
||||||
{
|
{
|
||||||
if (size == 8) {
|
if (size == 8) {
|
||||||
emit(con, SETS(add(t->low, a->low, b->low)));
|
emit(con, SETS(add(t->low, a->low, b->low)));
|
||||||
@ -443,9 +443,9 @@ void addR(Context* con,
|
|||||||
|
|
||||||
void subR(Context* con,
|
void subR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t)
|
lir::RegisterPair* t)
|
||||||
{
|
{
|
||||||
if (size == 8) {
|
if (size == 8) {
|
||||||
emit(con, SETS(rsb(t->low, a->low, b->low)));
|
emit(con, SETS(rsb(t->low, a->low, b->low)));
|
||||||
@ -458,8 +458,8 @@ void subR(Context* con,
|
|||||||
void addC(Context* con,
|
void addC(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* dst)
|
lir::RegisterPair* dst)
|
||||||
{
|
{
|
||||||
assertT(con, size == vm::TargetBytesPerWord);
|
assertT(con, size == vm::TargetBytesPerWord);
|
||||||
|
|
||||||
@ -481,8 +481,8 @@ void addC(Context* con,
|
|||||||
void subC(Context* con,
|
void subC(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* dst)
|
lir::RegisterPair* dst)
|
||||||
{
|
{
|
||||||
assertT(con, size == vm::TargetBytesPerWord);
|
assertT(con, size == vm::TargetBytesPerWord);
|
||||||
|
|
||||||
@ -503,9 +503,9 @@ void subC(Context* con,
|
|||||||
|
|
||||||
void multiplyR(Context* con,
|
void multiplyR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t)
|
lir::RegisterPair* t)
|
||||||
{
|
{
|
||||||
if (size == 8) {
|
if (size == 8) {
|
||||||
bool useTemporaries = b->low == t->low;
|
bool useTemporaries = b->low == t->low;
|
||||||
@ -531,9 +531,9 @@ void multiplyR(Context* con,
|
|||||||
|
|
||||||
void floatAbsoluteRR(Context* con,
|
void floatAbsoluteRR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
if (size == 8) {
|
if (size == 8) {
|
||||||
emit(con, fabsd(fpr64(b), fpr64(a)));
|
emit(con, fabsd(fpr64(b), fpr64(a)));
|
||||||
@ -544,9 +544,9 @@ void floatAbsoluteRR(Context* con,
|
|||||||
|
|
||||||
void floatNegateRR(Context* con,
|
void floatNegateRR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
if (size == 8) {
|
if (size == 8) {
|
||||||
emit(con, fnegd(fpr64(b), fpr64(a)));
|
emit(con, fnegd(fpr64(b), fpr64(a)));
|
||||||
@ -557,9 +557,9 @@ void floatNegateRR(Context* con,
|
|||||||
|
|
||||||
void float2FloatRR(Context* con,
|
void float2FloatRR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
if (size == 8) {
|
if (size == 8) {
|
||||||
emit(con, fcvtsd(fpr32(b), fpr64(a)));
|
emit(con, fcvtsd(fpr32(b), fpr64(a)));
|
||||||
@ -570,9 +570,9 @@ void float2FloatRR(Context* con,
|
|||||||
|
|
||||||
void float2IntRR(Context* con,
|
void float2IntRR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
int tmp = newTemp(con, FPR_MASK);
|
int tmp = newTemp(con, FPR_MASK);
|
||||||
int ftmp = fpr32(tmp);
|
int ftmp = fpr32(tmp);
|
||||||
@ -587,9 +587,9 @@ void float2IntRR(Context* con,
|
|||||||
|
|
||||||
void int2FloatRR(Context* con,
|
void int2FloatRR(Context* con,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
emit(con, fmsr(fpr32(b), a->low));
|
emit(con, fmsr(fpr32(b), a->low));
|
||||||
if (size == 8) { // int to double
|
if (size == 8) { // int to double
|
||||||
@ -601,9 +601,9 @@ void int2FloatRR(Context* con,
|
|||||||
|
|
||||||
void floatSqrtRR(Context* con,
|
void floatSqrtRR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
if (size == 8) {
|
if (size == 8) {
|
||||||
emit(con, fsqrtd(fpr64(b), fpr64(a)));
|
emit(con, fsqrtd(fpr64(b), fpr64(a)));
|
||||||
@ -614,9 +614,9 @@ void floatSqrtRR(Context* con,
|
|||||||
|
|
||||||
void floatAddR(Context* con,
|
void floatAddR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t)
|
lir::RegisterPair* t)
|
||||||
{
|
{
|
||||||
if (size == 8) {
|
if (size == 8) {
|
||||||
emit(con, faddd(fpr64(t), fpr64(a), fpr64(b)));
|
emit(con, faddd(fpr64(t), fpr64(a), fpr64(b)));
|
||||||
@ -627,9 +627,9 @@ void floatAddR(Context* con,
|
|||||||
|
|
||||||
void floatSubtractR(Context* con,
|
void floatSubtractR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t)
|
lir::RegisterPair* t)
|
||||||
{
|
{
|
||||||
if (size == 8) {
|
if (size == 8) {
|
||||||
emit(con, fsubd(fpr64(t), fpr64(b), fpr64(a)));
|
emit(con, fsubd(fpr64(t), fpr64(b), fpr64(a)));
|
||||||
@ -640,9 +640,9 @@ void floatSubtractR(Context* con,
|
|||||||
|
|
||||||
void floatMultiplyR(Context* con,
|
void floatMultiplyR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t)
|
lir::RegisterPair* t)
|
||||||
{
|
{
|
||||||
if (size == 8) {
|
if (size == 8) {
|
||||||
emit(con, fmuld(fpr64(t), fpr64(a), fpr64(b)));
|
emit(con, fmuld(fpr64(t), fpr64(a), fpr64(b)));
|
||||||
@ -653,9 +653,9 @@ void floatMultiplyR(Context* con,
|
|||||||
|
|
||||||
void floatDivideR(Context* con,
|
void floatDivideR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t)
|
lir::RegisterPair* t)
|
||||||
{
|
{
|
||||||
if (size == 8) {
|
if (size == 8) {
|
||||||
emit(con, fdivd(fpr64(t), fpr64(b), fpr64(a)));
|
emit(con, fdivd(fpr64(t), fpr64(b), fpr64(a)));
|
||||||
@ -672,7 +672,7 @@ int normalize(Context* con,
|
|||||||
bool* release)
|
bool* release)
|
||||||
{
|
{
|
||||||
if (offset != 0 or scale != 1) {
|
if (offset != 0 or scale != 1) {
|
||||||
lir::Register normalizedIndex(
|
lir::RegisterPair normalizedIndex(
|
||||||
*preserveIndex ? con->client->acquireTemporary(GPR_MASK) : index);
|
*preserveIndex ? con->client->acquireTemporary(GPR_MASK) : index);
|
||||||
|
|
||||||
if (*preserveIndex) {
|
if (*preserveIndex) {
|
||||||
@ -685,7 +685,7 @@ int normalize(Context* con,
|
|||||||
int scaled;
|
int scaled;
|
||||||
|
|
||||||
if (scale != 1) {
|
if (scale != 1) {
|
||||||
lir::Register unscaledIndex(index);
|
lir::RegisterPair unscaledIndex(index);
|
||||||
|
|
||||||
ResolvedPromise scalePromise(log(scale));
|
ResolvedPromise scalePromise(log(scale));
|
||||||
lir::Constant scaleConstant(&scalePromise);
|
lir::Constant scaleConstant(&scalePromise);
|
||||||
@ -702,12 +702,12 @@ int normalize(Context* con,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (offset != 0) {
|
if (offset != 0) {
|
||||||
lir::Register untranslatedIndex(scaled);
|
lir::RegisterPair untranslatedIndex(scaled);
|
||||||
|
|
||||||
ResolvedPromise offsetPromise(offset);
|
ResolvedPromise offsetPromise(offset);
|
||||||
lir::Constant offsetConstant(&offsetPromise);
|
lir::Constant offsetConstant(&offsetPromise);
|
||||||
|
|
||||||
lir::Register tmp(con->client->acquireTemporary(GPR_MASK));
|
lir::RegisterPair tmp(con->client->acquireTemporary(GPR_MASK));
|
||||||
moveCR(con,
|
moveCR(con,
|
||||||
vm::TargetBytesPerWord,
|
vm::TargetBytesPerWord,
|
||||||
&offsetConstant,
|
&offsetConstant,
|
||||||
@ -730,7 +730,7 @@ int normalize(Context* con,
|
|||||||
|
|
||||||
void store(Context* con,
|
void store(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* src,
|
lir::RegisterPair* src,
|
||||||
int base,
|
int base,
|
||||||
int offset,
|
int offset,
|
||||||
int index,
|
int index,
|
||||||
@ -757,7 +757,7 @@ void store(Context* con,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 8: { // split into 2 32-bit stores
|
case 8: { // split into 2 32-bit stores
|
||||||
lir::Register srcHigh(src->high);
|
lir::RegisterPair srcHigh(src->high);
|
||||||
store(con, 4, &srcHigh, base, 0, normalized, 1, preserveIndex);
|
store(con, 4, &srcHigh, base, 0, normalized, 1, preserveIndex);
|
||||||
store(con, 4, src, base, 4, normalized, 1, preserveIndex);
|
store(con, 4, src, base, 4, normalized, 1, preserveIndex);
|
||||||
} break;
|
} break;
|
||||||
@ -766,7 +766,7 @@ void store(Context* con,
|
|||||||
abort(con);
|
abort(con);
|
||||||
}
|
}
|
||||||
} else { // FPR store
|
} else { // FPR store
|
||||||
lir::Register base_(base), normalized_(normalized),
|
lir::RegisterPair base_(base), normalized_(normalized),
|
||||||
absAddr = makeTemp(con);
|
absAddr = makeTemp(con);
|
||||||
// FPR stores have only bases, so we must add the index
|
// FPR stores have only bases, so we must add the index
|
||||||
addR(con, vm::TargetBytesPerWord, &base_, &normalized_, &absAddr);
|
addR(con, vm::TargetBytesPerWord, &base_, &normalized_, &absAddr);
|
||||||
@ -798,7 +798,7 @@ void store(Context* con,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 8: { // split into 2 32-bit stores
|
case 8: { // split into 2 32-bit stores
|
||||||
lir::Register srcHigh(src->high);
|
lir::RegisterPair srcHigh(src->high);
|
||||||
store(con, 4, &srcHigh, base, offset, lir::NoRegister, 1, false);
|
store(con, 4, &srcHigh, base, offset, lir::NoRegister, 1, false);
|
||||||
store(con, 4, src, base, offset + 4, lir::NoRegister, 1, false);
|
store(con, 4, src, base, offset + 4, lir::NoRegister, 1, false);
|
||||||
} break;
|
} break;
|
||||||
@ -815,7 +815,7 @@ void store(Context* con,
|
|||||||
emit(con, fsts(fpr32(src), base, offset));
|
emit(con, fsts(fpr32(src), base, offset));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
lir::Register tmp(con->client->acquireTemporary(GPR_MASK));
|
lir::RegisterPair tmp(con->client->acquireTemporary(GPR_MASK));
|
||||||
ResolvedPromise offsetPromise(offset);
|
ResolvedPromise offsetPromise(offset);
|
||||||
lir::Constant offsetConstant(&offsetPromise);
|
lir::Constant offsetConstant(&offsetPromise);
|
||||||
moveCR(con,
|
moveCR(con,
|
||||||
@ -832,7 +832,7 @@ void store(Context* con,
|
|||||||
|
|
||||||
void moveRM(Context* con,
|
void moveRM(Context* con,
|
||||||
unsigned srcSize,
|
unsigned srcSize,
|
||||||
lir::Register* src,
|
lir::RegisterPair* src,
|
||||||
unsigned dstSize UNUSED,
|
unsigned dstSize UNUSED,
|
||||||
lir::Memory* dst)
|
lir::Memory* dst)
|
||||||
{
|
{
|
||||||
@ -849,7 +849,7 @@ void load(Context* con,
|
|||||||
int index,
|
int index,
|
||||||
unsigned scale,
|
unsigned scale,
|
||||||
unsigned dstSize,
|
unsigned dstSize,
|
||||||
lir::Register* dst,
|
lir::RegisterPair* dst,
|
||||||
bool preserveIndex,
|
bool preserveIndex,
|
||||||
bool signExtend)
|
bool signExtend)
|
||||||
{
|
{
|
||||||
@ -882,7 +882,7 @@ void load(Context* con,
|
|||||||
load(con, 4, base, 0, normalized, 1, 4, dst, preserveIndex, false);
|
load(con, 4, base, 0, normalized, 1, 4, dst, preserveIndex, false);
|
||||||
moveRR(con, 4, dst, 8, dst);
|
moveRR(con, 4, dst, 8, dst);
|
||||||
} else if (srcSize == 8 and dstSize == 8) {
|
} else if (srcSize == 8 and dstSize == 8) {
|
||||||
lir::Register dstHigh(dst->high);
|
lir::RegisterPair dstHigh(dst->high);
|
||||||
load(con,
|
load(con,
|
||||||
4,
|
4,
|
||||||
base,
|
base,
|
||||||
@ -903,7 +903,7 @@ void load(Context* con,
|
|||||||
abort(con);
|
abort(con);
|
||||||
}
|
}
|
||||||
} else { // FPR load
|
} else { // FPR load
|
||||||
lir::Register base_(base), normalized_(normalized),
|
lir::RegisterPair base_(base), normalized_(normalized),
|
||||||
absAddr = makeTemp(con);
|
absAddr = makeTemp(con);
|
||||||
// VFP loads only have bases, so we must add the index
|
// VFP loads only have bases, so we must add the index
|
||||||
addR(con, vm::TargetBytesPerWord, &base_, &normalized_, &absAddr);
|
addR(con, vm::TargetBytesPerWord, &base_, &normalized_, &absAddr);
|
||||||
@ -946,7 +946,7 @@ void load(Context* con,
|
|||||||
|
|
||||||
case 8: {
|
case 8: {
|
||||||
if (dstSize == 8) {
|
if (dstSize == 8) {
|
||||||
lir::Register dstHigh(dst->high);
|
lir::RegisterPair dstHigh(dst->high);
|
||||||
load(con,
|
load(con,
|
||||||
4,
|
4,
|
||||||
base,
|
base,
|
||||||
@ -984,7 +984,7 @@ void load(Context* con,
|
|||||||
emit(con, flds(fpr32(dst), base, offset));
|
emit(con, flds(fpr32(dst), base, offset));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
lir::Register tmp(con->client->acquireTemporary(GPR_MASK));
|
lir::RegisterPair tmp(con->client->acquireTemporary(GPR_MASK));
|
||||||
ResolvedPromise offsetPromise(offset);
|
ResolvedPromise offsetPromise(offset);
|
||||||
lir::Constant offsetConstant(&offsetPromise);
|
lir::Constant offsetConstant(&offsetPromise);
|
||||||
moveCR(con,
|
moveCR(con,
|
||||||
@ -1003,7 +1003,7 @@ void moveMR(Context* con,
|
|||||||
unsigned srcSize,
|
unsigned srcSize,
|
||||||
lir::Memory* src,
|
lir::Memory* src,
|
||||||
unsigned dstSize,
|
unsigned dstSize,
|
||||||
lir::Register* dst)
|
lir::RegisterPair* dst)
|
||||||
{
|
{
|
||||||
load(con,
|
load(con,
|
||||||
srcSize,
|
srcSize,
|
||||||
@ -1021,7 +1021,7 @@ void moveZMR(Context* con,
|
|||||||
unsigned srcSize,
|
unsigned srcSize,
|
||||||
lir::Memory* src,
|
lir::Memory* src,
|
||||||
unsigned dstSize,
|
unsigned dstSize,
|
||||||
lir::Register* dst)
|
lir::RegisterPair* dst)
|
||||||
{
|
{
|
||||||
load(con,
|
load(con,
|
||||||
srcSize,
|
srcSize,
|
||||||
@ -1037,9 +1037,9 @@ void moveZMR(Context* con,
|
|||||||
|
|
||||||
void andR(Context* con,
|
void andR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* dst)
|
lir::RegisterPair* dst)
|
||||||
{
|
{
|
||||||
if (size == 8)
|
if (size == 8)
|
||||||
emit(con, and_(dst->high, a->high, b->high));
|
emit(con, and_(dst->high, a->high, b->high));
|
||||||
@ -1049,8 +1049,8 @@ void andR(Context* con,
|
|||||||
void andC(Context* con,
|
void andC(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* dst)
|
lir::RegisterPair* dst)
|
||||||
{
|
{
|
||||||
int64_t v = a->value->value();
|
int64_t v = a->value->value();
|
||||||
|
|
||||||
@ -1061,8 +1061,8 @@ void andC(Context* con,
|
|||||||
ResolvedPromise low(v & 0xFFFFFFFF);
|
ResolvedPromise low(v & 0xFFFFFFFF);
|
||||||
lir::Constant al(&low);
|
lir::Constant al(&low);
|
||||||
|
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
lir::Register dh(dst->high);
|
lir::RegisterPair dh(dst->high);
|
||||||
|
|
||||||
andC(con, 4, &al, b, dst);
|
andC(con, 4, &al, b, dst);
|
||||||
andC(con, 4, &ah, &bh, &dh);
|
andC(con, 4, &ah, &bh, &dh);
|
||||||
@ -1078,7 +1078,7 @@ void andC(Context* con,
|
|||||||
// instruction
|
// instruction
|
||||||
|
|
||||||
bool useTemporary = b->low == dst->low;
|
bool useTemporary = b->low == dst->low;
|
||||||
lir::Register tmp(dst->low);
|
lir::RegisterPair tmp(dst->low);
|
||||||
if (useTemporary) {
|
if (useTemporary) {
|
||||||
tmp.low = con->client->acquireTemporary(GPR_MASK);
|
tmp.low = con->client->acquireTemporary(GPR_MASK);
|
||||||
}
|
}
|
||||||
@ -1098,9 +1098,9 @@ void andC(Context* con,
|
|||||||
|
|
||||||
void orR(Context* con,
|
void orR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* dst)
|
lir::RegisterPair* dst)
|
||||||
{
|
{
|
||||||
if (size == 8)
|
if (size == 8)
|
||||||
emit(con, orr(dst->high, a->high, b->high));
|
emit(con, orr(dst->high, a->high, b->high));
|
||||||
@ -1109,9 +1109,9 @@ void orR(Context* con,
|
|||||||
|
|
||||||
void xorR(Context* con,
|
void xorR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* dst)
|
lir::RegisterPair* dst)
|
||||||
{
|
{
|
||||||
if (size == 8)
|
if (size == 8)
|
||||||
emit(con, eor(dst->high, a->high, b->high));
|
emit(con, eor(dst->high, a->high, b->high));
|
||||||
@ -1122,7 +1122,7 @@ void moveAR2(Context* con,
|
|||||||
unsigned srcSize,
|
unsigned srcSize,
|
||||||
lir::Address* src,
|
lir::Address* src,
|
||||||
unsigned dstSize,
|
unsigned dstSize,
|
||||||
lir::Register* dst)
|
lir::RegisterPair* dst)
|
||||||
{
|
{
|
||||||
assertT(con, srcSize == 4 and dstSize == 4);
|
assertT(con, srcSize == 4 and dstSize == 4);
|
||||||
|
|
||||||
@ -1137,16 +1137,16 @@ void moveAR(Context* con,
|
|||||||
unsigned srcSize,
|
unsigned srcSize,
|
||||||
lir::Address* src,
|
lir::Address* src,
|
||||||
unsigned dstSize,
|
unsigned dstSize,
|
||||||
lir::Register* dst)
|
lir::RegisterPair* dst)
|
||||||
{
|
{
|
||||||
moveAR2(con, srcSize, src, dstSize, dst);
|
moveAR2(con, srcSize, src, dstSize, dst);
|
||||||
}
|
}
|
||||||
|
|
||||||
void compareRR(Context* con,
|
void compareRR(Context* con,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(con, !(isFpr(a) ^ isFpr(b))); // regs must be of the same type
|
assertT(con, !(isFpr(a) ^ isFpr(b))); // regs must be of the same type
|
||||||
|
|
||||||
@ -1168,14 +1168,14 @@ void compareCR(Context* con,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(con, aSize == 4 and bSize == 4);
|
assertT(con, aSize == 4 and bSize == 4);
|
||||||
|
|
||||||
if (!isFpr(b) && a->value->resolved() && isOfWidth(a->value->value(), 8)) {
|
if (!isFpr(b) && a->value->resolved() && isOfWidth(a->value->value(), 8)) {
|
||||||
emit(con, cmpi(b->low, a->value->value()));
|
emit(con, cmpi(b->low, a->value->value()));
|
||||||
} else {
|
} else {
|
||||||
lir::Register tmp(con->client->acquireTemporary(GPR_MASK));
|
lir::RegisterPair tmp(con->client->acquireTemporary(GPR_MASK));
|
||||||
moveCR(con, aSize, a, bSize, &tmp);
|
moveCR(con, aSize, a, bSize, &tmp);
|
||||||
compareRR(con, bSize, &tmp, bSize, b);
|
compareRR(con, bSize, &tmp, bSize, b);
|
||||||
con->client->releaseTemporary(tmp.low);
|
con->client->releaseTemporary(tmp.low);
|
||||||
@ -1190,7 +1190,7 @@ void compareCM(Context* con,
|
|||||||
{
|
{
|
||||||
assertT(con, aSize == 4 and bSize == 4);
|
assertT(con, aSize == 4 and bSize == 4);
|
||||||
|
|
||||||
lir::Register tmp(con->client->acquireTemporary(GPR_MASK));
|
lir::RegisterPair tmp(con->client->acquireTemporary(GPR_MASK));
|
||||||
moveMR(con, bSize, b, bSize, &tmp);
|
moveMR(con, bSize, b, bSize, &tmp);
|
||||||
compareCR(con, aSize, a, bSize, &tmp);
|
compareCR(con, aSize, a, bSize, &tmp);
|
||||||
con->client->releaseTemporary(tmp.low);
|
con->client->releaseTemporary(tmp.low);
|
||||||
@ -1198,13 +1198,13 @@ void compareCM(Context* con,
|
|||||||
|
|
||||||
void compareRM(Context* con,
|
void compareRM(Context* con,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Memory* b)
|
lir::Memory* b)
|
||||||
{
|
{
|
||||||
assertT(con, aSize == 4 and bSize == 4);
|
assertT(con, aSize == 4 and bSize == 4);
|
||||||
|
|
||||||
lir::Register tmp(con->client->acquireTemporary(GPR_MASK));
|
lir::RegisterPair tmp(con->client->acquireTemporary(GPR_MASK));
|
||||||
moveMR(con, bSize, b, bSize, &tmp);
|
moveMR(con, bSize, b, bSize, &tmp);
|
||||||
compareRR(con, aSize, a, bSize, &tmp);
|
compareRR(con, aSize, a, bSize, &tmp);
|
||||||
con->client->releaseTemporary(tmp.low);
|
con->client->releaseTemporary(tmp.low);
|
||||||
@ -1352,13 +1352,13 @@ void branchLong(Context* con,
|
|||||||
void branchRR(Context* con,
|
void branchRR(Context* con,
|
||||||
lir::TernaryOperation op,
|
lir::TernaryOperation op,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Constant* target)
|
lir::Constant* target)
|
||||||
{
|
{
|
||||||
if (!isFpr(a) && size > vm::TargetBytesPerWord) {
|
if (!isFpr(a) && size > vm::TargetBytesPerWord) {
|
||||||
lir::Register ah(a->high);
|
lir::RegisterPair ah(a->high);
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
|
|
||||||
branchLong(
|
branchLong(
|
||||||
con, op, a, &ah, b, &bh, target, CAST2(compareRR), CAST2(compareRR));
|
con, op, a, &ah, b, &bh, target, CAST2(compareRR), CAST2(compareRR));
|
||||||
@ -1372,7 +1372,7 @@ void branchCR(Context* con,
|
|||||||
lir::TernaryOperation op,
|
lir::TernaryOperation op,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Constant* target)
|
lir::Constant* target)
|
||||||
{
|
{
|
||||||
assertT(con, !isFloatBranch(op));
|
assertT(con, !isFloatBranch(op));
|
||||||
@ -1386,7 +1386,7 @@ void branchCR(Context* con,
|
|||||||
ResolvedPromise high((v >> 32) & ~static_cast<vm::target_uintptr_t>(0));
|
ResolvedPromise high((v >> 32) & ~static_cast<vm::target_uintptr_t>(0));
|
||||||
lir::Constant ah(&high);
|
lir::Constant ah(&high);
|
||||||
|
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
|
|
||||||
branchLong(
|
branchLong(
|
||||||
con, op, &al, &ah, b, &bh, target, CAST2(compareCR), CAST2(compareCR));
|
con, op, &al, &ah, b, &bh, target, CAST2(compareCR), CAST2(compareCR));
|
||||||
@ -1399,7 +1399,7 @@ void branchCR(Context* con,
|
|||||||
void branchRM(Context* con,
|
void branchRM(Context* con,
|
||||||
lir::TernaryOperation op,
|
lir::TernaryOperation op,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Memory* b,
|
lir::Memory* b,
|
||||||
lir::Constant* target)
|
lir::Constant* target)
|
||||||
{
|
{
|
||||||
@ -1450,7 +1450,7 @@ void moveCM(Context* con,
|
|||||||
} break;
|
} break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
lir::Register tmp(con->client->acquireTemporary(GPR_MASK));
|
lir::RegisterPair tmp(con->client->acquireTemporary(GPR_MASK));
|
||||||
moveCR(con, srcSize, src, dstSize, &tmp);
|
moveCR(con, srcSize, src, dstSize, &tmp);
|
||||||
moveRM(con, dstSize, &tmp, dstSize, dst);
|
moveRM(con, dstSize, &tmp, dstSize, dst);
|
||||||
con->client->releaseTemporary(tmp.low);
|
con->client->releaseTemporary(tmp.low);
|
||||||
@ -1459,9 +1459,9 @@ void moveCM(Context* con,
|
|||||||
|
|
||||||
void negateRR(Context* con,
|
void negateRR(Context* con,
|
||||||
unsigned srcSize,
|
unsigned srcSize,
|
||||||
lir::Register* src,
|
lir::RegisterPair* src,
|
||||||
unsigned dstSize UNUSED,
|
unsigned dstSize UNUSED,
|
||||||
lir::Register* dst)
|
lir::RegisterPair* dst)
|
||||||
{
|
{
|
||||||
assertT(con, srcSize == dstSize);
|
assertT(con, srcSize == dstSize);
|
||||||
|
|
||||||
@ -1473,7 +1473,7 @@ void negateRR(Context* con,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void callR(Context* con, unsigned size UNUSED, lir::Register* target)
|
void callR(Context* con, unsigned size UNUSED, lir::RegisterPair* target)
|
||||||
{
|
{
|
||||||
assertT(con, size == vm::TargetBytesPerWord);
|
assertT(con, size == vm::TargetBytesPerWord);
|
||||||
emit(con, blx(target->low));
|
emit(con, blx(target->low));
|
||||||
@ -1491,7 +1491,7 @@ void longCallC(Context* con, unsigned size UNUSED, lir::Constant* target)
|
|||||||
{
|
{
|
||||||
assertT(con, size == vm::TargetBytesPerWord);
|
assertT(con, size == vm::TargetBytesPerWord);
|
||||||
|
|
||||||
lir::Register tmp(4);
|
lir::RegisterPair tmp(4);
|
||||||
moveCR2(con, vm::TargetBytesPerWord, target, &tmp, offsetPromise(con));
|
moveCR2(con, vm::TargetBytesPerWord, target, &tmp, offsetPromise(con));
|
||||||
callR(con, vm::TargetBytesPerWord, &tmp);
|
callR(con, vm::TargetBytesPerWord, &tmp);
|
||||||
}
|
}
|
||||||
@ -1500,7 +1500,7 @@ void longJumpC(Context* con, unsigned size UNUSED, lir::Constant* target)
|
|||||||
{
|
{
|
||||||
assertT(con, size == vm::TargetBytesPerWord);
|
assertT(con, size == vm::TargetBytesPerWord);
|
||||||
|
|
||||||
lir::Register tmp(4); // a non-arg reg that we don't mind clobbering
|
lir::RegisterPair tmp(4); // a non-arg reg that we don't mind clobbering
|
||||||
moveCR2(con, vm::TargetBytesPerWord, target, &tmp, offsetPromise(con));
|
moveCR2(con, vm::TargetBytesPerWord, target, &tmp, offsetPromise(con));
|
||||||
jumpR(con, vm::TargetBytesPerWord, &tmp);
|
jumpR(con, vm::TargetBytesPerWord, &tmp);
|
||||||
}
|
}
|
||||||
|
@ -45,19 +45,19 @@ inline int64_t getValue(lir::Constant* con)
|
|||||||
return con->value->value();
|
return con->value->value();
|
||||||
}
|
}
|
||||||
|
|
||||||
inline lir::Register makeTemp(Context* con)
|
inline lir::RegisterPair makeTemp(Context* con)
|
||||||
{
|
{
|
||||||
lir::Register tmp(newTemp(con));
|
lir::RegisterPair tmp(newTemp(con));
|
||||||
return tmp;
|
return tmp;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline lir::Register makeTemp64(Context* con)
|
inline lir::RegisterPair makeTemp64(Context* con)
|
||||||
{
|
{
|
||||||
lir::Register tmp(newTemp(con), newTemp(con));
|
lir::RegisterPair tmp(newTemp(con), newTemp(con));
|
||||||
return tmp;
|
return tmp;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void freeTemp(Context* con, const lir::Register& tmp)
|
inline void freeTemp(Context* con, const lir::RegisterPair& tmp)
|
||||||
{
|
{
|
||||||
if (tmp.low != lir::NoRegister)
|
if (tmp.low != lir::NoRegister)
|
||||||
freeTemp(con, tmp.low);
|
freeTemp(con, tmp.low);
|
||||||
@ -67,45 +67,45 @@ inline void freeTemp(Context* con, const lir::Register& tmp)
|
|||||||
|
|
||||||
void shiftLeftR(Context* con,
|
void shiftLeftR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t);
|
lir::RegisterPair* t);
|
||||||
|
|
||||||
void moveRR(Context* con,
|
void moveRR(Context* con,
|
||||||
unsigned srcSize,
|
unsigned srcSize,
|
||||||
lir::Register* src,
|
lir::RegisterPair* src,
|
||||||
unsigned dstSize,
|
unsigned dstSize,
|
||||||
lir::Register* dst);
|
lir::RegisterPair* dst);
|
||||||
|
|
||||||
void shiftLeftC(Context* con,
|
void shiftLeftC(Context* con,
|
||||||
unsigned size UNUSED,
|
unsigned size UNUSED,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t);
|
lir::RegisterPair* t);
|
||||||
|
|
||||||
void shiftRightR(Context* con,
|
void shiftRightR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t);
|
lir::RegisterPair* t);
|
||||||
|
|
||||||
void shiftRightC(Context* con,
|
void shiftRightC(Context* con,
|
||||||
unsigned size UNUSED,
|
unsigned size UNUSED,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t);
|
lir::RegisterPair* t);
|
||||||
|
|
||||||
void unsignedShiftRightR(Context* con,
|
void unsignedShiftRightR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t);
|
lir::RegisterPair* t);
|
||||||
|
|
||||||
void unsignedShiftRightC(Context* con,
|
void unsignedShiftRightC(Context* con,
|
||||||
unsigned size UNUSED,
|
unsigned size UNUSED,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t);
|
lir::RegisterPair* t);
|
||||||
|
|
||||||
bool needJump(MyBlock* b);
|
bool needJump(MyBlock* b);
|
||||||
|
|
||||||
@ -113,133 +113,133 @@ unsigned padding(MyBlock* b, unsigned offset);
|
|||||||
|
|
||||||
void resolve(MyBlock* b);
|
void resolve(MyBlock* b);
|
||||||
|
|
||||||
void jumpR(Context* con, unsigned size UNUSED, lir::Register* target);
|
void jumpR(Context* con, unsigned size UNUSED, lir::RegisterPair* target);
|
||||||
|
|
||||||
void swapRR(Context* con,
|
void swapRR(Context* con,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void moveRR(Context* con,
|
void moveRR(Context* con,
|
||||||
unsigned srcSize,
|
unsigned srcSize,
|
||||||
lir::Register* src,
|
lir::RegisterPair* src,
|
||||||
unsigned dstSize,
|
unsigned dstSize,
|
||||||
lir::Register* dst);
|
lir::RegisterPair* dst);
|
||||||
|
|
||||||
void moveZRR(Context* con,
|
void moveZRR(Context* con,
|
||||||
unsigned srcSize,
|
unsigned srcSize,
|
||||||
lir::Register* src,
|
lir::RegisterPair* src,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register* dst);
|
lir::RegisterPair* dst);
|
||||||
|
|
||||||
void moveCR(Context* con,
|
void moveCR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Constant* src,
|
lir::Constant* src,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register* dst);
|
lir::RegisterPair* dst);
|
||||||
|
|
||||||
void moveCR2(Context* con,
|
void moveCR2(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Constant* src,
|
lir::Constant* src,
|
||||||
lir::Register* dst,
|
lir::RegisterPair* dst,
|
||||||
Promise* callOffset);
|
Promise* callOffset);
|
||||||
|
|
||||||
void moveCR(Context* con,
|
void moveCR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Constant* src,
|
lir::Constant* src,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register* dst);
|
lir::RegisterPair* dst);
|
||||||
|
|
||||||
void addR(Context* con,
|
void addR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t);
|
lir::RegisterPair* t);
|
||||||
|
|
||||||
void subR(Context* con,
|
void subR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t);
|
lir::RegisterPair* t);
|
||||||
|
|
||||||
void addC(Context* con,
|
void addC(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* dst);
|
lir::RegisterPair* dst);
|
||||||
|
|
||||||
void subC(Context* con,
|
void subC(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* dst);
|
lir::RegisterPair* dst);
|
||||||
|
|
||||||
void multiplyR(Context* con,
|
void multiplyR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t);
|
lir::RegisterPair* t);
|
||||||
|
|
||||||
void floatAbsoluteRR(Context* con,
|
void floatAbsoluteRR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void floatNegateRR(Context* con,
|
void floatNegateRR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void float2FloatRR(Context* con,
|
void float2FloatRR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void float2IntRR(Context* con,
|
void float2IntRR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void int2FloatRR(Context* con,
|
void int2FloatRR(Context* con,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void floatSqrtRR(Context* con,
|
void floatSqrtRR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void floatAddR(Context* con,
|
void floatAddR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t);
|
lir::RegisterPair* t);
|
||||||
|
|
||||||
void floatSubtractR(Context* con,
|
void floatSubtractR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t);
|
lir::RegisterPair* t);
|
||||||
|
|
||||||
void floatMultiplyR(Context* con,
|
void floatMultiplyR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t);
|
lir::RegisterPair* t);
|
||||||
|
|
||||||
void floatDivideR(Context* con,
|
void floatDivideR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* t);
|
lir::RegisterPair* t);
|
||||||
|
|
||||||
int normalize(Context* con,
|
int normalize(Context* con,
|
||||||
int offset,
|
int offset,
|
||||||
@ -250,7 +250,7 @@ int normalize(Context* con,
|
|||||||
|
|
||||||
void store(Context* con,
|
void store(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* src,
|
lir::RegisterPair* src,
|
||||||
int base,
|
int base,
|
||||||
int offset,
|
int offset,
|
||||||
int index,
|
int index,
|
||||||
@ -259,7 +259,7 @@ void store(Context* con,
|
|||||||
|
|
||||||
void moveRM(Context* con,
|
void moveRM(Context* con,
|
||||||
unsigned srcSize,
|
unsigned srcSize,
|
||||||
lir::Register* src,
|
lir::RegisterPair* src,
|
||||||
unsigned dstSize UNUSED,
|
unsigned dstSize UNUSED,
|
||||||
lir::Memory* dst);
|
lir::Memory* dst);
|
||||||
|
|
||||||
@ -270,7 +270,7 @@ void load(Context* con,
|
|||||||
int index,
|
int index,
|
||||||
unsigned scale,
|
unsigned scale,
|
||||||
unsigned dstSize,
|
unsigned dstSize,
|
||||||
lir::Register* dst,
|
lir::RegisterPair* dst,
|
||||||
bool preserveIndex,
|
bool preserveIndex,
|
||||||
bool signExtend);
|
bool signExtend);
|
||||||
|
|
||||||
@ -278,61 +278,61 @@ void moveMR(Context* con,
|
|||||||
unsigned srcSize,
|
unsigned srcSize,
|
||||||
lir::Memory* src,
|
lir::Memory* src,
|
||||||
unsigned dstSize,
|
unsigned dstSize,
|
||||||
lir::Register* dst);
|
lir::RegisterPair* dst);
|
||||||
|
|
||||||
void moveZMR(Context* con,
|
void moveZMR(Context* con,
|
||||||
unsigned srcSize,
|
unsigned srcSize,
|
||||||
lir::Memory* src,
|
lir::Memory* src,
|
||||||
unsigned dstSize,
|
unsigned dstSize,
|
||||||
lir::Register* dst);
|
lir::RegisterPair* dst);
|
||||||
|
|
||||||
void andR(Context* con,
|
void andR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* dst);
|
lir::RegisterPair* dst);
|
||||||
|
|
||||||
void andC(Context* con,
|
void andC(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* dst);
|
lir::RegisterPair* dst);
|
||||||
|
|
||||||
void orR(Context* con,
|
void orR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* dst);
|
lir::RegisterPair* dst);
|
||||||
|
|
||||||
void xorR(Context* con,
|
void xorR(Context* con,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Register* dst);
|
lir::RegisterPair* dst);
|
||||||
|
|
||||||
void moveAR2(Context* con,
|
void moveAR2(Context* con,
|
||||||
unsigned srcSize,
|
unsigned srcSize,
|
||||||
lir::Address* src,
|
lir::Address* src,
|
||||||
unsigned dstSize,
|
unsigned dstSize,
|
||||||
lir::Register* dst);
|
lir::RegisterPair* dst);
|
||||||
|
|
||||||
void moveAR(Context* con,
|
void moveAR(Context* con,
|
||||||
unsigned srcSize,
|
unsigned srcSize,
|
||||||
lir::Address* src,
|
lir::Address* src,
|
||||||
unsigned dstSize,
|
unsigned dstSize,
|
||||||
lir::Register* dst);
|
lir::RegisterPair* dst);
|
||||||
|
|
||||||
void compareRR(Context* con,
|
void compareRR(Context* con,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void compareCR(Context* con,
|
void compareCR(Context* con,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void compareCM(Context* con,
|
void compareCM(Context* con,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
@ -342,7 +342,7 @@ void compareCM(Context* con,
|
|||||||
|
|
||||||
void compareRM(Context* con,
|
void compareRM(Context* con,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Memory* b);
|
lir::Memory* b);
|
||||||
|
|
||||||
@ -365,21 +365,21 @@ void branchLong(Context* con,
|
|||||||
void branchRR(Context* con,
|
void branchRR(Context* con,
|
||||||
lir::TernaryOperation op,
|
lir::TernaryOperation op,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Constant* target);
|
lir::Constant* target);
|
||||||
|
|
||||||
void branchCR(Context* con,
|
void branchCR(Context* con,
|
||||||
lir::TernaryOperation op,
|
lir::TernaryOperation op,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Constant* target);
|
lir::Constant* target);
|
||||||
|
|
||||||
void branchRM(Context* con,
|
void branchRM(Context* con,
|
||||||
lir::TernaryOperation op,
|
lir::TernaryOperation op,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Memory* b,
|
lir::Memory* b,
|
||||||
lir::Constant* target);
|
lir::Constant* target);
|
||||||
|
|
||||||
@ -403,11 +403,11 @@ void moveCM(Context* con,
|
|||||||
|
|
||||||
void negateRR(Context* con,
|
void negateRR(Context* con,
|
||||||
unsigned srcSize,
|
unsigned srcSize,
|
||||||
lir::Register* src,
|
lir::RegisterPair* src,
|
||||||
unsigned dstSize UNUSED,
|
unsigned dstSize UNUSED,
|
||||||
lir::Register* dst);
|
lir::RegisterPair* dst);
|
||||||
|
|
||||||
void callR(Context* con, unsigned size UNUSED, lir::Register* target);
|
void callR(Context* con, unsigned size UNUSED, lir::RegisterPair* target);
|
||||||
|
|
||||||
void callC(Context* con, unsigned size UNUSED, lir::Constant* target);
|
void callC(Context* con, unsigned size UNUSED, lir::Constant* target);
|
||||||
|
|
||||||
|
@ -26,7 +26,7 @@ const int N_FPRS = 16;
|
|||||||
const RegisterMask GPR_MASK = 0xffff;
|
const RegisterMask GPR_MASK = 0xffff;
|
||||||
const RegisterMask FPR_MASK = 0xffff0000;
|
const RegisterMask FPR_MASK = 0xffff0000;
|
||||||
|
|
||||||
inline bool isFpr(lir::Register* reg)
|
inline bool isFpr(lir::RegisterPair* reg)
|
||||||
{
|
{
|
||||||
return reg->low >= N_GPRS;
|
return reg->low >= N_GPRS;
|
||||||
}
|
}
|
||||||
@ -35,7 +35,7 @@ inline int fpr64(int reg)
|
|||||||
{
|
{
|
||||||
return reg - N_GPRS;
|
return reg - N_GPRS;
|
||||||
}
|
}
|
||||||
inline int fpr64(lir::Register* reg)
|
inline int fpr64(lir::RegisterPair* reg)
|
||||||
{
|
{
|
||||||
return fpr64(reg->low);
|
return fpr64(reg->low);
|
||||||
}
|
}
|
||||||
@ -43,7 +43,7 @@ inline int fpr32(int reg)
|
|||||||
{
|
{
|
||||||
return fpr64(reg) << 1;
|
return fpr64(reg) << 1;
|
||||||
}
|
}
|
||||||
inline int fpr32(lir::Register* reg)
|
inline int fpr32(lir::RegisterPair* reg)
|
||||||
{
|
{
|
||||||
return fpr64(reg) << 1;
|
return fpr64(reg) << 1;
|
||||||
}
|
}
|
||||||
|
@ -902,7 +902,7 @@ class MyAssembler : public Assembler {
|
|||||||
virtual void checkStackOverflow(uintptr_t handler,
|
virtual void checkStackOverflow(uintptr_t handler,
|
||||||
unsigned stackLimitOffsetFromThread)
|
unsigned stackLimitOffsetFromThread)
|
||||||
{
|
{
|
||||||
lir::Register stack(rsp);
|
lir::RegisterPair stack(rsp);
|
||||||
lir::Memory stackLimit(rbx, stackLimitOffsetFromThread);
|
lir::Memory stackLimit(rbx, stackLimitOffsetFromThread);
|
||||||
lir::Constant handlerConstant(resolvedPromise(&c, handler));
|
lir::Constant handlerConstant(resolvedPromise(&c, handler));
|
||||||
branchRM(&c,
|
branchRM(&c,
|
||||||
@ -915,7 +915,7 @@ class MyAssembler : public Assembler {
|
|||||||
|
|
||||||
virtual void saveFrame(unsigned stackOffset, unsigned)
|
virtual void saveFrame(unsigned stackOffset, unsigned)
|
||||||
{
|
{
|
||||||
lir::Register stack(rsp);
|
lir::RegisterPair stack(rsp);
|
||||||
lir::Memory stackDst(rbx, stackOffset);
|
lir::Memory stackDst(rbx, stackOffset);
|
||||||
apply(lir::Move,
|
apply(lir::Move,
|
||||||
OperandInfo(TargetBytesPerWord, lir::Operand::Type::RegisterPair, &stack),
|
OperandInfo(TargetBytesPerWord, lir::Operand::Type::RegisterPair, &stack),
|
||||||
@ -949,7 +949,7 @@ class MyAssembler : public Assembler {
|
|||||||
unsigned offset = 0;
|
unsigned offset = 0;
|
||||||
for (unsigned i = 0; i < argumentCount; ++i) {
|
for (unsigned i = 0; i < argumentCount; ++i) {
|
||||||
if (i < arch_->argumentRegisterCount()) {
|
if (i < arch_->argumentRegisterCount()) {
|
||||||
lir::Register dst(arch_->argumentRegister(i));
|
lir::RegisterPair dst(arch_->argumentRegister(i));
|
||||||
apply(lir::Move,
|
apply(lir::Move,
|
||||||
OperandInfo(RUNTIME_ARRAY_BODY(arguments)[i].size,
|
OperandInfo(RUNTIME_ARRAY_BODY(arguments)[i].size,
|
||||||
RUNTIME_ARRAY_BODY(arguments)[i].type,
|
RUNTIME_ARRAY_BODY(arguments)[i].type,
|
||||||
@ -976,10 +976,10 @@ class MyAssembler : public Assembler {
|
|||||||
|
|
||||||
virtual void allocateFrame(unsigned footprint)
|
virtual void allocateFrame(unsigned footprint)
|
||||||
{
|
{
|
||||||
lir::Register stack(rsp);
|
lir::RegisterPair stack(rsp);
|
||||||
|
|
||||||
if (UseFramePointer) {
|
if (UseFramePointer) {
|
||||||
lir::Register base(rbp);
|
lir::RegisterPair base(rbp);
|
||||||
pushR(&c, TargetBytesPerWord, &base);
|
pushR(&c, TargetBytesPerWord, &base);
|
||||||
|
|
||||||
apply(lir::Move,
|
apply(lir::Move,
|
||||||
@ -998,7 +998,7 @@ class MyAssembler : public Assembler {
|
|||||||
|
|
||||||
virtual void adjustFrame(unsigned difference)
|
virtual void adjustFrame(unsigned difference)
|
||||||
{
|
{
|
||||||
lir::Register stack(rsp);
|
lir::RegisterPair stack(rsp);
|
||||||
lir::Constant differenceConstant(
|
lir::Constant differenceConstant(
|
||||||
resolvedPromise(&c, difference * TargetBytesPerWord));
|
resolvedPromise(&c, difference * TargetBytesPerWord));
|
||||||
apply(lir::Subtract,
|
apply(lir::Subtract,
|
||||||
@ -1011,15 +1011,15 @@ class MyAssembler : public Assembler {
|
|||||||
virtual void popFrame(unsigned frameFootprint)
|
virtual void popFrame(unsigned frameFootprint)
|
||||||
{
|
{
|
||||||
if (UseFramePointer) {
|
if (UseFramePointer) {
|
||||||
lir::Register base(rbp);
|
lir::RegisterPair base(rbp);
|
||||||
lir::Register stack(rsp);
|
lir::RegisterPair stack(rsp);
|
||||||
apply(lir::Move,
|
apply(lir::Move,
|
||||||
OperandInfo(TargetBytesPerWord, lir::Operand::Type::RegisterPair, &base),
|
OperandInfo(TargetBytesPerWord, lir::Operand::Type::RegisterPair, &base),
|
||||||
OperandInfo(TargetBytesPerWord, lir::Operand::Type::RegisterPair, &stack));
|
OperandInfo(TargetBytesPerWord, lir::Operand::Type::RegisterPair, &stack));
|
||||||
|
|
||||||
popR(&c, TargetBytesPerWord, &base);
|
popR(&c, TargetBytesPerWord, &base);
|
||||||
} else {
|
} else {
|
||||||
lir::Register stack(rsp);
|
lir::RegisterPair stack(rsp);
|
||||||
lir::Constant footprint(
|
lir::Constant footprint(
|
||||||
resolvedPromise(&c, frameFootprint * TargetBytesPerWord));
|
resolvedPromise(&c, frameFootprint * TargetBytesPerWord));
|
||||||
apply(lir::Add,
|
apply(lir::Add,
|
||||||
@ -1036,7 +1036,7 @@ class MyAssembler : public Assembler {
|
|||||||
{
|
{
|
||||||
if (TailCalls) {
|
if (TailCalls) {
|
||||||
if (offset) {
|
if (offset) {
|
||||||
lir::Register tmp(c.client->acquireTemporary());
|
lir::RegisterPair tmp(c.client->acquireTemporary());
|
||||||
|
|
||||||
unsigned baseSize = UseFramePointer ? 1 : 0;
|
unsigned baseSize = UseFramePointer ? 1 : 0;
|
||||||
|
|
||||||
@ -1060,11 +1060,11 @@ class MyAssembler : public Assembler {
|
|||||||
|
|
||||||
if (UseFramePointer) {
|
if (UseFramePointer) {
|
||||||
lir::Memory baseSrc(rsp, frameFootprint * TargetBytesPerWord);
|
lir::Memory baseSrc(rsp, frameFootprint * TargetBytesPerWord);
|
||||||
lir::Register base(rbp);
|
lir::RegisterPair base(rbp);
|
||||||
moveMR(&c, TargetBytesPerWord, &baseSrc, TargetBytesPerWord, &base);
|
moveMR(&c, TargetBytesPerWord, &baseSrc, TargetBytesPerWord, &base);
|
||||||
}
|
}
|
||||||
|
|
||||||
lir::Register stack(rsp);
|
lir::RegisterPair stack(rsp);
|
||||||
lir::Constant footprint(resolvedPromise(
|
lir::Constant footprint(resolvedPromise(
|
||||||
&c, (frameFootprint - offset + baseSize) * TargetBytesPerWord));
|
&c, (frameFootprint - offset + baseSize) * TargetBytesPerWord));
|
||||||
|
|
||||||
@ -1073,7 +1073,7 @@ class MyAssembler : public Assembler {
|
|||||||
if (returnAddressSurrogate != lir::NoRegister) {
|
if (returnAddressSurrogate != lir::NoRegister) {
|
||||||
assertT(&c, offset > 0);
|
assertT(&c, offset > 0);
|
||||||
|
|
||||||
lir::Register ras(returnAddressSurrogate);
|
lir::RegisterPair ras(returnAddressSurrogate);
|
||||||
lir::Memory dst(rsp, offset * TargetBytesPerWord);
|
lir::Memory dst(rsp, offset * TargetBytesPerWord);
|
||||||
moveRM(&c, TargetBytesPerWord, &ras, TargetBytesPerWord, &dst);
|
moveRM(&c, TargetBytesPerWord, &ras, TargetBytesPerWord, &dst);
|
||||||
}
|
}
|
||||||
@ -1081,7 +1081,7 @@ class MyAssembler : public Assembler {
|
|||||||
if (framePointerSurrogate != lir::NoRegister) {
|
if (framePointerSurrogate != lir::NoRegister) {
|
||||||
assertT(&c, offset > 0);
|
assertT(&c, offset > 0);
|
||||||
|
|
||||||
lir::Register fps(framePointerSurrogate);
|
lir::RegisterPair fps(framePointerSurrogate);
|
||||||
lir::Memory dst(rsp, (offset - 1) * TargetBytesPerWord);
|
lir::Memory dst(rsp, (offset - 1) * TargetBytesPerWord);
|
||||||
moveRM(&c, TargetBytesPerWord, &fps, TargetBytesPerWord, &dst);
|
moveRM(&c, TargetBytesPerWord, &fps, TargetBytesPerWord, &dst);
|
||||||
}
|
}
|
||||||
@ -1102,10 +1102,10 @@ class MyAssembler : public Assembler {
|
|||||||
assertT(&c, (argumentFootprint % StackAlignmentInWords) == 0);
|
assertT(&c, (argumentFootprint % StackAlignmentInWords) == 0);
|
||||||
|
|
||||||
if (TailCalls and argumentFootprint > StackAlignmentInWords) {
|
if (TailCalls and argumentFootprint > StackAlignmentInWords) {
|
||||||
lir::Register returnAddress(rcx);
|
lir::RegisterPair returnAddress(rcx);
|
||||||
popR(&c, TargetBytesPerWord, &returnAddress);
|
popR(&c, TargetBytesPerWord, &returnAddress);
|
||||||
|
|
||||||
lir::Register stack(rsp);
|
lir::RegisterPair stack(rsp);
|
||||||
lir::Constant adjustment(resolvedPromise(
|
lir::Constant adjustment(resolvedPromise(
|
||||||
&c,
|
&c,
|
||||||
(argumentFootprint - StackAlignmentInWords) * TargetBytesPerWord));
|
(argumentFootprint - StackAlignmentInWords) * TargetBytesPerWord));
|
||||||
@ -1122,10 +1122,10 @@ class MyAssembler : public Assembler {
|
|||||||
{
|
{
|
||||||
popFrame(frameFootprint);
|
popFrame(frameFootprint);
|
||||||
|
|
||||||
lir::Register returnAddress(rcx);
|
lir::RegisterPair returnAddress(rcx);
|
||||||
popR(&c, TargetBytesPerWord, &returnAddress);
|
popR(&c, TargetBytesPerWord, &returnAddress);
|
||||||
|
|
||||||
lir::Register stack(rsp);
|
lir::RegisterPair stack(rsp);
|
||||||
lir::Memory stackSrc(rbx, stackOffsetFromThread);
|
lir::Memory stackSrc(rbx, stackOffsetFromThread);
|
||||||
moveMR(&c, TargetBytesPerWord, &stackSrc, TargetBytesPerWord, &stack);
|
moveMR(&c, TargetBytesPerWord, &stackSrc, TargetBytesPerWord, &stack);
|
||||||
|
|
||||||
|
@ -76,22 +76,22 @@ void maybeRex(Context* c,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void maybeRex(Context* c, unsigned size, lir::Register* a, lir::Register* b)
|
void maybeRex(Context* c, unsigned size, lir::RegisterPair* a, lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
maybeRex(c, size, a->low, lir::NoRegister, b->low, false);
|
maybeRex(c, size, a->low, lir::NoRegister, b->low, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void alwaysRex(Context* c, unsigned size, lir::Register* a, lir::Register* b)
|
void alwaysRex(Context* c, unsigned size, lir::RegisterPair* a, lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
maybeRex(c, size, a->low, lir::NoRegister, b->low, true);
|
maybeRex(c, size, a->low, lir::NoRegister, b->low, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void maybeRex(Context* c, unsigned size, lir::Register* a)
|
void maybeRex(Context* c, unsigned size, lir::RegisterPair* a)
|
||||||
{
|
{
|
||||||
maybeRex(c, size, lir::NoRegister, lir::NoRegister, a->low, false);
|
maybeRex(c, size, lir::NoRegister, lir::NoRegister, a->low, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void maybeRex(Context* c, unsigned size, lir::Register* a, lir::Memory* b)
|
void maybeRex(Context* c, unsigned size, lir::RegisterPair* a, lir::Memory* b)
|
||||||
{
|
{
|
||||||
maybeRex(c, size, a->low, b->index, b->base, size == 1 and (a->low & 4));
|
maybeRex(c, size, a->low, b->index, b->base, size == 1 and (a->low & 4));
|
||||||
}
|
}
|
||||||
@ -106,7 +106,7 @@ void modrm(Context* c, uint8_t mod, int a, int b)
|
|||||||
c->code.append(mod | (regCode(b) << 3) | regCode(a));
|
c->code.append(mod | (regCode(b) << 3) | regCode(a));
|
||||||
}
|
}
|
||||||
|
|
||||||
void modrm(Context* c, uint8_t mod, lir::Register* a, lir::Register* b)
|
void modrm(Context* c, uint8_t mod, lir::RegisterPair* a, lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
modrm(c, mod, a->low, b->low);
|
modrm(c, mod, a->low, b->low);
|
||||||
}
|
}
|
||||||
@ -143,7 +143,7 @@ void modrmSibImm(Context* c, int a, int scale, int index, int base, int offset)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void modrmSibImm(Context* c, lir::Register* a, lir::Memory* b)
|
void modrmSibImm(Context* c, lir::RegisterPair* a, lir::Memory* b)
|
||||||
{
|
{
|
||||||
modrmSibImm(c, a->low, b->scale, b->index, b->base, b->offset);
|
modrmSibImm(c, a->low, b->scale, b->index, b->base, b->offset);
|
||||||
}
|
}
|
||||||
@ -177,9 +177,9 @@ void conditional(Context* c, unsigned condition, lir::Constant* a)
|
|||||||
|
|
||||||
void sseMoveRR(Context* c,
|
void sseMoveRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, aSize >= 4);
|
assertT(c, aSize >= 4);
|
||||||
assertT(c, aSize == bSize);
|
assertT(c, aSize == bSize);
|
||||||
@ -213,10 +213,10 @@ void sseMoveCR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, aSize <= vm::TargetBytesPerWord);
|
assertT(c, aSize <= vm::TargetBytesPerWord);
|
||||||
lir::Register tmp(c->client->acquireTemporary(GeneralRegisterMask));
|
lir::RegisterPair tmp(c->client->acquireTemporary(GeneralRegisterMask));
|
||||||
moveCR2(c, aSize, a, aSize, &tmp, 0);
|
moveCR2(c, aSize, a, aSize, &tmp, 0);
|
||||||
sseMoveRR(c, aSize, &tmp, bSize, b);
|
sseMoveRR(c, aSize, &tmp, bSize, b);
|
||||||
c->client->releaseTemporary(tmp.low);
|
c->client->releaseTemporary(tmp.low);
|
||||||
@ -226,7 +226,7 @@ void sseMoveMR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, aSize >= 4);
|
assertT(c, aSize >= 4);
|
||||||
|
|
||||||
@ -244,7 +244,7 @@ void sseMoveMR(Context* c,
|
|||||||
|
|
||||||
void sseMoveRM(Context* c,
|
void sseMoveRM(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
UNUSED unsigned bSize,
|
UNUSED unsigned bSize,
|
||||||
lir::Memory* b)
|
lir::Memory* b)
|
||||||
{
|
{
|
||||||
@ -353,9 +353,9 @@ void branchFloat(Context* c, lir::TernaryOperation op, lir::Constant* target)
|
|||||||
|
|
||||||
void floatRegOp(Context* c,
|
void floatRegOp(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
uint8_t op,
|
uint8_t op,
|
||||||
uint8_t mod)
|
uint8_t mod)
|
||||||
{
|
{
|
||||||
@ -373,7 +373,7 @@ void floatMemOp(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
uint8_t op)
|
uint8_t op)
|
||||||
{
|
{
|
||||||
if (aSize == 4) {
|
if (aSize == 4) {
|
||||||
@ -390,13 +390,13 @@ void moveCR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void moveCR2(Context* c,
|
void moveCR2(Context* c,
|
||||||
UNUSED unsigned aSize,
|
UNUSED unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
UNUSED unsigned bSize,
|
UNUSED unsigned bSize,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
unsigned promiseOffset)
|
unsigned promiseOffset)
|
||||||
{
|
{
|
||||||
if (vm::TargetBytesPerWord == 4 and bSize == 8) {
|
if (vm::TargetBytesPerWord == 4 and bSize == 8) {
|
||||||
@ -408,7 +408,7 @@ void moveCR2(Context* c,
|
|||||||
ResolvedPromise low(v & 0xFFFFFFFF);
|
ResolvedPromise low(v & 0xFFFFFFFF);
|
||||||
lir::Constant al(&low);
|
lir::Constant al(&low);
|
||||||
|
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
|
|
||||||
moveCR(c, 4, &al, 4, b);
|
moveCR(c, 4, &al, 4, b);
|
||||||
moveCR(c, 4, &ah, 4, &bh);
|
moveCR(c, 4, &ah, 4, &bh);
|
||||||
|
@ -32,13 +32,13 @@ void maybeRex(Context* c,
|
|||||||
int base,
|
int base,
|
||||||
bool always);
|
bool always);
|
||||||
|
|
||||||
void maybeRex(Context* c, unsigned size, lir::Register* a, lir::Register* b);
|
void maybeRex(Context* c, unsigned size, lir::RegisterPair* a, lir::RegisterPair* b);
|
||||||
|
|
||||||
void alwaysRex(Context* c, unsigned size, lir::Register* a, lir::Register* b);
|
void alwaysRex(Context* c, unsigned size, lir::RegisterPair* a, lir::RegisterPair* b);
|
||||||
|
|
||||||
void maybeRex(Context* c, unsigned size, lir::Register* a);
|
void maybeRex(Context* c, unsigned size, lir::RegisterPair* a);
|
||||||
|
|
||||||
void maybeRex(Context* c, unsigned size, lir::Register* a, lir::Memory* b);
|
void maybeRex(Context* c, unsigned size, lir::RegisterPair* a, lir::Memory* b);
|
||||||
|
|
||||||
void maybeRex(Context* c, unsigned size, lir::Memory* a);
|
void maybeRex(Context* c, unsigned size, lir::Memory* a);
|
||||||
|
|
||||||
@ -47,19 +47,19 @@ inline int regCode(int a)
|
|||||||
return a & 7;
|
return a & 7;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int regCode(lir::Register* a)
|
inline int regCode(lir::RegisterPair* a)
|
||||||
{
|
{
|
||||||
return regCode(a->low);
|
return regCode(a->low);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool isFloatReg(lir::Register* a)
|
inline bool isFloatReg(lir::RegisterPair* a)
|
||||||
{
|
{
|
||||||
return a->low >= xmm0;
|
return a->low >= xmm0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void modrm(Context* c, uint8_t mod, int a, int b);
|
void modrm(Context* c, uint8_t mod, int a, int b);
|
||||||
|
|
||||||
void modrm(Context* c, uint8_t mod, lir::Register* a, lir::Register* b);
|
void modrm(Context* c, uint8_t mod, lir::RegisterPair* a, lir::RegisterPair* b);
|
||||||
|
|
||||||
void sib(Context* c, unsigned scale, int index, int base);
|
void sib(Context* c, unsigned scale, int index, int base);
|
||||||
|
|
||||||
@ -67,7 +67,7 @@ void modrmSib(Context* c, int width, int a, int scale, int index, int base);
|
|||||||
|
|
||||||
void modrmSibImm(Context* c, int a, int scale, int index, int base, int offset);
|
void modrmSibImm(Context* c, int a, int scale, int index, int base, int offset);
|
||||||
|
|
||||||
void modrmSibImm(Context* c, lir::Register* a, lir::Memory* b);
|
void modrmSibImm(Context* c, lir::RegisterPair* a, lir::Memory* b);
|
||||||
|
|
||||||
void opcode(Context* c, uint8_t op);
|
void opcode(Context* c, uint8_t op);
|
||||||
|
|
||||||
@ -79,25 +79,25 @@ void conditional(Context* c, unsigned condition, lir::Constant* a);
|
|||||||
|
|
||||||
void sseMoveRR(Context* c,
|
void sseMoveRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void sseMoveCR(Context* c,
|
void sseMoveCR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void sseMoveMR(Context* c,
|
void sseMoveMR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void sseMoveRM(Context* c,
|
void sseMoveRM(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
UNUSED unsigned bSize,
|
UNUSED unsigned bSize,
|
||||||
lir::Memory* b);
|
lir::Memory* b);
|
||||||
|
|
||||||
@ -107,9 +107,9 @@ void branchFloat(Context* c, lir::TernaryOperation op, lir::Constant* target);
|
|||||||
|
|
||||||
void floatRegOp(Context* c,
|
void floatRegOp(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
uint8_t op,
|
uint8_t op,
|
||||||
uint8_t mod = 0xc0);
|
uint8_t mod = 0xc0);
|
||||||
|
|
||||||
@ -117,14 +117,14 @@ void floatMemOp(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
uint8_t op);
|
uint8_t op);
|
||||||
|
|
||||||
void moveCR2(Context* c,
|
void moveCR2(Context* c,
|
||||||
UNUSED unsigned aSize,
|
UNUSED unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
UNUSED unsigned bSize,
|
UNUSED unsigned bSize,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
unsigned promiseOffset);
|
unsigned promiseOffset);
|
||||||
|
|
||||||
} // namespace x86
|
} // namespace x86
|
||||||
|
@ -78,7 +78,7 @@ void longCallC(Context* c, unsigned size, lir::Constant* a)
|
|||||||
assertT(c, size == vm::TargetBytesPerWord);
|
assertT(c, size == vm::TargetBytesPerWord);
|
||||||
|
|
||||||
if (vm::TargetBytesPerWord == 8) {
|
if (vm::TargetBytesPerWord == 8) {
|
||||||
lir::Register r(LongJumpRegister);
|
lir::RegisterPair r(LongJumpRegister);
|
||||||
moveCR2(c, size, a, size, &r, 11);
|
moveCR2(c, size, a, size, &r, 11);
|
||||||
callR(c, size, &r);
|
callR(c, size, &r);
|
||||||
} else {
|
} else {
|
||||||
@ -86,7 +86,7 @@ void longCallC(Context* c, unsigned size, lir::Constant* a)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void jumpR(Context* c, unsigned size UNUSED, lir::Register* a)
|
void jumpR(Context* c, unsigned size UNUSED, lir::RegisterPair* a)
|
||||||
{
|
{
|
||||||
assertT(c, size == vm::TargetBytesPerWord);
|
assertT(c, size == vm::TargetBytesPerWord);
|
||||||
|
|
||||||
@ -115,7 +115,7 @@ void longJumpC(Context* c, unsigned size, lir::Constant* a)
|
|||||||
assertT(c, size == vm::TargetBytesPerWord);
|
assertT(c, size == vm::TargetBytesPerWord);
|
||||||
|
|
||||||
if (vm::TargetBytesPerWord == 8) {
|
if (vm::TargetBytesPerWord == 8) {
|
||||||
lir::Register r(LongJumpRegister);
|
lir::RegisterPair r(LongJumpRegister);
|
||||||
moveCR2(c, size, a, size, &r, 11);
|
moveCR2(c, size, a, size, &r, 11);
|
||||||
jumpR(c, size, &r);
|
jumpR(c, size, &r);
|
||||||
} else {
|
} else {
|
||||||
@ -123,7 +123,7 @@ void longJumpC(Context* c, unsigned size, lir::Constant* a)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void callR(Context* c, unsigned size UNUSED, lir::Register* a)
|
void callR(Context* c, unsigned size UNUSED, lir::RegisterPair* a)
|
||||||
{
|
{
|
||||||
assertT(c, size == vm::TargetBytesPerWord);
|
assertT(c, size == vm::TargetBytesPerWord);
|
||||||
|
|
||||||
@ -177,10 +177,10 @@ void alignedLongJumpC(Context* c, unsigned size, lir::Constant* a)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void pushR(Context* c, unsigned size, lir::Register* a)
|
void pushR(Context* c, unsigned size, lir::RegisterPair* a)
|
||||||
{
|
{
|
||||||
if (vm::TargetBytesPerWord == 4 and size == 8) {
|
if (vm::TargetBytesPerWord == 4 and size == 8) {
|
||||||
lir::Register ah(a->high);
|
lir::RegisterPair ah(a->high);
|
||||||
|
|
||||||
pushR(c, 4, &ah);
|
pushR(c, 4, &ah);
|
||||||
pushR(c, 4, a);
|
pushR(c, 4, a);
|
||||||
@ -190,10 +190,10 @@ void pushR(Context* c, unsigned size, lir::Register* a)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void popR(Context* c, unsigned size, lir::Register* a)
|
void popR(Context* c, unsigned size, lir::RegisterPair* a)
|
||||||
{
|
{
|
||||||
if (vm::TargetBytesPerWord == 4 and size == 8) {
|
if (vm::TargetBytesPerWord == 4 and size == 8) {
|
||||||
lir::Register ah(a->high);
|
lir::RegisterPair ah(a->high);
|
||||||
|
|
||||||
popR(c, 4, a);
|
popR(c, 4, a);
|
||||||
popR(c, 4, &ah);
|
popR(c, 4, &ah);
|
||||||
@ -206,7 +206,7 @@ void popR(Context* c, unsigned size, lir::Register* a)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void negateR(Context* c, unsigned size, lir::Register* a)
|
void negateR(Context* c, unsigned size, lir::RegisterPair* a)
|
||||||
{
|
{
|
||||||
if (vm::TargetBytesPerWord == 4 and size == 8) {
|
if (vm::TargetBytesPerWord == 4 and size == 8) {
|
||||||
assertT(c, a->low == rax and a->high == rdx);
|
assertT(c, a->low == rax and a->high == rdx);
|
||||||
@ -214,7 +214,7 @@ void negateR(Context* c, unsigned size, lir::Register* a)
|
|||||||
ResolvedPromise zeroPromise(0);
|
ResolvedPromise zeroPromise(0);
|
||||||
lir::Constant zero(&zeroPromise);
|
lir::Constant zero(&zeroPromise);
|
||||||
|
|
||||||
lir::Register ah(a->high);
|
lir::RegisterPair ah(a->high);
|
||||||
|
|
||||||
negateR(c, 4, a);
|
negateR(c, 4, a);
|
||||||
addCarryCR(c, 4, &zero, &ah);
|
addCarryCR(c, 4, &zero, &ah);
|
||||||
@ -227,9 +227,9 @@ void negateR(Context* c, unsigned size, lir::Register* a)
|
|||||||
|
|
||||||
void negateRR(Context* c,
|
void negateRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b UNUSED)
|
lir::RegisterPair* b UNUSED)
|
||||||
{
|
{
|
||||||
assertT(c, aSize == bSize);
|
assertT(c, aSize == bSize);
|
||||||
|
|
||||||
@ -240,7 +240,7 @@ void moveCR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
if (isFloatReg(b)) {
|
if (isFloatReg(b)) {
|
||||||
sseMoveCR(c, aSize, a, bSize, b);
|
sseMoveCR(c, aSize, a, bSize, b);
|
||||||
@ -253,7 +253,7 @@ void moveZCR(Context* c,
|
|||||||
unsigned aSize UNUSED,
|
unsigned aSize UNUSED,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, not isFloatReg(b));
|
assertT(c, not isFloatReg(b));
|
||||||
assertT(c, aSize == 2);
|
assertT(c, aSize == 2);
|
||||||
@ -267,9 +267,9 @@ void moveZCR(Context* c,
|
|||||||
|
|
||||||
void swapRR(Context* c,
|
void swapRR(Context* c,
|
||||||
unsigned aSize UNUSED,
|
unsigned aSize UNUSED,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, aSize == bSize);
|
assertT(c, aSize == bSize);
|
||||||
assertT(c, aSize == vm::TargetBytesPerWord);
|
assertT(c, aSize == vm::TargetBytesPerWord);
|
||||||
@ -281,9 +281,9 @@ void swapRR(Context* c,
|
|||||||
|
|
||||||
void moveRR(Context* c,
|
void moveRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
UNUSED unsigned bSize,
|
UNUSED unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
if (isFloatReg(a) or isFloatReg(b)) {
|
if (isFloatReg(a) or isFloatReg(b)) {
|
||||||
sseMoveRR(c, aSize, a, bSize, b);
|
sseMoveRR(c, aSize, a, bSize, b);
|
||||||
@ -291,8 +291,8 @@ void moveRR(Context* c,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (vm::TargetBytesPerWord == 4 and aSize == 8 and bSize == 8) {
|
if (vm::TargetBytesPerWord == 4 and aSize == 8 and bSize == 8) {
|
||||||
lir::Register ah(a->high);
|
lir::RegisterPair ah(a->high);
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
|
|
||||||
if (a->high == b->low) {
|
if (a->high == b->low) {
|
||||||
if (a->low == b->high) {
|
if (a->low == b->high) {
|
||||||
@ -366,7 +366,7 @@ void moveMR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
if (isFloatReg(b)) {
|
if (isFloatReg(b)) {
|
||||||
sseMoveMR(c, aSize, a, bSize, b);
|
sseMoveMR(c, aSize, a, bSize, b);
|
||||||
@ -408,7 +408,7 @@ void moveMR(Context* c,
|
|||||||
case 8:
|
case 8:
|
||||||
if (vm::TargetBytesPerWord == 4 and bSize == 8) {
|
if (vm::TargetBytesPerWord == 4 and bSize == 8) {
|
||||||
lir::Memory ah(a->base, a->offset + 4, a->index, a->scale);
|
lir::Memory ah(a->base, a->offset + 4, a->index, a->scale);
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
|
|
||||||
moveMR(c, 4, a, 4, b);
|
moveMR(c, 4, a, 4, b);
|
||||||
moveMR(c, 4, &ah, 4, &bh);
|
moveMR(c, 4, &ah, 4, &bh);
|
||||||
@ -426,7 +426,7 @@ void moveMR(Context* c,
|
|||||||
|
|
||||||
void moveRM(Context* c,
|
void moveRM(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Memory* b)
|
lir::Memory* b)
|
||||||
{
|
{
|
||||||
@ -469,7 +469,7 @@ void moveRM(Context* c,
|
|||||||
opcode(c, 0x89);
|
opcode(c, 0x89);
|
||||||
modrmSibImm(c, a, b);
|
modrmSibImm(c, a, b);
|
||||||
} else {
|
} else {
|
||||||
lir::Register ah(a->high);
|
lir::RegisterPair ah(a->high);
|
||||||
lir::Memory bh(b->base, b->offset + 4, b->index, b->scale);
|
lir::Memory bh(b->base, b->offset + 4, b->index, b->scale);
|
||||||
|
|
||||||
moveRM(c, 4, a, 4, b);
|
moveRM(c, 4, a, 4, b);
|
||||||
@ -486,7 +486,7 @@ void moveAR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Address* a,
|
lir::Address* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, vm::TargetBytesPerWord == 8 or (aSize == 4 and bSize == 4));
|
assertT(c, vm::TargetBytesPerWord == 8 or (aSize == 4 and bSize == 4));
|
||||||
|
|
||||||
@ -539,7 +539,7 @@ void moveCM(Context* c,
|
|||||||
modrmSibImm(c, 0, b->scale, b->index, b->base, b->offset);
|
modrmSibImm(c, 0, b->scale, b->index, b->base, b->offset);
|
||||||
c->code.append4(a->value->value());
|
c->code.append4(a->value->value());
|
||||||
} else {
|
} else {
|
||||||
lir::Register tmp(c->client->acquireTemporary(GeneralRegisterMask));
|
lir::RegisterPair tmp(c->client->acquireTemporary(GeneralRegisterMask));
|
||||||
moveCR(c, 8, a, 8, &tmp);
|
moveCR(c, 8, a, 8, &tmp);
|
||||||
moveRM(c, 8, &tmp, 8, b);
|
moveRM(c, 8, &tmp, 8, b);
|
||||||
c->client->releaseTemporary(tmp.low);
|
c->client->releaseTemporary(tmp.low);
|
||||||
@ -562,9 +562,9 @@ void moveCM(Context* c,
|
|||||||
|
|
||||||
void moveZRR(Context* c,
|
void moveZRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
switch (aSize) {
|
switch (aSize) {
|
||||||
case 2:
|
case 2:
|
||||||
@ -582,7 +582,7 @@ void moveZMR(Context* c,
|
|||||||
unsigned aSize UNUSED,
|
unsigned aSize UNUSED,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, bSize == vm::TargetBytesPerWord);
|
assertT(c, bSize == vm::TargetBytesPerWord);
|
||||||
assertT(c, aSize == 2);
|
assertT(c, aSize == 2);
|
||||||
@ -592,7 +592,7 @@ void moveZMR(Context* c,
|
|||||||
modrmSibImm(c, b->low, a->scale, a->index, a->base, a->offset);
|
modrmSibImm(c, b->low, a->scale, a->index, a->base, a->offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
void addCarryRR(Context* c, unsigned size, lir::Register* a, lir::Register* b)
|
void addCarryRR(Context* c, unsigned size, lir::RegisterPair* a, lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, vm::TargetBytesPerWord == 8 or size == 4);
|
assertT(c, vm::TargetBytesPerWord == 8 or size == 4);
|
||||||
|
|
||||||
@ -603,15 +603,15 @@ void addCarryRR(Context* c, unsigned size, lir::Register* a, lir::Register* b)
|
|||||||
|
|
||||||
void addRR(Context* c,
|
void addRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, aSize == bSize);
|
assertT(c, aSize == bSize);
|
||||||
|
|
||||||
if (vm::TargetBytesPerWord == 4 and aSize == 8) {
|
if (vm::TargetBytesPerWord == 4 and aSize == 8) {
|
||||||
lir::Register ah(a->high);
|
lir::RegisterPair ah(a->high);
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
|
|
||||||
addRR(c, 4, a, 4, b);
|
addRR(c, 4, a, 4, b);
|
||||||
addCarryRR(c, 4, &ah, &bh);
|
addCarryRR(c, 4, &ah, &bh);
|
||||||
@ -622,7 +622,7 @@ void addRR(Context* c,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void addCarryCR(Context* c, unsigned size, lir::Constant* a, lir::Register* b)
|
void addCarryCR(Context* c, unsigned size, lir::Constant* a, lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
int64_t v = a->value->value();
|
int64_t v = a->value->value();
|
||||||
maybeRex(c, size, b);
|
maybeRex(c, size, b);
|
||||||
@ -639,7 +639,7 @@ void addCR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, aSize == bSize);
|
assertT(c, aSize == bSize);
|
||||||
|
|
||||||
@ -652,7 +652,7 @@ void addCR(Context* c,
|
|||||||
ResolvedPromise low(v & 0xFFFFFFFF);
|
ResolvedPromise low(v & 0xFFFFFFFF);
|
||||||
lir::Constant al(&low);
|
lir::Constant al(&low);
|
||||||
|
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
|
|
||||||
addCR(c, 4, &al, 4, b);
|
addCR(c, 4, &al, 4, b);
|
||||||
addCarryCR(c, 4, &ah, &bh);
|
addCarryCR(c, 4, &ah, &bh);
|
||||||
@ -667,7 +667,7 @@ void addCR(Context* c,
|
|||||||
c->code.append4(v);
|
c->code.append4(v);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
lir::Register tmp(c->client->acquireTemporary(GeneralRegisterMask));
|
lir::RegisterPair tmp(c->client->acquireTemporary(GeneralRegisterMask));
|
||||||
moveCR(c, aSize, a, aSize, &tmp);
|
moveCR(c, aSize, a, aSize, &tmp);
|
||||||
addRR(c, aSize, &tmp, bSize, b);
|
addRR(c, aSize, &tmp, bSize, b);
|
||||||
c->client->releaseTemporary(tmp.low);
|
c->client->releaseTemporary(tmp.low);
|
||||||
@ -679,7 +679,7 @@ void addCR(Context* c,
|
|||||||
void subtractBorrowCR(Context* c,
|
void subtractBorrowCR(Context* c,
|
||||||
unsigned size UNUSED,
|
unsigned size UNUSED,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, vm::TargetBytesPerWord == 8 or size == 4);
|
assertT(c, vm::TargetBytesPerWord == 8 or size == 4);
|
||||||
|
|
||||||
@ -697,7 +697,7 @@ void subtractCR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, aSize == bSize);
|
assertT(c, aSize == bSize);
|
||||||
|
|
||||||
@ -710,7 +710,7 @@ void subtractCR(Context* c,
|
|||||||
ResolvedPromise low(v & 0xFFFFFFFF);
|
ResolvedPromise low(v & 0xFFFFFFFF);
|
||||||
lir::Constant al(&low);
|
lir::Constant al(&low);
|
||||||
|
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
|
|
||||||
subtractCR(c, 4, &al, 4, b);
|
subtractCR(c, 4, &al, 4, b);
|
||||||
subtractBorrowCR(c, 4, &ah, &bh);
|
subtractBorrowCR(c, 4, &ah, &bh);
|
||||||
@ -725,7 +725,7 @@ void subtractCR(Context* c,
|
|||||||
c->code.append4(v);
|
c->code.append4(v);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
lir::Register tmp(c->client->acquireTemporary(GeneralRegisterMask));
|
lir::RegisterPair tmp(c->client->acquireTemporary(GeneralRegisterMask));
|
||||||
moveCR(c, aSize, a, aSize, &tmp);
|
moveCR(c, aSize, a, aSize, &tmp);
|
||||||
subtractRR(c, aSize, &tmp, bSize, b);
|
subtractRR(c, aSize, &tmp, bSize, b);
|
||||||
c->client->releaseTemporary(tmp.low);
|
c->client->releaseTemporary(tmp.low);
|
||||||
@ -736,8 +736,8 @@ void subtractCR(Context* c,
|
|||||||
|
|
||||||
void subtractBorrowRR(Context* c,
|
void subtractBorrowRR(Context* c,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, vm::TargetBytesPerWord == 8 or size == 4);
|
assertT(c, vm::TargetBytesPerWord == 8 or size == 4);
|
||||||
|
|
||||||
@ -748,15 +748,15 @@ void subtractBorrowRR(Context* c,
|
|||||||
|
|
||||||
void subtractRR(Context* c,
|
void subtractRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, aSize == bSize);
|
assertT(c, aSize == bSize);
|
||||||
|
|
||||||
if (vm::TargetBytesPerWord == 4 and aSize == 8) {
|
if (vm::TargetBytesPerWord == 4 and aSize == 8) {
|
||||||
lir::Register ah(a->high);
|
lir::RegisterPair ah(a->high);
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
|
|
||||||
subtractRR(c, 4, a, 4, b);
|
subtractRR(c, 4, a, 4, b);
|
||||||
subtractBorrowRR(c, 4, &ah, &bh);
|
subtractBorrowRR(c, 4, &ah, &bh);
|
||||||
@ -769,15 +769,15 @@ void subtractRR(Context* c,
|
|||||||
|
|
||||||
void andRR(Context* c,
|
void andRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, aSize == bSize);
|
assertT(c, aSize == bSize);
|
||||||
|
|
||||||
if (vm::TargetBytesPerWord == 4 and aSize == 8) {
|
if (vm::TargetBytesPerWord == 4 and aSize == 8) {
|
||||||
lir::Register ah(a->high);
|
lir::RegisterPair ah(a->high);
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
|
|
||||||
andRR(c, 4, a, 4, b);
|
andRR(c, 4, a, 4, b);
|
||||||
andRR(c, 4, &ah, 4, &bh);
|
andRR(c, 4, &ah, 4, &bh);
|
||||||
@ -792,7 +792,7 @@ void andCR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, aSize == bSize);
|
assertT(c, aSize == bSize);
|
||||||
|
|
||||||
@ -805,7 +805,7 @@ void andCR(Context* c,
|
|||||||
ResolvedPromise low(v & 0xFFFFFFFF);
|
ResolvedPromise low(v & 0xFFFFFFFF);
|
||||||
lir::Constant al(&low);
|
lir::Constant al(&low);
|
||||||
|
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
|
|
||||||
andCR(c, 4, &al, 4, b);
|
andCR(c, 4, &al, 4, b);
|
||||||
andCR(c, 4, &ah, 4, &bh);
|
andCR(c, 4, &ah, 4, &bh);
|
||||||
@ -820,7 +820,7 @@ void andCR(Context* c,
|
|||||||
c->code.append4(v);
|
c->code.append4(v);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
lir::Register tmp(c->client->acquireTemporary(GeneralRegisterMask));
|
lir::RegisterPair tmp(c->client->acquireTemporary(GeneralRegisterMask));
|
||||||
moveCR(c, aSize, a, aSize, &tmp);
|
moveCR(c, aSize, a, aSize, &tmp);
|
||||||
andRR(c, aSize, &tmp, bSize, b);
|
andRR(c, aSize, &tmp, bSize, b);
|
||||||
c->client->releaseTemporary(tmp.low);
|
c->client->releaseTemporary(tmp.low);
|
||||||
@ -830,15 +830,15 @@ void andCR(Context* c,
|
|||||||
|
|
||||||
void orRR(Context* c,
|
void orRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, aSize == bSize);
|
assertT(c, aSize == bSize);
|
||||||
|
|
||||||
if (vm::TargetBytesPerWord == 4 and aSize == 8) {
|
if (vm::TargetBytesPerWord == 4 and aSize == 8) {
|
||||||
lir::Register ah(a->high);
|
lir::RegisterPair ah(a->high);
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
|
|
||||||
orRR(c, 4, a, 4, b);
|
orRR(c, 4, a, 4, b);
|
||||||
orRR(c, 4, &ah, 4, &bh);
|
orRR(c, 4, &ah, 4, &bh);
|
||||||
@ -853,7 +853,7 @@ void orCR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, aSize == bSize);
|
assertT(c, aSize == bSize);
|
||||||
|
|
||||||
@ -866,7 +866,7 @@ void orCR(Context* c,
|
|||||||
ResolvedPromise low(v & 0xFFFFFFFF);
|
ResolvedPromise low(v & 0xFFFFFFFF);
|
||||||
lir::Constant al(&low);
|
lir::Constant al(&low);
|
||||||
|
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
|
|
||||||
orCR(c, 4, &al, 4, b);
|
orCR(c, 4, &al, 4, b);
|
||||||
orCR(c, 4, &ah, 4, &bh);
|
orCR(c, 4, &ah, 4, &bh);
|
||||||
@ -881,7 +881,7 @@ void orCR(Context* c,
|
|||||||
c->code.append4(v);
|
c->code.append4(v);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
lir::Register tmp(c->client->acquireTemporary(GeneralRegisterMask));
|
lir::RegisterPair tmp(c->client->acquireTemporary(GeneralRegisterMask));
|
||||||
moveCR(c, aSize, a, aSize, &tmp);
|
moveCR(c, aSize, a, aSize, &tmp);
|
||||||
orRR(c, aSize, &tmp, bSize, b);
|
orRR(c, aSize, &tmp, bSize, b);
|
||||||
c->client->releaseTemporary(tmp.low);
|
c->client->releaseTemporary(tmp.low);
|
||||||
@ -892,13 +892,13 @@ void orCR(Context* c,
|
|||||||
|
|
||||||
void xorRR(Context* c,
|
void xorRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
if (vm::TargetBytesPerWord == 4 and aSize == 8) {
|
if (vm::TargetBytesPerWord == 4 and aSize == 8) {
|
||||||
lir::Register ah(a->high);
|
lir::RegisterPair ah(a->high);
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
|
|
||||||
xorRR(c, 4, a, 4, b);
|
xorRR(c, 4, a, 4, b);
|
||||||
xorRR(c, 4, &ah, 4, &bh);
|
xorRR(c, 4, &ah, 4, &bh);
|
||||||
@ -913,7 +913,7 @@ void xorCR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, aSize == bSize);
|
assertT(c, aSize == bSize);
|
||||||
|
|
||||||
@ -926,7 +926,7 @@ void xorCR(Context* c,
|
|||||||
ResolvedPromise low(v & 0xFFFFFFFF);
|
ResolvedPromise low(v & 0xFFFFFFFF);
|
||||||
lir::Constant al(&low);
|
lir::Constant al(&low);
|
||||||
|
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
|
|
||||||
xorCR(c, 4, &al, 4, b);
|
xorCR(c, 4, &al, 4, b);
|
||||||
xorCR(c, 4, &ah, 4, &bh);
|
xorCR(c, 4, &ah, 4, &bh);
|
||||||
@ -941,7 +941,7 @@ void xorCR(Context* c,
|
|||||||
c->code.append4(v);
|
c->code.append4(v);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
lir::Register tmp(c->client->acquireTemporary(GeneralRegisterMask));
|
lir::RegisterPair tmp(c->client->acquireTemporary(GeneralRegisterMask));
|
||||||
moveCR(c, aSize, a, aSize, &tmp);
|
moveCR(c, aSize, a, aSize, &tmp);
|
||||||
xorRR(c, aSize, &tmp, bSize, b);
|
xorRR(c, aSize, &tmp, bSize, b);
|
||||||
c->client->releaseTemporary(tmp.low);
|
c->client->releaseTemporary(tmp.low);
|
||||||
@ -952,9 +952,9 @@ void xorCR(Context* c,
|
|||||||
|
|
||||||
void multiplyRR(Context* c,
|
void multiplyRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, aSize == bSize);
|
assertT(c, aSize == bSize);
|
||||||
|
|
||||||
@ -966,12 +966,12 @@ void multiplyRR(Context* c,
|
|||||||
|
|
||||||
c->client->save(rax);
|
c->client->save(rax);
|
||||||
|
|
||||||
lir::Register axdx(rax, rdx);
|
lir::RegisterPair axdx(rax, rdx);
|
||||||
lir::Register ah(a->high);
|
lir::RegisterPair ah(a->high);
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
|
|
||||||
lir::Register tmp(-1);
|
lir::RegisterPair tmp(-1);
|
||||||
lir::Register* scratch;
|
lir::RegisterPair* scratch;
|
||||||
if (a->low == b->low) {
|
if (a->low == b->low) {
|
||||||
tmp.low = c->client->acquireTemporary(GeneralRegisterMask & ~(1 << rax));
|
tmp.low = c->client->acquireTemporary(GeneralRegisterMask & ~(1 << rax));
|
||||||
scratch = &tmp;
|
scratch = &tmp;
|
||||||
@ -1003,9 +1003,9 @@ void multiplyRR(Context* c,
|
|||||||
|
|
||||||
void compareRR(Context* c,
|
void compareRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, aSize == bSize);
|
assertT(c, aSize == bSize);
|
||||||
assertT(c, aSize <= vm::TargetBytesPerWord);
|
assertT(c, aSize <= vm::TargetBytesPerWord);
|
||||||
@ -1019,7 +1019,7 @@ void compareCR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, aSize == bSize);
|
assertT(c, aSize == bSize);
|
||||||
assertT(c, vm::TargetBytesPerWord == 8 or aSize == 4);
|
assertT(c, vm::TargetBytesPerWord == 8 or aSize == 4);
|
||||||
@ -1035,7 +1035,7 @@ void compareCR(Context* c,
|
|||||||
c->code.append4(v);
|
c->code.append4(v);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
lir::Register tmp(c->client->acquireTemporary(GeneralRegisterMask));
|
lir::RegisterPair tmp(c->client->acquireTemporary(GeneralRegisterMask));
|
||||||
moveCR(c, aSize, a, aSize, &tmp);
|
moveCR(c, aSize, a, aSize, &tmp);
|
||||||
compareRR(c, aSize, &tmp, bSize, b);
|
compareRR(c, aSize, &tmp, bSize, b);
|
||||||
c->client->releaseTemporary(tmp.low);
|
c->client->releaseTemporary(tmp.low);
|
||||||
@ -1044,7 +1044,7 @@ void compareCR(Context* c,
|
|||||||
|
|
||||||
void compareRM(Context* c,
|
void compareRM(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Memory* b)
|
lir::Memory* b)
|
||||||
{
|
{
|
||||||
@ -1082,7 +1082,7 @@ void compareCM(Context* c,
|
|||||||
abort(c);
|
abort(c);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
lir::Register tmp(c->client->acquireTemporary(GeneralRegisterMask));
|
lir::RegisterPair tmp(c->client->acquireTemporary(GeneralRegisterMask));
|
||||||
moveCR(c, aSize, a, bSize, &tmp);
|
moveCR(c, aSize, a, bSize, &tmp);
|
||||||
compareRM(c, bSize, &tmp, bSize, b);
|
compareRM(c, bSize, &tmp, bSize, b);
|
||||||
c->client->releaseTemporary(tmp.low);
|
c->client->releaseTemporary(tmp.low);
|
||||||
@ -1091,9 +1091,9 @@ void compareCM(Context* c,
|
|||||||
|
|
||||||
void compareFloatRR(Context* c,
|
void compareFloatRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, aSize == bSize);
|
assertT(c, aSize == bSize);
|
||||||
|
|
||||||
@ -1192,16 +1192,16 @@ void branchLong(Context* c,
|
|||||||
void branchRR(Context* c,
|
void branchRR(Context* c,
|
||||||
lir::TernaryOperation op,
|
lir::TernaryOperation op,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Constant* target)
|
lir::Constant* target)
|
||||||
{
|
{
|
||||||
if (isFloatBranch(op)) {
|
if (isFloatBranch(op)) {
|
||||||
compareFloatRR(c, size, a, size, b);
|
compareFloatRR(c, size, a, size, b);
|
||||||
branchFloat(c, op, target);
|
branchFloat(c, op, target);
|
||||||
} else if (size > vm::TargetBytesPerWord) {
|
} else if (size > vm::TargetBytesPerWord) {
|
||||||
lir::Register ah(a->high);
|
lir::RegisterPair ah(a->high);
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
|
|
||||||
branchLong(c, op, a, &ah, b, &bh, target, CAST2(compareRR));
|
branchLong(c, op, a, &ah, b, &bh, target, CAST2(compareRR));
|
||||||
} else {
|
} else {
|
||||||
@ -1214,7 +1214,7 @@ void branchCR(Context* c,
|
|||||||
lir::TernaryOperation op,
|
lir::TernaryOperation op,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Constant* target)
|
lir::Constant* target)
|
||||||
{
|
{
|
||||||
assertT(c, not isFloatBranch(op));
|
assertT(c, not isFloatBranch(op));
|
||||||
@ -1228,7 +1228,7 @@ void branchCR(Context* c,
|
|||||||
ResolvedPromise high((v >> 32) & ~static_cast<uintptr_t>(0));
|
ResolvedPromise high((v >> 32) & ~static_cast<uintptr_t>(0));
|
||||||
lir::Constant ah(&high);
|
lir::Constant ah(&high);
|
||||||
|
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
|
|
||||||
branchLong(c, op, &al, &ah, b, &bh, target, CAST2(compareCR));
|
branchLong(c, op, &al, &ah, b, &bh, target, CAST2(compareCR));
|
||||||
} else {
|
} else {
|
||||||
@ -1240,7 +1240,7 @@ void branchCR(Context* c,
|
|||||||
void branchRM(Context* c,
|
void branchRM(Context* c,
|
||||||
lir::TernaryOperation op,
|
lir::TernaryOperation op,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Memory* b,
|
lir::Memory* b,
|
||||||
lir::Constant* target)
|
lir::Constant* target)
|
||||||
{
|
{
|
||||||
@ -1269,13 +1269,13 @@ void multiplyCR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, aSize == bSize);
|
assertT(c, aSize == bSize);
|
||||||
|
|
||||||
if (vm::TargetBytesPerWord == 4 and aSize == 8) {
|
if (vm::TargetBytesPerWord == 4 and aSize == 8) {
|
||||||
const RegisterMask mask = GeneralRegisterMask & ~((1 << rax) | (1 << rdx));
|
const RegisterMask mask = GeneralRegisterMask & ~((1 << rax) | (1 << rdx));
|
||||||
lir::Register tmp(c->client->acquireTemporary(mask),
|
lir::RegisterPair tmp(c->client->acquireTemporary(mask),
|
||||||
c->client->acquireTemporary(mask));
|
c->client->acquireTemporary(mask));
|
||||||
|
|
||||||
moveCR(c, aSize, a, aSize, &tmp);
|
moveCR(c, aSize, a, aSize, &tmp);
|
||||||
@ -1297,7 +1297,7 @@ void multiplyCR(Context* c,
|
|||||||
c->code.append4(v);
|
c->code.append4(v);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
lir::Register tmp(c->client->acquireTemporary(GeneralRegisterMask));
|
lir::RegisterPair tmp(c->client->acquireTemporary(GeneralRegisterMask));
|
||||||
moveCR(c, aSize, a, aSize, &tmp);
|
moveCR(c, aSize, a, aSize, &tmp);
|
||||||
multiplyRR(c, aSize, &tmp, bSize, b);
|
multiplyRR(c, aSize, &tmp, bSize, b);
|
||||||
c->client->releaseTemporary(tmp.low);
|
c->client->releaseTemporary(tmp.low);
|
||||||
@ -1308,9 +1308,9 @@ void multiplyCR(Context* c,
|
|||||||
|
|
||||||
void divideRR(Context* c,
|
void divideRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b UNUSED)
|
lir::RegisterPair* b UNUSED)
|
||||||
{
|
{
|
||||||
assertT(c, aSize == bSize);
|
assertT(c, aSize == bSize);
|
||||||
|
|
||||||
@ -1327,9 +1327,9 @@ void divideRR(Context* c,
|
|||||||
|
|
||||||
void remainderRR(Context* c,
|
void remainderRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, aSize == bSize);
|
assertT(c, aSize == bSize);
|
||||||
|
|
||||||
@ -1343,28 +1343,28 @@ void remainderRR(Context* c,
|
|||||||
maybeRex(c, aSize, b, a);
|
maybeRex(c, aSize, b, a);
|
||||||
opcode(c, 0xf7, 0xf8 + regCode(a));
|
opcode(c, 0xf7, 0xf8 + regCode(a));
|
||||||
|
|
||||||
lir::Register dx(rdx);
|
lir::RegisterPair dx(rdx);
|
||||||
moveRR(c, vm::TargetBytesPerWord, &dx, vm::TargetBytesPerWord, b);
|
moveRR(c, vm::TargetBytesPerWord, &dx, vm::TargetBytesPerWord, b);
|
||||||
}
|
}
|
||||||
|
|
||||||
void doShift(Context* c,
|
void doShift(Context* c,
|
||||||
UNUSED void (*shift)(Context*,
|
UNUSED void (*shift)(Context*,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register*,
|
lir::RegisterPair*,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register*),
|
lir::RegisterPair*),
|
||||||
int type,
|
int type,
|
||||||
UNUSED unsigned aSize,
|
UNUSED unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
int64_t v = a->value->value();
|
int64_t v = a->value->value();
|
||||||
|
|
||||||
if (vm::TargetBytesPerWord == 4 and bSize == 8) {
|
if (vm::TargetBytesPerWord == 4 and bSize == 8) {
|
||||||
c->client->save(rcx);
|
c->client->save(rcx);
|
||||||
|
|
||||||
lir::Register cx(rcx);
|
lir::RegisterPair cx(rcx);
|
||||||
ResolvedPromise promise(v & 0x3F);
|
ResolvedPromise promise(v & 0x3F);
|
||||||
lir::Constant masked(&promise);
|
lir::Constant masked(&promise);
|
||||||
moveCR(c, 4, &masked, 4, &cx);
|
moveCR(c, 4, &masked, 4, &cx);
|
||||||
@ -1384,12 +1384,12 @@ void doShift(Context* c,
|
|||||||
|
|
||||||
void shiftLeftRR(Context* c,
|
void shiftLeftRR(Context* c,
|
||||||
UNUSED unsigned aSize,
|
UNUSED unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
if (vm::TargetBytesPerWord == 4 and bSize == 8) {
|
if (vm::TargetBytesPerWord == 4 and bSize == 8) {
|
||||||
lir::Register cx(rcx);
|
lir::RegisterPair cx(rcx);
|
||||||
if (a->low != rcx) {
|
if (a->low != rcx) {
|
||||||
c->client->save(rcx);
|
c->client->save(rcx);
|
||||||
ResolvedPromise promise(0x3F);
|
ResolvedPromise promise(0x3F);
|
||||||
@ -1413,7 +1413,7 @@ void shiftLeftRR(Context* c,
|
|||||||
opcode(c, 0x7c); // jl
|
opcode(c, 0x7c); // jl
|
||||||
c->code.append(2 + 2);
|
c->code.append(2 + 2);
|
||||||
|
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
moveRR(c, 4, b, 4, &bh); // 2 bytes
|
moveRR(c, 4, b, 4, &bh); // 2 bytes
|
||||||
xorRR(c, 4, b, 4, b); // 2 bytes
|
xorRR(c, 4, b, 4, b); // 2 bytes
|
||||||
} else {
|
} else {
|
||||||
@ -1428,19 +1428,19 @@ void shiftLeftCR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
doShift(c, shiftLeftRR, 0xe0, aSize, a, bSize, b);
|
doShift(c, shiftLeftRR, 0xe0, aSize, a, bSize, b);
|
||||||
}
|
}
|
||||||
|
|
||||||
void shiftRightRR(Context* c,
|
void shiftRightRR(Context* c,
|
||||||
UNUSED unsigned aSize,
|
UNUSED unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
if (vm::TargetBytesPerWord == 4 and bSize == 8) {
|
if (vm::TargetBytesPerWord == 4 and bSize == 8) {
|
||||||
lir::Register cx(rcx);
|
lir::RegisterPair cx(rcx);
|
||||||
if (a->low != rcx) {
|
if (a->low != rcx) {
|
||||||
c->client->save(rcx);
|
c->client->save(rcx);
|
||||||
ResolvedPromise promise(0x3F);
|
ResolvedPromise promise(0x3F);
|
||||||
@ -1464,7 +1464,7 @@ void shiftRightRR(Context* c,
|
|||||||
opcode(c, 0x7c); // jl
|
opcode(c, 0x7c); // jl
|
||||||
c->code.append(2 + 3);
|
c->code.append(2 + 3);
|
||||||
|
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
moveRR(c, 4, &bh, 4, b); // 2 bytes
|
moveRR(c, 4, &bh, 4, b); // 2 bytes
|
||||||
|
|
||||||
// sar 31,high
|
// sar 31,high
|
||||||
@ -1482,19 +1482,19 @@ void shiftRightCR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
doShift(c, shiftRightRR, 0xf8, aSize, a, bSize, b);
|
doShift(c, shiftRightRR, 0xf8, aSize, a, bSize, b);
|
||||||
}
|
}
|
||||||
|
|
||||||
void unsignedShiftRightRR(Context* c,
|
void unsignedShiftRightRR(Context* c,
|
||||||
UNUSED unsigned aSize,
|
UNUSED unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
if (vm::TargetBytesPerWord == 4 and bSize == 8) {
|
if (vm::TargetBytesPerWord == 4 and bSize == 8) {
|
||||||
lir::Register cx(rcx);
|
lir::RegisterPair cx(rcx);
|
||||||
if (a->low != rcx) {
|
if (a->low != rcx) {
|
||||||
c->client->save(rcx);
|
c->client->save(rcx);
|
||||||
ResolvedPromise promise(0x3F);
|
ResolvedPromise promise(0x3F);
|
||||||
@ -1518,7 +1518,7 @@ void unsignedShiftRightRR(Context* c,
|
|||||||
opcode(c, 0x7c); // jl
|
opcode(c, 0x7c); // jl
|
||||||
c->code.append(2 + 2);
|
c->code.append(2 + 2);
|
||||||
|
|
||||||
lir::Register bh(b->high);
|
lir::RegisterPair bh(b->high);
|
||||||
moveRR(c, 4, &bh, 4, b); // 2 bytes
|
moveRR(c, 4, &bh, 4, b); // 2 bytes
|
||||||
xorRR(c, 4, &bh, 4, &bh); // 2 bytes
|
xorRR(c, 4, &bh, 4, &bh); // 2 bytes
|
||||||
} else {
|
} else {
|
||||||
@ -1533,16 +1533,16 @@ void unsignedShiftRightCR(Context* c,
|
|||||||
unsigned aSize UNUSED,
|
unsigned aSize UNUSED,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
doShift(c, unsignedShiftRightRR, 0xe8, aSize, a, bSize, b);
|
doShift(c, unsignedShiftRightRR, 0xe8, aSize, a, bSize, b);
|
||||||
}
|
}
|
||||||
|
|
||||||
void floatSqrtRR(Context* c,
|
void floatSqrtRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
floatRegOp(c, aSize, a, 4, b, 0x51);
|
floatRegOp(c, aSize, a, 4, b, 0x51);
|
||||||
}
|
}
|
||||||
@ -1551,16 +1551,16 @@ void floatSqrtMR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
floatMemOp(c, aSize, a, 4, b, 0x51);
|
floatMemOp(c, aSize, a, 4, b, 0x51);
|
||||||
}
|
}
|
||||||
|
|
||||||
void floatAddRR(Context* c,
|
void floatAddRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
floatRegOp(c, aSize, a, 4, b, 0x58);
|
floatRegOp(c, aSize, a, 4, b, 0x58);
|
||||||
}
|
}
|
||||||
@ -1569,16 +1569,16 @@ void floatAddMR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
floatMemOp(c, aSize, a, 4, b, 0x58);
|
floatMemOp(c, aSize, a, 4, b, 0x58);
|
||||||
}
|
}
|
||||||
|
|
||||||
void floatSubtractRR(Context* c,
|
void floatSubtractRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
floatRegOp(c, aSize, a, 4, b, 0x5c);
|
floatRegOp(c, aSize, a, 4, b, 0x5c);
|
||||||
}
|
}
|
||||||
@ -1587,16 +1587,16 @@ void floatSubtractMR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
floatMemOp(c, aSize, a, 4, b, 0x5c);
|
floatMemOp(c, aSize, a, 4, b, 0x5c);
|
||||||
}
|
}
|
||||||
|
|
||||||
void floatMultiplyRR(Context* c,
|
void floatMultiplyRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
floatRegOp(c, aSize, a, 4, b, 0x59);
|
floatRegOp(c, aSize, a, 4, b, 0x59);
|
||||||
}
|
}
|
||||||
@ -1605,16 +1605,16 @@ void floatMultiplyMR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
floatMemOp(c, aSize, a, 4, b, 0x59);
|
floatMemOp(c, aSize, a, 4, b, 0x59);
|
||||||
}
|
}
|
||||||
|
|
||||||
void floatDivideRR(Context* c,
|
void floatDivideRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
floatRegOp(c, aSize, a, 4, b, 0x5e);
|
floatRegOp(c, aSize, a, 4, b, 0x5e);
|
||||||
}
|
}
|
||||||
@ -1623,16 +1623,16 @@ void floatDivideMR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
floatMemOp(c, aSize, a, 4, b, 0x5e);
|
floatMemOp(c, aSize, a, 4, b, 0x5e);
|
||||||
}
|
}
|
||||||
|
|
||||||
void float2FloatRR(Context* c,
|
void float2FloatRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
floatRegOp(c, aSize, a, 4, b, 0x5a);
|
floatRegOp(c, aSize, a, 4, b, 0x5a);
|
||||||
}
|
}
|
||||||
@ -1641,16 +1641,16 @@ void float2FloatMR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
floatMemOp(c, aSize, a, 4, b, 0x5a);
|
floatMemOp(c, aSize, a, 4, b, 0x5a);
|
||||||
}
|
}
|
||||||
|
|
||||||
void float2IntRR(Context* c,
|
void float2IntRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, not isFloatReg(b));
|
assertT(c, not isFloatReg(b));
|
||||||
floatRegOp(c, aSize, a, bSize, b, 0x2c);
|
floatRegOp(c, aSize, a, bSize, b, 0x2c);
|
||||||
@ -1660,16 +1660,16 @@ void float2IntMR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
floatMemOp(c, aSize, a, bSize, b, 0x2c);
|
floatMemOp(c, aSize, a, bSize, b, 0x2c);
|
||||||
}
|
}
|
||||||
|
|
||||||
void int2FloatRR(Context* c,
|
void int2FloatRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
floatRegOp(c, bSize, a, aSize, b, 0x2a);
|
floatRegOp(c, bSize, a, aSize, b, 0x2a);
|
||||||
}
|
}
|
||||||
@ -1678,16 +1678,16 @@ void int2FloatMR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
floatMemOp(c, bSize, a, aSize, b, 0x2a);
|
floatMemOp(c, bSize, a, aSize, b, 0x2a);
|
||||||
}
|
}
|
||||||
|
|
||||||
void floatNegateRR(Context* c,
|
void floatNegateRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, isFloatReg(a) and isFloatReg(b));
|
assertT(c, isFloatReg(a) and isFloatReg(b));
|
||||||
// unlike most of the other floating point code, this does NOT
|
// unlike most of the other floating point code, this does NOT
|
||||||
@ -1696,7 +1696,7 @@ void floatNegateRR(Context* c,
|
|||||||
ResolvedPromise pcon(0x80000000);
|
ResolvedPromise pcon(0x80000000);
|
||||||
lir::Constant con(&pcon);
|
lir::Constant con(&pcon);
|
||||||
if (a->low == b->low) {
|
if (a->low == b->low) {
|
||||||
lir::Register tmp(c->client->acquireTemporary(FloatRegisterMask));
|
lir::RegisterPair tmp(c->client->acquireTemporary(FloatRegisterMask));
|
||||||
moveCR(c, 4, &con, 4, &tmp);
|
moveCR(c, 4, &con, 4, &tmp);
|
||||||
maybeRex(c, 4, a, &tmp);
|
maybeRex(c, 4, a, &tmp);
|
||||||
opcode(c, 0x0f, 0x57);
|
opcode(c, 0x0f, 0x57);
|
||||||
@ -1714,9 +1714,9 @@ void floatNegateRR(Context* c,
|
|||||||
|
|
||||||
void floatAbsoluteRR(Context* c,
|
void floatAbsoluteRR(Context* c,
|
||||||
unsigned aSize UNUSED,
|
unsigned aSize UNUSED,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, isFloatReg(a) and isFloatReg(b));
|
assertT(c, isFloatReg(a) and isFloatReg(b));
|
||||||
// unlike most of the other floating point code, this does NOT
|
// unlike most of the other floating point code, this does NOT
|
||||||
@ -1725,7 +1725,7 @@ void floatAbsoluteRR(Context* c,
|
|||||||
ResolvedPromise pcon(0x7fffffff);
|
ResolvedPromise pcon(0x7fffffff);
|
||||||
lir::Constant con(&pcon);
|
lir::Constant con(&pcon);
|
||||||
if (a->low == b->low) {
|
if (a->low == b->low) {
|
||||||
lir::Register tmp(c->client->acquireTemporary(FloatRegisterMask));
|
lir::RegisterPair tmp(c->client->acquireTemporary(FloatRegisterMask));
|
||||||
moveCR(c, 4, &con, 4, &tmp);
|
moveCR(c, 4, &con, 4, &tmp);
|
||||||
maybeRex(c, 4, a, &tmp);
|
maybeRex(c, 4, a, &tmp);
|
||||||
opcode(c, 0x0f, 0x54);
|
opcode(c, 0x0f, 0x54);
|
||||||
@ -1741,12 +1741,12 @@ void floatAbsoluteRR(Context* c,
|
|||||||
|
|
||||||
void absoluteRR(Context* c,
|
void absoluteRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b UNUSED)
|
lir::RegisterPair* b UNUSED)
|
||||||
{
|
{
|
||||||
assertT(c, aSize == bSize and a->low == rax and b->low == rax);
|
assertT(c, aSize == bSize and a->low == rax and b->low == rax);
|
||||||
lir::Register d(c->client->acquireTemporary(static_cast<uint64_t>(1) << rdx));
|
lir::RegisterPair d(c->client->acquireTemporary(static_cast<uint64_t>(1) << rdx));
|
||||||
maybeRex(c, aSize, a, b);
|
maybeRex(c, aSize, a, b);
|
||||||
opcode(c, 0x99);
|
opcode(c, 0x99);
|
||||||
xorRR(c, aSize, &d, aSize, a);
|
xorRR(c, aSize, &d, aSize, a);
|
||||||
|
@ -33,7 +33,7 @@ void callC(Context* c, unsigned size UNUSED, lir::Constant* a);
|
|||||||
|
|
||||||
void longCallC(Context* c, unsigned size, lir::Constant* a);
|
void longCallC(Context* c, unsigned size, lir::Constant* a);
|
||||||
|
|
||||||
void jumpR(Context* c, unsigned size UNUSED, lir::Register* a);
|
void jumpR(Context* c, unsigned size UNUSED, lir::RegisterPair* a);
|
||||||
|
|
||||||
void jumpC(Context* c, unsigned size UNUSED, lir::Constant* a);
|
void jumpC(Context* c, unsigned size UNUSED, lir::Constant* a);
|
||||||
|
|
||||||
@ -41,7 +41,7 @@ void jumpM(Context* c, unsigned size UNUSED, lir::Memory* a);
|
|||||||
|
|
||||||
void longJumpC(Context* c, unsigned size, lir::Constant* a);
|
void longJumpC(Context* c, unsigned size, lir::Constant* a);
|
||||||
|
|
||||||
void callR(Context* c, unsigned size UNUSED, lir::Register* a);
|
void callR(Context* c, unsigned size UNUSED, lir::RegisterPair* a);
|
||||||
|
|
||||||
void callM(Context* c, unsigned size UNUSED, lir::Memory* a);
|
void callM(Context* c, unsigned size UNUSED, lir::Memory* a);
|
||||||
|
|
||||||
@ -53,51 +53,51 @@ void alignedJumpC(Context* c, unsigned size, lir::Constant* a);
|
|||||||
|
|
||||||
void alignedLongJumpC(Context* c, unsigned size, lir::Constant* a);
|
void alignedLongJumpC(Context* c, unsigned size, lir::Constant* a);
|
||||||
|
|
||||||
void pushR(Context* c, unsigned size, lir::Register* a);
|
void pushR(Context* c, unsigned size, lir::RegisterPair* a);
|
||||||
|
|
||||||
void popR(Context* c, unsigned size, lir::Register* a);
|
void popR(Context* c, unsigned size, lir::RegisterPair* a);
|
||||||
|
|
||||||
void negateR(Context* c, unsigned size, lir::Register* a);
|
void negateR(Context* c, unsigned size, lir::RegisterPair* a);
|
||||||
|
|
||||||
void negateRR(Context* c,
|
void negateRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b UNUSED);
|
lir::RegisterPair* b UNUSED);
|
||||||
|
|
||||||
void moveCR(Context* c,
|
void moveCR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void moveZCR(Context* c,
|
void moveZCR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void swapRR(Context* c,
|
void swapRR(Context* c,
|
||||||
unsigned aSize UNUSED,
|
unsigned aSize UNUSED,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void moveRR(Context* c,
|
void moveRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
UNUSED unsigned bSize,
|
UNUSED unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void moveMR(Context* c,
|
void moveMR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void moveRM(Context* c,
|
void moveRM(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Memory* b);
|
lir::Memory* b);
|
||||||
|
|
||||||
@ -105,7 +105,7 @@ void moveAR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Address* a,
|
lir::Address* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void moveCM(Context* c,
|
void moveCM(Context* c,
|
||||||
unsigned aSize UNUSED,
|
unsigned aSize UNUSED,
|
||||||
@ -115,111 +115,111 @@ void moveCM(Context* c,
|
|||||||
|
|
||||||
void moveZRR(Context* c,
|
void moveZRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void moveZMR(Context* c,
|
void moveZMR(Context* c,
|
||||||
unsigned aSize UNUSED,
|
unsigned aSize UNUSED,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void addCarryRR(Context* c, unsigned size, lir::Register* a, lir::Register* b);
|
void addCarryRR(Context* c, unsigned size, lir::RegisterPair* a, lir::RegisterPair* b);
|
||||||
|
|
||||||
void addRR(Context* c,
|
void addRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void addCarryCR(Context* c, unsigned size, lir::Constant* a, lir::Register* b);
|
void addCarryCR(Context* c, unsigned size, lir::Constant* a, lir::RegisterPair* b);
|
||||||
|
|
||||||
void addCR(Context* c,
|
void addCR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void subtractBorrowCR(Context* c,
|
void subtractBorrowCR(Context* c,
|
||||||
unsigned size UNUSED,
|
unsigned size UNUSED,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void subtractCR(Context* c,
|
void subtractCR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void subtractBorrowRR(Context* c,
|
void subtractBorrowRR(Context* c,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void subtractRR(Context* c,
|
void subtractRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void andRR(Context* c,
|
void andRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void andCR(Context* c,
|
void andCR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void orRR(Context* c,
|
void orRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void orCR(Context* c,
|
void orCR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void xorRR(Context* c,
|
void xorRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void xorCR(Context* c,
|
void xorCR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void multiplyRR(Context* c,
|
void multiplyRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void compareRR(Context* c,
|
void compareRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void compareCR(Context* c,
|
void compareCR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void compareRM(Context* c,
|
void compareRM(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Memory* b);
|
lir::Memory* b);
|
||||||
|
|
||||||
@ -231,9 +231,9 @@ void compareCM(Context* c,
|
|||||||
|
|
||||||
void compareFloatRR(Context* c,
|
void compareFloatRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void branchLong(Context* c,
|
void branchLong(Context* c,
|
||||||
lir::TernaryOperation op,
|
lir::TernaryOperation op,
|
||||||
@ -247,21 +247,21 @@ void branchLong(Context* c,
|
|||||||
void branchRR(Context* c,
|
void branchRR(Context* c,
|
||||||
lir::TernaryOperation op,
|
lir::TernaryOperation op,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Constant* target);
|
lir::Constant* target);
|
||||||
|
|
||||||
void branchCR(Context* c,
|
void branchCR(Context* c,
|
||||||
lir::TernaryOperation op,
|
lir::TernaryOperation op,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
lir::Register* b,
|
lir::RegisterPair* b,
|
||||||
lir::Constant* target);
|
lir::Constant* target);
|
||||||
|
|
||||||
void branchRM(Context* c,
|
void branchRM(Context* c,
|
||||||
lir::TernaryOperation op,
|
lir::TernaryOperation op,
|
||||||
unsigned size,
|
unsigned size,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
lir::Memory* b,
|
lir::Memory* b,
|
||||||
lir::Constant* target);
|
lir::Constant* target);
|
||||||
|
|
||||||
@ -276,181 +276,181 @@ void multiplyCR(Context* c,
|
|||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void divideRR(Context* c,
|
void divideRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b UNUSED);
|
lir::RegisterPair* b UNUSED);
|
||||||
|
|
||||||
void remainderRR(Context* c,
|
void remainderRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void doShift(Context* c,
|
void doShift(Context* c,
|
||||||
UNUSED void (*shift)(Context*,
|
UNUSED void (*shift)(Context*,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register*,
|
lir::RegisterPair*,
|
||||||
unsigned,
|
unsigned,
|
||||||
lir::Register*),
|
lir::RegisterPair*),
|
||||||
int type,
|
int type,
|
||||||
UNUSED unsigned aSize,
|
UNUSED unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void shiftLeftRR(Context* c,
|
void shiftLeftRR(Context* c,
|
||||||
UNUSED unsigned aSize,
|
UNUSED unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void shiftLeftCR(Context* c,
|
void shiftLeftCR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void shiftRightRR(Context* c,
|
void shiftRightRR(Context* c,
|
||||||
UNUSED unsigned aSize,
|
UNUSED unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void shiftRightCR(Context* c,
|
void shiftRightCR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void unsignedShiftRightRR(Context* c,
|
void unsignedShiftRightRR(Context* c,
|
||||||
UNUSED unsigned aSize,
|
UNUSED unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void unsignedShiftRightCR(Context* c,
|
void unsignedShiftRightCR(Context* c,
|
||||||
unsigned aSize UNUSED,
|
unsigned aSize UNUSED,
|
||||||
lir::Constant* a,
|
lir::Constant* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void floatSqrtRR(Context* c,
|
void floatSqrtRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void floatSqrtMR(Context* c,
|
void floatSqrtMR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void floatAddRR(Context* c,
|
void floatAddRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void floatAddMR(Context* c,
|
void floatAddMR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void floatSubtractRR(Context* c,
|
void floatSubtractRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void floatSubtractMR(Context* c,
|
void floatSubtractMR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void floatMultiplyRR(Context* c,
|
void floatMultiplyRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void floatMultiplyMR(Context* c,
|
void floatMultiplyMR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void floatDivideRR(Context* c,
|
void floatDivideRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void floatDivideMR(Context* c,
|
void floatDivideMR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void float2FloatRR(Context* c,
|
void float2FloatRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void float2FloatMR(Context* c,
|
void float2FloatMR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void float2IntRR(Context* c,
|
void float2IntRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void float2IntMR(Context* c,
|
void float2IntMR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void int2FloatRR(Context* c,
|
void int2FloatRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void int2FloatMR(Context* c,
|
void int2FloatMR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Memory* a,
|
lir::Memory* a,
|
||||||
unsigned bSize,
|
unsigned bSize,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void floatNegateRR(Context* c,
|
void floatNegateRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void floatAbsoluteRR(Context* c,
|
void floatAbsoluteRR(Context* c,
|
||||||
unsigned aSize UNUSED,
|
unsigned aSize UNUSED,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b);
|
lir::RegisterPair* b);
|
||||||
|
|
||||||
void absoluteRR(Context* c,
|
void absoluteRR(Context* c,
|
||||||
unsigned aSize,
|
unsigned aSize,
|
||||||
lir::Register* a,
|
lir::RegisterPair* a,
|
||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::Register* b UNUSED);
|
lir::RegisterPair* b UNUSED);
|
||||||
|
|
||||||
} // namespace x86
|
} // namespace x86
|
||||||
} // namespace codegen
|
} // namespace codegen
|
||||||
|
@ -9783,7 +9783,7 @@ void compileCall(MyThread* t, Context* c, ThunkIndex index, bool call = true)
|
|||||||
|
|
||||||
if (processor(t)->bootImage) {
|
if (processor(t)->bootImage) {
|
||||||
lir::Memory table(t->arch->thread(), TARGET_THREAD_THUNKTABLE);
|
lir::Memory table(t->arch->thread(), TARGET_THREAD_THUNKTABLE);
|
||||||
lir::Register scratch(t->arch->scratch());
|
lir::RegisterPair scratch(t->arch->scratch());
|
||||||
a->apply(lir::Move,
|
a->apply(lir::Move,
|
||||||
OperandInfo(TargetBytesPerWord, lir::Operand::Type::Memory, &table),
|
OperandInfo(TargetBytesPerWord, lir::Operand::Type::Memory, &table),
|
||||||
OperandInfo(TargetBytesPerWord, lir::Operand::Type::RegisterPair, &scratch));
|
OperandInfo(TargetBytesPerWord, lir::Operand::Type::RegisterPair, &scratch));
|
||||||
@ -9814,14 +9814,14 @@ void compileThunks(MyThread* t, FixedAllocator* allocator)
|
|||||||
|
|
||||||
p->thunks.default_.frameSavedOffset = a->length();
|
p->thunks.default_.frameSavedOffset = a->length();
|
||||||
|
|
||||||
lir::Register thread(t->arch->thread());
|
lir::RegisterPair thread(t->arch->thread());
|
||||||
a->pushFrame(1, TargetBytesPerWord, lir::Operand::Type::RegisterPair, &thread);
|
a->pushFrame(1, TargetBytesPerWord, lir::Operand::Type::RegisterPair, &thread);
|
||||||
|
|
||||||
compileCall(t, &context, compileMethodIndex);
|
compileCall(t, &context, compileMethodIndex);
|
||||||
|
|
||||||
a->popFrame(t->arch->alignFrameSize(1));
|
a->popFrame(t->arch->alignFrameSize(1));
|
||||||
|
|
||||||
lir::Register result(t->arch->returnLow());
|
lir::RegisterPair result(t->arch->returnLow());
|
||||||
a->apply(lir::Jump,
|
a->apply(lir::Jump,
|
||||||
OperandInfo(TargetBytesPerWord, lir::Operand::Type::RegisterPair, &result));
|
OperandInfo(TargetBytesPerWord, lir::Operand::Type::RegisterPair, &result));
|
||||||
|
|
||||||
@ -9835,7 +9835,7 @@ void compileThunks(MyThread* t, FixedAllocator* allocator)
|
|||||||
Context context(t);
|
Context context(t);
|
||||||
avian::codegen::Assembler* a = context.assembler;
|
avian::codegen::Assembler* a = context.assembler;
|
||||||
|
|
||||||
lir::Register class_(t->arch->virtualCallTarget());
|
lir::RegisterPair class_(t->arch->virtualCallTarget());
|
||||||
lir::Memory virtualCallTargetSrc(
|
lir::Memory virtualCallTargetSrc(
|
||||||
t->arch->stack(),
|
t->arch->stack(),
|
||||||
(t->arch->frameFooterSize() + t->arch->frameReturnAddressSize())
|
(t->arch->frameFooterSize() + t->arch->frameReturnAddressSize())
|
||||||
@ -9855,7 +9855,7 @@ void compileThunks(MyThread* t, FixedAllocator* allocator)
|
|||||||
OperandInfo(
|
OperandInfo(
|
||||||
TargetBytesPerWord, lir::Operand::Type::Memory, &virtualCallTargetDst));
|
TargetBytesPerWord, lir::Operand::Type::Memory, &virtualCallTargetDst));
|
||||||
|
|
||||||
lir::Register index(t->arch->virtualCallIndex());
|
lir::RegisterPair index(t->arch->virtualCallIndex());
|
||||||
lir::Memory virtualCallIndex(t->arch->thread(),
|
lir::Memory virtualCallIndex(t->arch->thread(),
|
||||||
TARGET_THREAD_VIRTUALCALLINDEX);
|
TARGET_THREAD_VIRTUALCALLINDEX);
|
||||||
|
|
||||||
@ -9868,14 +9868,14 @@ void compileThunks(MyThread* t, FixedAllocator* allocator)
|
|||||||
|
|
||||||
p->thunks.defaultVirtual.frameSavedOffset = a->length();
|
p->thunks.defaultVirtual.frameSavedOffset = a->length();
|
||||||
|
|
||||||
lir::Register thread(t->arch->thread());
|
lir::RegisterPair thread(t->arch->thread());
|
||||||
a->pushFrame(1, TargetBytesPerWord, lir::Operand::Type::RegisterPair, &thread);
|
a->pushFrame(1, TargetBytesPerWord, lir::Operand::Type::RegisterPair, &thread);
|
||||||
|
|
||||||
compileCall(t, &context, compileVirtualMethodIndex);
|
compileCall(t, &context, compileVirtualMethodIndex);
|
||||||
|
|
||||||
a->popFrame(t->arch->alignFrameSize(1));
|
a->popFrame(t->arch->alignFrameSize(1));
|
||||||
|
|
||||||
lir::Register result(t->arch->returnLow());
|
lir::RegisterPair result(t->arch->returnLow());
|
||||||
a->apply(lir::Jump,
|
a->apply(lir::Jump,
|
||||||
OperandInfo(TargetBytesPerWord, lir::Operand::Type::RegisterPair, &result));
|
OperandInfo(TargetBytesPerWord, lir::Operand::Type::RegisterPair, &result));
|
||||||
|
|
||||||
@ -9893,7 +9893,7 @@ void compileThunks(MyThread* t, FixedAllocator* allocator)
|
|||||||
|
|
||||||
p->thunks.native.frameSavedOffset = a->length();
|
p->thunks.native.frameSavedOffset = a->length();
|
||||||
|
|
||||||
lir::Register thread(t->arch->thread());
|
lir::RegisterPair thread(t->arch->thread());
|
||||||
a->pushFrame(1, TargetBytesPerWord, lir::Operand::Type::RegisterPair, &thread);
|
a->pushFrame(1, TargetBytesPerWord, lir::Operand::Type::RegisterPair, &thread);
|
||||||
|
|
||||||
compileCall(t, &context, invokeNativeIndex);
|
compileCall(t, &context, invokeNativeIndex);
|
||||||
@ -9915,7 +9915,7 @@ void compileThunks(MyThread* t, FixedAllocator* allocator)
|
|||||||
|
|
||||||
p->thunks.aioob.frameSavedOffset = a->length();
|
p->thunks.aioob.frameSavedOffset = a->length();
|
||||||
|
|
||||||
lir::Register thread(t->arch->thread());
|
lir::RegisterPair thread(t->arch->thread());
|
||||||
a->pushFrame(1, TargetBytesPerWord, lir::Operand::Type::RegisterPair, &thread);
|
a->pushFrame(1, TargetBytesPerWord, lir::Operand::Type::RegisterPair, &thread);
|
||||||
|
|
||||||
compileCall(t, &context, throwArrayIndexOutOfBoundsIndex);
|
compileCall(t, &context, throwArrayIndexOutOfBoundsIndex);
|
||||||
@ -9934,7 +9934,7 @@ void compileThunks(MyThread* t, FixedAllocator* allocator)
|
|||||||
|
|
||||||
p->thunks.stackOverflow.frameSavedOffset = a->length();
|
p->thunks.stackOverflow.frameSavedOffset = a->length();
|
||||||
|
|
||||||
lir::Register thread(t->arch->thread());
|
lir::RegisterPair thread(t->arch->thread());
|
||||||
a->pushFrame(1, TargetBytesPerWord, lir::Operand::Type::RegisterPair, &thread);
|
a->pushFrame(1, TargetBytesPerWord, lir::Operand::Type::RegisterPair, &thread);
|
||||||
|
|
||||||
compileCall(t, &context, throwStackOverflowIndex);
|
compileCall(t, &context, throwStackOverflowIndex);
|
||||||
@ -10058,7 +10058,7 @@ uintptr_t compileVirtualThunk(MyThread* t, unsigned index, unsigned* size)
|
|||||||
|
|
||||||
avian::codegen::ResolvedPromise indexPromise(index);
|
avian::codegen::ResolvedPromise indexPromise(index);
|
||||||
lir::Constant indexConstant(&indexPromise);
|
lir::Constant indexConstant(&indexPromise);
|
||||||
lir::Register indexRegister(t->arch->virtualCallIndex());
|
lir::RegisterPair indexRegister(t->arch->virtualCallIndex());
|
||||||
a->apply(
|
a->apply(
|
||||||
lir::Move,
|
lir::Move,
|
||||||
OperandInfo(TargetBytesPerWord, lir::Operand::Type::Constant, &indexConstant),
|
OperandInfo(TargetBytesPerWord, lir::Operand::Type::Constant, &indexConstant),
|
||||||
|
Loading…
Reference in New Issue
Block a user