mirror of
https://github.com/corda/corda.git
synced 2025-01-21 03:55:00 +00:00
initialize vtables with pointers to JIT function, including native methods, since this allows code shrinkers to eliminate unused methods without confusing the VM
This commit is contained in:
parent
a60dafaf4f
commit
422133d1ba
@ -380,7 +380,9 @@ unsigned
|
|||||||
localSize(MyThread* t, object method)
|
localSize(MyThread* t, object method)
|
||||||
{
|
{
|
||||||
unsigned size = codeMaxLocals(t, methodCode(t, method));
|
unsigned size = codeMaxLocals(t, methodCode(t, method));
|
||||||
if (methodFlags(t, method) & ACC_SYNCHRONIZED) {
|
if ((methodFlags(t, method) & (ACC_SYNCHRONIZED | ACC_STATIC))
|
||||||
|
== ACC_SYNCHRONIZED)
|
||||||
|
{
|
||||||
++ size;
|
++ size;
|
||||||
}
|
}
|
||||||
return size;
|
return size;
|
||||||
@ -1603,8 +1605,8 @@ handleEntrance(MyThread* t, Frame* frame)
|
|||||||
{
|
{
|
||||||
object method = frame->context->method;
|
object method = frame->context->method;
|
||||||
|
|
||||||
if ((methodFlags(t, method) & ACC_SYNCHRONIZED)
|
if ((methodFlags(t, method) & (ACC_SYNCHRONIZED | ACC_STATIC))
|
||||||
and ((methodFlags(t, method) & ACC_STATIC) == 0))
|
== ACC_SYNCHRONIZED)
|
||||||
{
|
{
|
||||||
Compiler* c = frame->c;
|
Compiler* c = frame->c;
|
||||||
|
|
||||||
@ -3974,7 +3976,7 @@ invokeNative2(MyThread* t, object method)
|
|||||||
unsigned returnCode = methodReturnCode(t, method);
|
unsigned returnCode = methodReturnCode(t, method);
|
||||||
unsigned returnType = fieldType(t, returnCode);
|
unsigned returnType = fieldType(t, returnCode);
|
||||||
uint64_t result;
|
uint64_t result;
|
||||||
|
|
||||||
if (DebugNatives) {
|
if (DebugNatives) {
|
||||||
fprintf(stderr, "invoke native method %s.%s\n",
|
fprintf(stderr, "invoke native method %s.%s\n",
|
||||||
&byteArrayBody(t, className(t, methodClass(t, method)), 0),
|
&byteArrayBody(t, className(t, methodClass(t, method)), 0),
|
||||||
@ -4428,14 +4430,10 @@ class MyProcessor: public Processor {
|
|||||||
object class_,
|
object class_,
|
||||||
object code)
|
object code)
|
||||||
{
|
{
|
||||||
object compiled
|
|
||||||
= ((flags & ACC_NATIVE)
|
|
||||||
? getNativeCompiled(static_cast<MyThread*>(t))
|
|
||||||
: getDefaultCompiled(static_cast<MyThread*>(t)));
|
|
||||||
|
|
||||||
return vm::makeMethod
|
return vm::makeMethod
|
||||||
(t, vmFlags, returnCode, parameterCount, parameterFootprint, flags,
|
(t, vmFlags, returnCode, parameterCount, parameterFootprint, flags,
|
||||||
offset, name, spec, class_, code, compiled);
|
offset, name, spec, class_, code,
|
||||||
|
getDefaultCompiled(static_cast<MyThread*>(t)));
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual object
|
virtual object
|
||||||
@ -4465,13 +4463,11 @@ class MyProcessor: public Processor {
|
|||||||
virtual void
|
virtual void
|
||||||
initVtable(Thread* t, object c)
|
initVtable(Thread* t, object c)
|
||||||
{
|
{
|
||||||
for (unsigned i = 0; i < classLength(t, c); ++i) {
|
void* compiled = &singletonBody
|
||||||
object compiled
|
(t, getDefaultCompiled(static_cast<MyThread*>(t)), 0);
|
||||||
= ((classFlags(t, c) & ACC_NATIVE)
|
|
||||||
? getNativeCompiled(static_cast<MyThread*>(t))
|
|
||||||
: getDefaultCompiled(static_cast<MyThread*>(t)));
|
|
||||||
|
|
||||||
classVtable(t, c, i) = &singletonBody(t, compiled, 0);
|
for (unsigned i = 0; i < classLength(t, c); ++i) {
|
||||||
|
classVtable(t, c, i) = compiled;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4715,9 +4711,14 @@ compile(MyThread* t, object method)
|
|||||||
if (UNLIKELY(t->exception)) return;
|
if (UNLIKELY(t->exception)) return;
|
||||||
|
|
||||||
if (methodCompiled(t, method) == p->getDefaultCompiled(t)) {
|
if (methodCompiled(t, method) == p->getDefaultCompiled(t)) {
|
||||||
Context context(t, method, p->indirectCaller);
|
object compiled;
|
||||||
|
if (methodFlags(t, method) & ACC_NATIVE) {
|
||||||
object compiled = compile(t, &context);
|
compiled = p->getNativeCompiled(t);
|
||||||
|
} else {
|
||||||
|
Context context(t, method, p->indirectCaller);
|
||||||
|
compiled = compile(t, &context);
|
||||||
|
}
|
||||||
|
|
||||||
set(t, method, MethodCompiled, compiled);
|
set(t, method, MethodCompiled, compiled);
|
||||||
|
|
||||||
if (methodVirtual(t, method)) {
|
if (methodVirtual(t, method)) {
|
||||||
|
Loading…
Reference in New Issue
Block a user