mirror of
https://github.com/corda/corda.git
synced 2025-01-07 13:38:47 +00:00
format recent changes using clang-format
This commit is contained in:
parent
e3f50e6d67
commit
cdcf173601
@ -125,8 +125,7 @@ void nextFrame(ArchitectureContext* con,
|
|||||||
|
|
||||||
// check for post-non-tail-call stack adjustment of the form "sub
|
// check for post-non-tail-call stack adjustment of the form "sub
|
||||||
// sp, sp, #offset":
|
// sp, sp, #offset":
|
||||||
if (TargetBytesPerWord == 8 and (*instruction & 0xff0003ff) == 0xd10003ff)
|
if (TargetBytesPerWord == 8 and (*instruction & 0xff0003ff) == 0xd10003ff) {
|
||||||
{
|
|
||||||
unsigned value = (*instruction >> 10) & 0xfff;
|
unsigned value = (*instruction >> 10) & 0xfff;
|
||||||
unsigned shift = (*instruction >> 22) & 1;
|
unsigned shift = (*instruction >> 22) & 1;
|
||||||
switch (shift) {
|
switch (shift) {
|
||||||
|
@ -16,7 +16,7 @@ namespace {
|
|||||||
|
|
||||||
const unsigned InstructionSize = 4;
|
const unsigned InstructionSize = 4;
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
namespace avian {
|
namespace avian {
|
||||||
namespace codegen {
|
namespace codegen {
|
||||||
@ -44,8 +44,7 @@ int64_t OffsetPromise::value()
|
|||||||
assertT(con, resolved());
|
assertT(con, resolved());
|
||||||
|
|
||||||
unsigned o = offset - block->offset;
|
unsigned o = offset - block->offset;
|
||||||
return block->start
|
return block->start + padding(block, forTrace ? o - InstructionSize : o) + o;
|
||||||
+ padding(block, forTrace ? o - InstructionSize : o) + o;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Promise* offsetPromise(Context* con, bool forTrace)
|
Promise* offsetPromise(Context* con, bool forTrace)
|
||||||
|
@ -417,9 +417,9 @@ void multiplyR(Context* con,
|
|||||||
if (size == 8) {
|
if (size == 8) {
|
||||||
bool useTemporaries = b->low == t->low;
|
bool useTemporaries = b->low == t->low;
|
||||||
Register tmpLow = useTemporaries ? con->client->acquireTemporary(GPR_MASK)
|
Register tmpLow = useTemporaries ? con->client->acquireTemporary(GPR_MASK)
|
||||||
: t->low;
|
: t->low;
|
||||||
Register tmpHigh = useTemporaries ? con->client->acquireTemporary(GPR_MASK)
|
Register tmpHigh = useTemporaries ? con->client->acquireTemporary(GPR_MASK)
|
||||||
: t->high;
|
: t->high;
|
||||||
|
|
||||||
emit(con, umull(tmpLow, tmpHigh, a->low, b->low));
|
emit(con, umull(tmpLow, tmpHigh, a->low, b->low));
|
||||||
emit(con, mla(tmpHigh, a->low, b->high, tmpHigh));
|
emit(con, mla(tmpHigh, a->low, b->high, tmpHigh));
|
||||||
@ -572,11 +572,11 @@ void floatDivideR(Context* con,
|
|||||||
}
|
}
|
||||||
|
|
||||||
Register normalize(Context* con,
|
Register normalize(Context* con,
|
||||||
int offset,
|
int offset,
|
||||||
Register index,
|
Register index,
|
||||||
unsigned scale,
|
unsigned scale,
|
||||||
bool* preserveIndex,
|
bool* preserveIndex,
|
||||||
bool* release)
|
bool* release)
|
||||||
{
|
{
|
||||||
if (offset != 0 or scale != 1) {
|
if (offset != 0 or scale != 1) {
|
||||||
lir::RegisterPair normalizedIndex(
|
lir::RegisterPair normalizedIndex(
|
||||||
@ -854,26 +854,8 @@ void load(Context* con,
|
|||||||
case 8: {
|
case 8: {
|
||||||
if (dstSize == 8) {
|
if (dstSize == 8) {
|
||||||
lir::RegisterPair dstHigh(dst->high);
|
lir::RegisterPair dstHigh(dst->high);
|
||||||
load(con,
|
load(con, 4, base, offset, NoRegister, 1, 4, &dstHigh, false, false);
|
||||||
4,
|
load(con, 4, base, offset + 4, NoRegister, 1, 4, dst, false, false);
|
||||||
base,
|
|
||||||
offset,
|
|
||||||
NoRegister,
|
|
||||||
1,
|
|
||||||
4,
|
|
||||||
&dstHigh,
|
|
||||||
false,
|
|
||||||
false);
|
|
||||||
load(con,
|
|
||||||
4,
|
|
||||||
base,
|
|
||||||
offset + 4,
|
|
||||||
NoRegister,
|
|
||||||
1,
|
|
||||||
4,
|
|
||||||
dst,
|
|
||||||
false,
|
|
||||||
false);
|
|
||||||
} else {
|
} else {
|
||||||
emit(con, ldri(dst->low, base, offset));
|
emit(con, ldri(dst->low, base, offset));
|
||||||
}
|
}
|
||||||
@ -1407,7 +1389,8 @@ void longJumpC(Context* con, unsigned size UNUSED, lir::Constant* target)
|
|||||||
{
|
{
|
||||||
assertT(con, size == vm::TargetBytesPerWord);
|
assertT(con, size == vm::TargetBytesPerWord);
|
||||||
|
|
||||||
lir::RegisterPair tmp(Register(4)); // a non-arg reg that we don't mind clobbering
|
lir::RegisterPair tmp(
|
||||||
|
Register(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);
|
||||||
}
|
}
|
||||||
@ -1462,4 +1445,4 @@ void storeLoadBarrier(Context* con)
|
|||||||
} // namespace codegen
|
} // namespace codegen
|
||||||
} // namespace avian
|
} // namespace avian
|
||||||
|
|
||||||
#endif // AVIAN_TARGET_ARCH == AVIAN_ARCH_ARM
|
#endif // AVIAN_TARGET_ARCH == AVIAN_ARCH_ARM
|
||||||
|
@ -38,17 +38,20 @@ void append(Context* c, uint32_t instruction)
|
|||||||
|
|
||||||
uint32_t lslv(Register Rd, Register Rn, Register Rm, unsigned size)
|
uint32_t lslv(Register Rd, Register Rn, Register Rm, unsigned size)
|
||||||
{
|
{
|
||||||
return (size == 8 ? 0x9ac02000 : 0x1ac02000) | (Rm.index() << 16) | (Rn.index() << 5) | Rd.index();
|
return (size == 8 ? 0x9ac02000 : 0x1ac02000) | (Rm.index() << 16)
|
||||||
|
| (Rn.index() << 5) | Rd.index();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t ubfm(Register Rd, Register Rn, int r, int s, unsigned size)
|
uint32_t ubfm(Register Rd, Register Rn, int r, int s, unsigned size)
|
||||||
{
|
{
|
||||||
return (size == 8 ? 0xd3400000 : 0x53000000) | (r << 16) | (s << 10) | (Rn.index() << 5) | Rd.index();
|
return (size == 8 ? 0xd3400000 : 0x53000000) | (r << 16) | (s << 10)
|
||||||
|
| (Rn.index() << 5) | Rd.index();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t sbfm(Register Rd, Register Rn, int r, int s, unsigned size)
|
uint32_t sbfm(Register Rd, Register Rn, int r, int s, unsigned size)
|
||||||
{
|
{
|
||||||
return (size == 8 ? 0x93400000 : 0x13000000) | (r << 16) | (s << 10) | (Rn.index() << 5) | Rd.index();
|
return (size == 8 ? 0x93400000 : 0x13000000) | (r << 16) | (s << 10)
|
||||||
|
| (Rn.index() << 5) | Rd.index();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t lsli(Register Rd, Register Rn, int shift, unsigned size)
|
uint32_t lsli(Register Rd, Register Rn, int shift, unsigned size)
|
||||||
@ -62,12 +65,14 @@ uint32_t lsli(Register Rd, Register Rn, int shift, unsigned size)
|
|||||||
|
|
||||||
uint32_t asrv(Register Rd, Register Rn, Register Rm, unsigned size)
|
uint32_t asrv(Register Rd, Register Rn, Register Rm, unsigned size)
|
||||||
{
|
{
|
||||||
return (size == 8 ? 0x9ac02800 : 0x1ac02800) | (Rm.index() << 16) | (Rn.index() << 5) | Rd.index();
|
return (size == 8 ? 0x9ac02800 : 0x1ac02800) | (Rm.index() << 16)
|
||||||
|
| (Rn.index() << 5) | Rd.index();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t lsrv(Register Rd, Register Rn, Register Rm, unsigned size)
|
uint32_t lsrv(Register Rd, Register Rn, Register Rm, unsigned size)
|
||||||
{
|
{
|
||||||
return (size == 8 ? 0x9ac02400 : 0x1ac02400) | (Rm.index() << 16) | (Rn.index() << 5) | Rd.index();
|
return (size == 8 ? 0x9ac02400 : 0x1ac02400) | (Rm.index() << 16)
|
||||||
|
| (Rn.index() << 5) | Rd.index();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t lsri(Register Rd, Register Rn, int shift, unsigned size)
|
uint32_t lsri(Register Rd, Register Rn, int shift, unsigned size)
|
||||||
@ -122,37 +127,38 @@ uint32_t fmovFdRn(Register Fd, Register Rn, unsigned size)
|
|||||||
|
|
||||||
uint32_t orr(Register Rd, Register Rn, Register Rm, unsigned size)
|
uint32_t orr(Register Rd, Register Rn, Register Rm, unsigned size)
|
||||||
{
|
{
|
||||||
return (size == 8 ? 0xaa000000 : 0x2a000000) | (Rm.index() << 16) | (Rn.index() << 5) | Rd.index();
|
return (size == 8 ? 0xaa000000 : 0x2a000000) | (Rm.index() << 16)
|
||||||
|
| (Rn.index() << 5) | Rd.index();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t addi(Register Rd, Register Rn, int value, int shift, unsigned size)
|
uint32_t addi(Register Rd, Register Rn, int value, int shift, unsigned size)
|
||||||
{
|
{
|
||||||
return (size == 8 ? 0x91000000 : 0x11000000) | (shift ? 0x400000 : 0)
|
return (size == 8 ? 0x91000000 : 0x11000000) | (shift ? 0x400000 : 0)
|
||||||
| (value << 10) | (Rn.index() << 5) | Rd.index();
|
| (value << 10) | (Rn.index() << 5) | Rd.index();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t mov(Register Rd, Register Rn, unsigned size)
|
uint32_t mov(Register Rd, Register Rn, unsigned size)
|
||||||
{
|
{
|
||||||
return Rn.index() == 31 ? addi(Rd, Rn, 0, 0, size)
|
return Rn.index() == 31 ? addi(Rd, Rn, 0, 0, size)
|
||||||
: orr(Rd, Register(31), Rn, size);
|
: orr(Rd, Register(31), Rn, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t movz(Register Rd, int value, unsigned shift, unsigned size)
|
uint32_t movz(Register Rd, int value, unsigned shift, unsigned size)
|
||||||
{
|
{
|
||||||
return (size == 8 ? 0xd2800000 : 0x52800000) | ((shift >> 4) << 21)
|
return (size == 8 ? 0xd2800000 : 0x52800000) | ((shift >> 4) << 21)
|
||||||
| (value << 5) | Rd.index();
|
| (value << 5) | Rd.index();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t movn(Register Rd, int value, unsigned shift, unsigned size)
|
uint32_t movn(Register Rd, int value, unsigned shift, unsigned size)
|
||||||
{
|
{
|
||||||
return (size == 8 ? 0x92800000 : 0x12800000) | ((shift >> 4) << 21)
|
return (size == 8 ? 0x92800000 : 0x12800000) | ((shift >> 4) << 21)
|
||||||
| (value << 5) | Rd.index();
|
| (value << 5) | Rd.index();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t movk(Register Rd, int value, unsigned shift, unsigned size)
|
uint32_t movk(Register Rd, int value, unsigned shift, unsigned size)
|
||||||
{
|
{
|
||||||
return (size == 8 ? 0xf2800000 : 0x72800000) | ((shift >> 4) << 21)
|
return (size == 8 ? 0xf2800000 : 0x72800000) | ((shift >> 4) << 21)
|
||||||
| (value << 5) | Rd.index();
|
| (value << 5) | Rd.index();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t ldrPCRel(Register Rd, int offset, unsigned size)
|
uint32_t ldrPCRel(Register Rd, int offset, unsigned size)
|
||||||
@ -163,12 +169,14 @@ uint32_t ldrPCRel(Register Rd, int offset, unsigned size)
|
|||||||
|
|
||||||
uint32_t add(Register Rd, Register Rn, Register Rm, unsigned size)
|
uint32_t add(Register Rd, Register Rn, Register Rm, unsigned size)
|
||||||
{
|
{
|
||||||
return (size == 8 ? 0x8b000000 : 0x0b000000) | (Rm.index() << 16) | (Rn.index() << 5) | Rd.index();
|
return (size == 8 ? 0x8b000000 : 0x0b000000) | (Rm.index() << 16)
|
||||||
|
| (Rn.index() << 5) | Rd.index();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t sub(Register Rd, Register Rn, Register Rm, unsigned size)
|
uint32_t sub(Register Rd, Register Rn, Register Rm, unsigned size)
|
||||||
{
|
{
|
||||||
return (size == 8 ? 0xcb000000 : 0x4b000000) | (Rm.index() << 16) | (Rn.index() << 5) | Rd.index();
|
return (size == 8 ? 0xcb000000 : 0x4b000000) | (Rm.index() << 16)
|
||||||
|
| (Rn.index() << 5) | Rd.index();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t and_(Register Rd, Register Rn, Register Rm, unsigned size)
|
uint32_t and_(Register Rd, Register Rn, Register Rm, unsigned size)
|
||||||
@ -185,8 +193,8 @@ uint32_t eor(Register Rd, Register Rn, Register Rm, unsigned size)
|
|||||||
|
|
||||||
uint32_t madd(Register Rd, Register Rn, Register Rm, Register Ra, unsigned size)
|
uint32_t madd(Register Rd, Register Rn, Register Rm, Register Ra, unsigned size)
|
||||||
{
|
{
|
||||||
return (size == 8 ? 0x9b000000 : 0x1b000000)
|
return (size == 8 ? 0x9b000000 : 0x1b000000) | (Rm.index() << 16)
|
||||||
| (Rm.index() << 16) | (Ra.index() << 10) | (Rn.index() << 5) | Rd.index();
|
| (Ra.index() << 10) | (Rn.index() << 5) | Rd.index();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t mul(Register Rd, Register Rn, Register Rm, unsigned size)
|
uint32_t mul(Register Rd, Register Rn, Register Rm, unsigned size)
|
||||||
@ -197,7 +205,7 @@ uint32_t mul(Register Rd, Register Rn, Register Rm, unsigned size)
|
|||||||
uint32_t subi(Register Rd, Register Rn, int value, int shift, unsigned size)
|
uint32_t subi(Register Rd, Register Rn, int value, int shift, unsigned size)
|
||||||
{
|
{
|
||||||
return (size == 8 ? 0xd1000000 : 0x51000000) | (shift ? 0x400000 : 0)
|
return (size == 8 ? 0xd1000000 : 0x51000000) | (shift ? 0x400000 : 0)
|
||||||
| (value << 10) | (Rn.index() << 5) | Rd.index();
|
| (value << 10) | (Rn.index() << 5) | Rd.index();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t fabs_(Register Fd, Register Fn, unsigned size)
|
uint32_t fabs_(Register Fd, Register Fn, unsigned size)
|
||||||
@ -288,7 +296,8 @@ uint32_t strh(Register Rs, Register Rn, Register Rm)
|
|||||||
uint32_t striFs(Register Fs, Register Rn, int offset, unsigned size)
|
uint32_t striFs(Register Fs, Register Rn, int offset, unsigned size)
|
||||||
{
|
{
|
||||||
return (size == 8 ? 0xfd000000 : 0xbd000000)
|
return (size == 8 ? 0xfd000000 : 0xbd000000)
|
||||||
| ((offset >> (size == 8 ? 3 : 2)) << 10) | (Rn.index() << 5) | Fs.index();
|
| ((offset >> (size == 8 ? 3 : 2)) << 10) | (Rn.index() << 5)
|
||||||
|
| Fs.index();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t str(Register Rs, Register Rn, Register Rm, unsigned size)
|
uint32_t str(Register Rs, Register Rn, Register Rm, unsigned size)
|
||||||
@ -310,7 +319,8 @@ uint32_t strhi(Register Rs, Register Rn, int offset)
|
|||||||
uint32_t stri(Register Rs, Register Rn, int offset, unsigned size)
|
uint32_t stri(Register Rs, Register Rn, int offset, unsigned size)
|
||||||
{
|
{
|
||||||
return (size == 8 ? 0xf9000000 : 0xb9000000)
|
return (size == 8 ? 0xf9000000 : 0xb9000000)
|
||||||
| ((offset >> (size == 8 ? 3 : 2)) << 10) | (Rn.index() << 5) | Rs.index();
|
| ((offset >> (size == 8 ? 3 : 2)) << 10) | (Rn.index() << 5)
|
||||||
|
| Rs.index();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t ldrFd(Register Fd, Register Rn, Register Rm, unsigned size)
|
uint32_t ldrFd(Register Fd, Register Rn, Register Rm, unsigned size)
|
||||||
@ -353,7 +363,8 @@ uint32_t ldr(Register Rd, Register Rn, Register Rm, unsigned size)
|
|||||||
uint32_t ldriFd(Register Fd, Register Rn, int offset, unsigned size)
|
uint32_t ldriFd(Register Fd, Register Rn, int offset, unsigned size)
|
||||||
{
|
{
|
||||||
return (size == 8 ? 0xfd400000 : 0xbd400000)
|
return (size == 8 ? 0xfd400000 : 0xbd400000)
|
||||||
| ((offset >> (size == 8 ? 3 : 2)) << 10) | (Rn.index() << 5) | Fd.index();
|
| ((offset >> (size == 8 ? 3 : 2)) << 10) | (Rn.index() << 5)
|
||||||
|
| Fd.index();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t ldrbi(Register Rd, Register Rn, int offset)
|
uint32_t ldrbi(Register Rd, Register Rn, int offset)
|
||||||
@ -384,7 +395,8 @@ uint32_t ldrswi(Register Rd, Register Rn, int offset)
|
|||||||
uint32_t ldri(Register Rd, Register Rn, int offset, unsigned size)
|
uint32_t ldri(Register Rd, Register Rn, int offset, unsigned size)
|
||||||
{
|
{
|
||||||
return (size == 8 ? 0xf9400000 : 0xb9400000)
|
return (size == 8 ? 0xf9400000 : 0xb9400000)
|
||||||
| ((offset >> (size == 8 ? 3 : 2)) << 10) | (Rn.index() << 5) | Rd.index();
|
| ((offset >> (size == 8 ? 3 : 2)) << 10) | (Rn.index() << 5)
|
||||||
|
| Rd.index();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t fcmp(Register Fn, Register Fm, unsigned size)
|
uint32_t fcmp(Register Fn, Register Fm, unsigned size)
|
||||||
@ -1038,19 +1050,19 @@ void moveRM(Context* c,
|
|||||||
assertT(c, srcSize == dstSize);
|
assertT(c, srcSize == dstSize);
|
||||||
|
|
||||||
if (src->low.index() == 31) {
|
if (src->low.index() == 31) {
|
||||||
assertT(c, c->client == 0); // the compiler should never ask us to
|
assertT(c, c->client == 0); // the compiler should never ask us to
|
||||||
// store the SP; we'll only get here
|
// store the SP; we'll only get here
|
||||||
// when assembling a thunk
|
// when assembling a thunk
|
||||||
|
|
||||||
lir::RegisterPair tmp(Register(9)); // we're in a thunk, so we can
|
lir::RegisterPair tmp(Register(9)); // we're in a thunk, so we can
|
||||||
// clobber this
|
// clobber this
|
||||||
|
|
||||||
moveRR(c, srcSize, src, srcSize, &tmp);
|
moveRR(c, srcSize, src, srcSize, &tmp);
|
||||||
store(
|
store(
|
||||||
c, srcSize, &tmp, dst->base, dst->offset, dst->index, dst->scale, true);
|
c, srcSize, &tmp, dst->base, dst->offset, dst->index, dst->scale, true);
|
||||||
} else {
|
} else {
|
||||||
store(
|
store(
|
||||||
c, srcSize, src, dst->base, dst->offset, dst->index, dst->scale, true);
|
c, srcSize, src, dst->base, dst->offset, dst->index, dst->scale, true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1272,8 +1284,9 @@ void moveAR(Context* c,
|
|||||||
unsigned dstSize,
|
unsigned dstSize,
|
||||||
lir::RegisterPair* dst)
|
lir::RegisterPair* dst)
|
||||||
{
|
{
|
||||||
assertT(c, srcSize == vm::TargetBytesPerWord
|
assertT(
|
||||||
and dstSize == vm::TargetBytesPerWord);
|
c,
|
||||||
|
srcSize == vm::TargetBytesPerWord and dstSize == vm::TargetBytesPerWord);
|
||||||
|
|
||||||
lir::Constant constant(src->address);
|
lir::Constant constant(src->address);
|
||||||
moveCR(c, srcSize, &constant, dstSize, dst);
|
moveCR(c, srcSize, &constant, dstSize, dst);
|
||||||
@ -1288,7 +1301,7 @@ void compareRR(Context* c,
|
|||||||
unsigned bSize UNUSED,
|
unsigned bSize UNUSED,
|
||||||
lir::RegisterPair* b)
|
lir::RegisterPair* b)
|
||||||
{
|
{
|
||||||
assertT(c, not (isFpr(a) xor isFpr(b)));
|
assertT(c, not(isFpr(a) xor isFpr(b)));
|
||||||
assertT(c, aSize == bSize);
|
assertT(c, aSize == bSize);
|
||||||
|
|
||||||
if (isFpr(a)) {
|
if (isFpr(a)) {
|
||||||
@ -1593,4 +1606,4 @@ void storeLoadBarrier(Context* c)
|
|||||||
} // namespace codegen
|
} // namespace codegen
|
||||||
} // namespace avian
|
} // namespace avian
|
||||||
|
|
||||||
#endif // AVIAN_TARGET_ARCH == AVIAN_ARCH_ARM64
|
#endif // AVIAN_TARGET_ARCH == AVIAN_ARCH_ARM64
|
||||||
|
@ -27,7 +27,7 @@ const unsigned MASK_LO8 = 0xff;
|
|||||||
constexpr Register ThreadRegister(19);
|
constexpr Register ThreadRegister(19);
|
||||||
constexpr Register StackRegister(31);
|
constexpr Register StackRegister(31);
|
||||||
constexpr Register LinkRegister(30);
|
constexpr Register LinkRegister(30);
|
||||||
constexpr Register ProgramCounter(0xFE); // i.e. unaddressable
|
constexpr Register ProgramCounter(0xFE); // i.e. unaddressable
|
||||||
|
|
||||||
const int N_GPRS = 32;
|
const int N_GPRS = 32;
|
||||||
const int N_FPRS = 32;
|
const int N_FPRS = 32;
|
||||||
@ -38,7 +38,7 @@ const RegisterMask FPR_MASK = 0xffffffff00000000;
|
|||||||
constexpr Register ThreadRegister(8);
|
constexpr Register ThreadRegister(8);
|
||||||
constexpr Register StackRegister(13);
|
constexpr Register StackRegister(13);
|
||||||
constexpr Register LinkRegister(14);
|
constexpr Register LinkRegister(14);
|
||||||
constexpr Register FrameRegister(0xFE); // i.e. there is none
|
constexpr Register FrameRegister(0xFE); // i.e. there is none
|
||||||
constexpr Register ProgramCounter(15);
|
constexpr Register ProgramCounter(15);
|
||||||
|
|
||||||
const int N_GPRS = 16;
|
const int N_GPRS = 16;
|
||||||
|
Loading…
Reference in New Issue
Block a user