mirror of
https://github.com/corda/corda.git
synced 2025-01-22 12:28:11 +00:00
make callNode and methodRuntimeData.native better statically typed
This commit is contained in:
parent
1da8170c66
commit
bb331e9414
@ -654,8 +654,8 @@ closeMemoryMappedFile(Thread* t, GcMethod* method, uintptr_t* arguments)
|
|||||||
}
|
}
|
||||||
|
|
||||||
t->m->processor->invoke
|
t->m->processor->invoke
|
||||||
(t, cast<GcMethod>(t, nativeInterceptOriginal
|
(t, cast<GcMethod>(t,
|
||||||
(t, getMethodRuntimeData(t, method)->native())),
|
getMethodRuntimeData(t, method)->native()->as<GcNativeIntercept>(t)->original()),
|
||||||
file);
|
file);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1963,7 +1963,7 @@ savedTargetIndex(MyThread* t UNUSED, GcMethod* method)
|
|||||||
return method->code()->maxLocals();
|
return method->code()->maxLocals();
|
||||||
}
|
}
|
||||||
|
|
||||||
object
|
GcCallNode*
|
||||||
findCallNode(MyThread* t, void* address);
|
findCallNode(MyThread* t, void* address);
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -6863,7 +6863,7 @@ finish(MyThread* t, FixedAllocator* allocator, Context* context)
|
|||||||
if (p->target) {
|
if (p->target) {
|
||||||
insertCallNode
|
insertCallNode
|
||||||
(t, reinterpret_cast<object>(makeCallNode
|
(t, reinterpret_cast<object>(makeCallNode
|
||||||
(t, p->address->value(), reinterpret_cast<object>(p->target), p->flags, 0)));
|
(t, p->address->value(), p->target, p->flags, 0)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -7314,9 +7314,9 @@ invokeNative(MyThread* t)
|
|||||||
ip = getIp(t);
|
ip = getIp(t);
|
||||||
}
|
}
|
||||||
|
|
||||||
object node = findCallNode(t, ip);
|
GcCallNode* node = findCallNode(t, ip);
|
||||||
GcMethod* target = cast<GcMethod>(t, callNodeTarget(t, node));
|
GcMethod* target = node->target();
|
||||||
if (callNodeFlags(t, node) & TraceElement::VirtualCall) {
|
if (node->flags() & TraceElement::VirtualCall) {
|
||||||
target = resolveTarget(t, t->stack, target);
|
target = resolveTarget(t, t->stack, target);
|
||||||
}
|
}
|
||||||
t->trace->nativeMethod = target;
|
t->trace->nativeMethod = target;
|
||||||
@ -8845,15 +8845,15 @@ class MyProcessor: public Processor {
|
|||||||
|
|
||||||
unsigned index = 0;
|
unsigned index = 0;
|
||||||
for (unsigned i = 0; i < arrayLength(t, root(t, CallTable)); ++i) {
|
for (unsigned i = 0; i < arrayLength(t, root(t, CallTable)); ++i) {
|
||||||
for (object p = arrayBody(t, root(t, CallTable), i);
|
for (GcCallNode* p = cast<GcCallNode>(t, arrayBody(t, root(t, CallTable), i));
|
||||||
p; p = callNodeNext(t, p))
|
p; p = p->next())
|
||||||
{
|
{
|
||||||
table[index++] = targetVW(
|
table[index++] = targetVW(
|
||||||
callNodeAddress(t, p)
|
p->address()
|
||||||
- reinterpret_cast<uintptr_t>(codeAllocator.memory.begin()));
|
- reinterpret_cast<uintptr_t>(codeAllocator.memory.begin()));
|
||||||
table[index++] = targetVW(
|
table[index++] = targetVW(
|
||||||
w->map()->find(callNodeTarget(t, p))
|
w->map()->find(reinterpret_cast<object>(p->target()))
|
||||||
| (static_cast<unsigned>(callNodeFlags(t, p)) << TargetBootShift));
|
| (static_cast<unsigned>(p->flags()) << TargetBootShift));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -9027,8 +9027,8 @@ logCompile(MyThread* t, const void* code, unsigned size, const char* class_,
|
|||||||
void*
|
void*
|
||||||
compileMethod2(MyThread* t, void* ip)
|
compileMethod2(MyThread* t, void* ip)
|
||||||
{
|
{
|
||||||
object node = findCallNode(t, ip);
|
GcCallNode* node = findCallNode(t, ip);
|
||||||
GcMethod* target = cast<GcMethod>(t, callNodeTarget(t, node));
|
GcMethod* target = node->target();
|
||||||
|
|
||||||
PROTECT(t, node);
|
PROTECT(t, node);
|
||||||
PROTECT(t, target);
|
PROTECT(t, target);
|
||||||
@ -9056,13 +9056,13 @@ compileMethod2(MyThread* t, void* ip)
|
|||||||
|
|
||||||
if (updateCaller) {
|
if (updateCaller) {
|
||||||
avian::codegen::lir::UnaryOperation op;
|
avian::codegen::lir::UnaryOperation op;
|
||||||
if (callNodeFlags(t, node) & TraceElement::LongCall) {
|
if (node->flags() & TraceElement::LongCall) {
|
||||||
if (callNodeFlags(t, node) & TraceElement::TailCall) {
|
if (node->flags() & TraceElement::TailCall) {
|
||||||
op = avian::codegen::lir::AlignedLongJump;
|
op = avian::codegen::lir::AlignedLongJump;
|
||||||
} else {
|
} else {
|
||||||
op = avian::codegen::lir::AlignedLongCall;
|
op = avian::codegen::lir::AlignedLongCall;
|
||||||
}
|
}
|
||||||
} else if (callNodeFlags(t, node) & TraceElement::TailCall) {
|
} else if (node->flags() & TraceElement::TailCall) {
|
||||||
op = avian::codegen::lir::AlignedJump;
|
op = avian::codegen::lir::AlignedJump;
|
||||||
} else {
|
} else {
|
||||||
op = avian::codegen::lir::AlignedCall;
|
op = avian::codegen::lir::AlignedCall;
|
||||||
@ -9161,7 +9161,7 @@ isThunkUnsafeStack(MyThread* t, void* ip)
|
|||||||
or isThunkUnsafeStack(&(p->bootThunks), ip));
|
or isThunkUnsafeStack(&(p->bootThunks), ip));
|
||||||
}
|
}
|
||||||
|
|
||||||
object
|
GcCallNode*
|
||||||
findCallNode(MyThread* t, void* address)
|
findCallNode(MyThread* t, void* address)
|
||||||
{
|
{
|
||||||
if (DebugCallTable) {
|
if (DebugCallTable) {
|
||||||
@ -9178,10 +9178,10 @@ findCallNode(MyThread* t, void* address)
|
|||||||
intptr_t key = reinterpret_cast<intptr_t>(address);
|
intptr_t key = reinterpret_cast<intptr_t>(address);
|
||||||
unsigned index = static_cast<uintptr_t>(key) & (arrayLength(t, table) - 1);
|
unsigned index = static_cast<uintptr_t>(key) & (arrayLength(t, table) - 1);
|
||||||
|
|
||||||
for (object n = arrayBody(t, table, index);
|
for (GcCallNode* n = cast<GcCallNode>(t, arrayBody(t, table, index));
|
||||||
n; n = callNodeNext(t, n))
|
n; n = n->next())
|
||||||
{
|
{
|
||||||
intptr_t k = callNodeAddress(t, n);
|
intptr_t k = n->address();
|
||||||
|
|
||||||
if (k == key) {
|
if (k == key) {
|
||||||
return n;
|
return n;
|
||||||
@ -9196,26 +9196,26 @@ resizeTable(MyThread* t, object oldTable, unsigned newLength)
|
|||||||
{
|
{
|
||||||
PROTECT(t, oldTable);
|
PROTECT(t, oldTable);
|
||||||
|
|
||||||
object oldNode = 0;
|
GcCallNode* oldNode = 0;
|
||||||
PROTECT(t, oldNode);
|
PROTECT(t, oldNode);
|
||||||
|
|
||||||
object newTable = reinterpret_cast<object>(makeArray(t, newLength));
|
object newTable = reinterpret_cast<object>(makeArray(t, newLength));
|
||||||
PROTECT(t, newTable);
|
PROTECT(t, newTable);
|
||||||
|
|
||||||
for (unsigned i = 0; i < arrayLength(t, oldTable); ++i) {
|
for (unsigned i = 0; i < arrayLength(t, oldTable); ++i) {
|
||||||
for (oldNode = arrayBody(t, oldTable, i);
|
for (oldNode = cast<GcCallNode>(t, arrayBody(t, oldTable, i));
|
||||||
oldNode;
|
oldNode;
|
||||||
oldNode = callNodeNext(t, oldNode))
|
oldNode = oldNode->next())
|
||||||
{
|
{
|
||||||
intptr_t k = callNodeAddress(t, oldNode);
|
intptr_t k = oldNode->address();
|
||||||
|
|
||||||
unsigned index = k & (newLength - 1);
|
unsigned index = k & (newLength - 1);
|
||||||
|
|
||||||
object newNode = reinterpret_cast<object>(makeCallNode
|
object newNode = reinterpret_cast<object>(makeCallNode
|
||||||
(t, callNodeAddress(t, oldNode),
|
(t, oldNode->address(),
|
||||||
callNodeTarget(t, oldNode),
|
oldNode->target(),
|
||||||
callNodeFlags(t, oldNode),
|
oldNode->flags(),
|
||||||
arrayBody(t, newTable, index)));
|
cast<GcCallNode>(t, arrayBody(t, newTable, index))));
|
||||||
|
|
||||||
set(t, newTable, ArrayBody + (index * BytesPerWord), newNode);
|
set(t, newTable, ArrayBody + (index * BytesPerWord), newNode);
|
||||||
}
|
}
|
||||||
@ -9320,7 +9320,7 @@ makeCallTable(MyThread* t, uintptr_t* heap, unsigned* calls, unsigned count,
|
|||||||
unsigned target = calls[(i * 2) + 1];
|
unsigned target = calls[(i * 2) + 1];
|
||||||
|
|
||||||
object node = reinterpret_cast<object>(makeCallNode
|
object node = reinterpret_cast<object>(makeCallNode
|
||||||
(t, base + address, bootObject(heap, target & BootMask),
|
(t, base + address, cast<GcMethod>(t, bootObject(heap, target & BootMask)),
|
||||||
target >> BootShift, 0));
|
target >> BootShift, 0));
|
||||||
|
|
||||||
table = insertCallNode(t, table, &size, node);
|
table = insertCallNode(t, table, &size, node);
|
||||||
|
@ -49,16 +49,16 @@
|
|||||||
(object pool)
|
(object pool)
|
||||||
(object signers))
|
(object signers))
|
||||||
|
|
||||||
(type methodRuntimeData
|
|
||||||
(object native))
|
|
||||||
|
|
||||||
(type pointer
|
|
||||||
(void* value))
|
|
||||||
|
|
||||||
(type native
|
(type native
|
||||||
(void* function)
|
(void* function)
|
||||||
(uint8_t fast))
|
(uint8_t fast))
|
||||||
|
|
||||||
|
(type methodRuntimeData
|
||||||
|
(native native))
|
||||||
|
|
||||||
|
(type pointer
|
||||||
|
(void* value))
|
||||||
|
|
||||||
(type nativeIntercept
|
(type nativeIntercept
|
||||||
(extends native)
|
(extends native)
|
||||||
(object original))
|
(object original))
|
||||||
@ -120,9 +120,9 @@
|
|||||||
|
|
||||||
(type callNode
|
(type callNode
|
||||||
(intptr_t address)
|
(intptr_t address)
|
||||||
(object target)
|
(method target)
|
||||||
(uintptr_t flags)
|
(uintptr_t flags)
|
||||||
(object next))
|
(callNode next))
|
||||||
|
|
||||||
(type wordArray
|
(type wordArray
|
||||||
(array uintptr_t body))
|
(array uintptr_t body))
|
||||||
|
Loading…
Reference in New Issue
Block a user