mirror of
https://github.com/corda/corda.git
synced 2025-01-31 16:35:43 +00:00
fix ARM64 bootimage=true build
This fixes a problem with atomically updating JIT-compiled static calls to AOT-compiled code. It turns out there was also a problem with the 32-bit ARM code as well, but we never hit it because it is extremely unlikely that a code address can be loaded with a single immediate load instruction on 32-bit ARM since it can only handle numbers with 8 significant bits. I've fixed that as well.
This commit is contained in:
parent
8c277e2af8
commit
76bfcaa8c0
@ -320,8 +320,13 @@ class MyArchitecture : public Architecture {
|
|||||||
case lir::AlignedLongCall:
|
case lir::AlignedLongCall:
|
||||||
case lir::AlignedLongJump: {
|
case lir::AlignedLongJump: {
|
||||||
uint32_t* p = static_cast<uint32_t*>(returnAddress) - 2;
|
uint32_t* p = static_cast<uint32_t*>(returnAddress) - 2;
|
||||||
|
#if AVIAN_TARGET_ARCH == AVIAN_ARCH_ARM64
|
||||||
|
const int32_t mask = (PoolOffsetMask >> 2) << 5;
|
||||||
|
*reinterpret_cast<void**>(p + ((*p & mask) >> 5)) = newTarget;
|
||||||
|
#else
|
||||||
*reinterpret_cast<void**>(p + (((*p & PoolOffsetMask) + 8) / 4))
|
*reinterpret_cast<void**>(p + (((*p & PoolOffsetMask) + 8) / 4))
|
||||||
= newTarget;
|
= newTarget;
|
||||||
|
#endif
|
||||||
} break;
|
} break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
@ -317,7 +317,8 @@ void moveCR2(Context* con,
|
|||||||
lir::RegisterPair 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 (callOffset == 0 and src->value->resolved()
|
||||||
|
and isOfWidth(getValue(src), 8)) {
|
||||||
emit(con, movi(dst->low, lo8(getValue(src)))); // fits in immediate
|
emit(con, movi(dst->low, lo8(getValue(src)))); // fits in immediate
|
||||||
} else {
|
} else {
|
||||||
appendConstantPoolEntry(con, src->value, callOffset);
|
appendConstantPoolEntry(con, src->value, callOffset);
|
||||||
@ -1385,6 +1386,11 @@ void longCallC(Context* con, unsigned size UNUSED, lir::Constant* target)
|
|||||||
callR(con, vm::TargetBytesPerWord, &tmp);
|
callR(con, vm::TargetBytesPerWord, &tmp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void alignedLongCallC(Context* con, unsigned size, lir::Constant* target)
|
||||||
|
{
|
||||||
|
longCallC(con, size, target);
|
||||||
|
}
|
||||||
|
|
||||||
void longJumpC(Context* con, unsigned size UNUSED, lir::Constant* target)
|
void longJumpC(Context* con, unsigned size UNUSED, lir::Constant* target)
|
||||||
{
|
{
|
||||||
assertT(con, size == vm::TargetBytesPerWord);
|
assertT(con, size == vm::TargetBytesPerWord);
|
||||||
@ -1395,6 +1401,11 @@ void longJumpC(Context* con, unsigned size UNUSED, lir::Constant* target)
|
|||||||
jumpR(con, vm::TargetBytesPerWord, &tmp);
|
jumpR(con, vm::TargetBytesPerWord, &tmp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void alignedLongJumpC(Context* con, unsigned size, lir::Constant* target)
|
||||||
|
{
|
||||||
|
longJumpC(con, size, target);
|
||||||
|
}
|
||||||
|
|
||||||
void jumpC(Context* con, unsigned size UNUSED, lir::Constant* target)
|
void jumpC(Context* con, unsigned size UNUSED, lir::Constant* target)
|
||||||
{
|
{
|
||||||
assertT(con, size == vm::TargetBytesPerWord);
|
assertT(con, size == vm::TargetBytesPerWord);
|
||||||
|
@ -652,7 +652,7 @@ void moveCR2(Context* c,
|
|||||||
moveCR(c, size, src, size, &tmp);
|
moveCR(c, size, src, size, &tmp);
|
||||||
moveRR(c, size, &tmp, size, dst);
|
moveRR(c, size, &tmp, size, dst);
|
||||||
c->client->releaseTemporary(tmp.low);
|
c->client->releaseTemporary(tmp.low);
|
||||||
} else if (src->value->resolved()) {
|
} else if (callOffset == 0 and src->value->resolved()) {
|
||||||
int64_t value = src->value->value();
|
int64_t value = src->value->value();
|
||||||
if (value >= 0) {
|
if (value >= 0) {
|
||||||
append(c, movz(dst->low, value & 0xFFFF, 0, size));
|
append(c, movz(dst->low, value & 0xFFFF, 0, size));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user