mirror of
https://github.com/corda/corda.git
synced 2025-01-07 13:38:47 +00:00
moduloInt + arm work
This commit is contained in:
parent
e00fc5d91a
commit
d3d228e69b
44
src/arm.cpp
44
src/arm.cpp
@ -287,18 +287,13 @@ bounded(int right, int left, int32_t v)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void*
|
void*
|
||||||
updateOffset(System* s, uint8_t* instruction, bool conditional, int64_t value)
|
updateOffset(System* s, uint8_t* instruction, bool conditional UNUSED, int64_t value)
|
||||||
{
|
{
|
||||||
int32_t v = reinterpret_cast<uint8_t*>(value) - instruction;
|
int32_t v = reinterpret_cast<uint8_t*>(value) - instruction;
|
||||||
|
|
||||||
int32_t mask;
|
int32_t mask;
|
||||||
if (conditional) {
|
expect(s, bounded(0, 8, v));
|
||||||
expect(s, bounded(2, 16, v));
|
mask = 0xFFFFFF;
|
||||||
mask = 0xFFFC;
|
|
||||||
} else {
|
|
||||||
expect(s, bounded(2, 6, v));
|
|
||||||
mask = 0x3FFFFFC;
|
|
||||||
}
|
|
||||||
|
|
||||||
int32_t* p = reinterpret_cast<int32_t*>(instruction);
|
int32_t* p = reinterpret_cast<int32_t*>(instruction);
|
||||||
*p = (v & mask) | ((~mask) & *p);
|
*p = (v & mask) | ((~mask) & *p);
|
||||||
@ -711,22 +706,6 @@ void multiplyR(Context* con, unsigned size, Assembler::Register a, Assembler::Re
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void remainderR(Context* con, unsigned size, Assembler::Register a, Assembler::Register b, Assembler::Register t) {
|
|
||||||
bool useTemporary = b->low == t->low;
|
|
||||||
Assembler::Register tmp(t->low);
|
|
||||||
if (useTemporary) {
|
|
||||||
tmp.low = con->client->acquireTemporary();
|
|
||||||
}
|
|
||||||
|
|
||||||
divideR(con, size, a, b, &tmp);
|
|
||||||
multiplyR(con, size, a, &tmp, &tmp);
|
|
||||||
subR(con, size, &tmp, b, t);
|
|
||||||
|
|
||||||
if (useTemporary) {
|
|
||||||
con->client->releaseTemporary(tmp.low);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
int
|
||||||
normalize(Context* c, int offset, int index, unsigned scale,
|
normalize(Context* c, int offset, int index, unsigned scale,
|
||||||
bool* preserveIndex, bool* release)
|
bool* preserveIndex, bool* release)
|
||||||
@ -1104,7 +1083,6 @@ compareRM(Context* c, unsigned aSize, Assembler::Register* a,
|
|||||||
c->client->releaseTemporary(tmp.low);
|
c->client->releaseTemporary(tmp.low);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO
|
|
||||||
void
|
void
|
||||||
longCompare(Context* c, Assembler::Operand* al, Assembler::Operand* ah,
|
longCompare(Context* c, Assembler::Operand* al, Assembler::Operand* ah,
|
||||||
Assembler::Operand* bl, Assembler::Operand* bh,
|
Assembler::Operand* bl, Assembler::Operand* bh,
|
||||||
@ -1295,7 +1273,7 @@ jumpC(Context* c, unsigned size UNUSED, Assembler::Constant* target)
|
|||||||
assert(c, size == BytesPerWord);
|
assert(c, size == BytesPerWord);
|
||||||
|
|
||||||
appendOffsetTask(c, target->value, offset(c), false);
|
appendOffsetTask(c, target->value, offset(c), false);
|
||||||
emit(c, b(0)); /* TODO */
|
emit(c, b(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -1365,7 +1343,6 @@ memoryBarrier(Context* c) {}
|
|||||||
|
|
||||||
// END OPERATION COMPILERS
|
// END OPERATION COMPILERS
|
||||||
|
|
||||||
// TODO
|
|
||||||
void
|
void
|
||||||
populateTables(ArchitectureContext* c)
|
populateTables(ArchitectureContext* c)
|
||||||
{
|
{
|
||||||
@ -1523,13 +1500,13 @@ class MyArchitecture: public Assembler::Architecture {
|
|||||||
}
|
}
|
||||||
|
|
||||||
virtual unsigned argumentRegisterCount() {
|
virtual unsigned argumentRegisterCount() {
|
||||||
return 8;
|
return 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual int argumentRegister(unsigned index) {
|
virtual int argumentRegister(unsigned index) {
|
||||||
assert(&c, index < argumentRegisterCount());
|
assert(&c, index < argumentRegisterCount());
|
||||||
|
|
||||||
return index + 3;
|
return index + 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual unsigned stackAlignmentInWords() {
|
virtual unsigned stackAlignmentInWords() {
|
||||||
@ -1685,18 +1662,9 @@ class MyArchitecture: public Assembler::Architecture {
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case Divide:
|
case Divide:
|
||||||
*bTypeMask = ~0;
|
|
||||||
*thunk = true;
|
|
||||||
*aTypeMask = (1 << RegisterOperand);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case Remainder:
|
case Remainder:
|
||||||
if (BytesPerWord == 4 and aSize == 8) {
|
|
||||||
*bTypeMask = ~0;
|
*bTypeMask = ~0;
|
||||||
*thunk = true;
|
*thunk = true;
|
||||||
} else {
|
|
||||||
*aTypeMask = (1 << RegisterOperand);
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
@ -788,6 +788,8 @@ class Context {
|
|||||||
case Remainder:
|
case Remainder:
|
||||||
if (size == 8) {
|
if (size == 8) {
|
||||||
return local::getThunk(t, moduloLongThunk);
|
return local::getThunk(t, moduloLongThunk);
|
||||||
|
} else if (size == 4) {
|
||||||
|
return local::getThunk(t, moduloIntThunk);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -2010,6 +2012,11 @@ moduloLong(int64_t b, int64_t a)
|
|||||||
return a % b;
|
return a % b;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int64_t
|
||||||
|
moduloInt(int32_t b, int32_t a) {
|
||||||
|
return a % b;
|
||||||
|
}
|
||||||
|
|
||||||
uint64_t
|
uint64_t
|
||||||
floatToDouble(int32_t a)
|
floatToDouble(int32_t a)
|
||||||
{
|
{
|
||||||
|
@ -22,6 +22,7 @@ THUNK(negateFloat)
|
|||||||
THUNK(divideLong)
|
THUNK(divideLong)
|
||||||
THUNK(divideInt)
|
THUNK(divideInt)
|
||||||
THUNK(moduloLong)
|
THUNK(moduloLong)
|
||||||
|
THUNK(moduloInt)
|
||||||
THUNK(floatToDouble)
|
THUNK(floatToDouble)
|
||||||
THUNK(floatToInt)
|
THUNK(floatToInt)
|
||||||
THUNK(floatToLong)
|
THUNK(floatToLong)
|
||||||
|
Loading…
Reference in New Issue
Block a user