implement andC and moveAR; fix MyArchitecture::nextFrame

This commit is contained in:
Joel Dice 2009-02-25 18:16:38 -07:00
parent 09c96a3063
commit 08af5deb36

View File

@ -725,6 +725,31 @@ void subC(Context* con, unsigned size, Const* a, Reg* b, Reg* t) {
} }
} }
void andC(Context* c, unsigned size, Assembler::Constant* a,
Assembler::Register* b, Assembler::Register* dst)
{
int64_t v = a->value->value();
if(size == 8) {
ResolvedPromise high((v >> 32) & 0xFFFFFFFF);
Assembler::Constant ah(&high);
ResolvedPromise low(v & 0xFFFFFFFF);
Assembler::Constant al(&low);
Assembler::Register bh(b->high);
Assembler::Register dh(dst->high);
andC(c, 4, &al, b, dst);
andC(c, 4, &ah, &bh, &dh);
} else {
issue(c, andi(dst->low, b->low, v));
if (not isInt16(v)) {
issue(c, andis(dst->low, b->low, v >> 16));
}
}
}
void void
moveAndUpdateRM(Context* c, unsigned srcSize, Assembler::Register* src, moveAndUpdateRM(Context* c, unsigned srcSize, Assembler::Register* src,
unsigned dstSize UNUSED, Assembler::Memory* dst) unsigned dstSize UNUSED, Assembler::Memory* dst)
@ -855,6 +880,19 @@ moveCR(Context* c, unsigned srcSize, Assembler::Constant* src,
// issue(con, ori(R(t), R(t), lo16(i))); // issue(con, ori(R(t), R(t), lo16(i)));
// } // }
void
moveAR(Context* c, unsigned srcSize, Assembler::Address* src,
unsigned dstSize, Assembler::Register* dst)
{
assert(c, srcSize == 4 and dstSize == 4);
Assembler::Constant constant(src->address);
Assembler::Memory memory(dst->low, 0, -1, 0);
moveCR(c, srcSize, &constant, dstSize, dst);
moveMR(c, dstSize, &memory, dstSize, dst);
}
void void
compareRR(Context* c, unsigned aSize, Assembler::Register* a, compareRR(Context* c, unsigned aSize, Assembler::Register* a,
unsigned bSize, Assembler::Register* b) unsigned bSize, Assembler::Register* b)
@ -1057,7 +1095,7 @@ void
populateTables(ArchitectureContext* c) populateTables(ArchitectureContext* c)
{ {
const OperandType C = ConstantOperand; const OperandType C = ConstantOperand;
// const OperandType A = AddressOperand; const OperandType A = AddressOperand;
const OperandType R = RegisterOperand; const OperandType R = RegisterOperand;
const OperandType M = MemoryOperand; const OperandType M = MemoryOperand;
@ -1078,14 +1116,17 @@ populateTables(ArchitectureContext* c)
uo[index(JumpIfEqual, C)] = CAST1(jumpIfEqualC); uo[index(JumpIfEqual, C)] = CAST1(jumpIfEqualC);
uo[index(Call, C)] = CAST1(callC); uo[index(Call, C)] = CAST1(callC);
uo[index(Call, R)] = CAST1(callR);
uo[index(AlignedCall, C)] = CAST1(callC); uo[index(AlignedCall, C)] = CAST1(callC);
uo[index(AlignedCall, R)] = CAST1(callR);
bo[index(Move, R, R)] = CAST2(moveRR); bo[index(Move, R, R)] = CAST2(moveRR);
bo[index(Move, C, R)] = CAST2(moveCR); bo[index(Move, C, R)] = CAST2(moveCR);
bo[index(Move, C, M)] = CAST2(moveCM); bo[index(Move, C, M)] = CAST2(moveCM);
bo[index(Move, M, R)] = CAST2(moveMR); bo[index(Move, M, R)] = CAST2(moveMR);
bo[index(Move, R, M)] = CAST2(moveRM); bo[index(Move, R, M)] = CAST2(moveRM);
bo[index(Move, A, R)] = CAST2(moveAR);
bo[index(Compare, R, R)] = CAST2(compareRR); bo[index(Compare, R, R)] = CAST2(compareRR);
@ -1095,6 +1136,8 @@ populateTables(ArchitectureContext* c)
to[index(Subtract, R)] = CAST3(subR); to[index(Subtract, R)] = CAST3(subR);
to[index(Subtract, C)] = CAST3(subC); to[index(Subtract, C)] = CAST3(subC);
to[index(And, C)] = CAST3(andC);
to[index(LongCompare, R)] = CAST3(longCompareR); to[index(LongCompare, R)] = CAST3(longCompareR);
} }
@ -1186,7 +1229,9 @@ class MyArchitecture: public Assembler::Architecture {
} }
virtual void nextFrame(void** stack, void**) { virtual void nextFrame(void** stack, void**) {
*stack = static_cast<void**>(*stack); assert(&c, *static_cast<void**>(*stack) != *stack);
*stack = *static_cast<void**>(*stack);
} }
virtual void plan virtual void plan