mirror of
https://github.com/corda/corda.git
synced 2025-01-22 12:28:11 +00:00
fix native method lookup for fast calling convention on Windows
This commit is contained in:
parent
01f302d4b5
commit
ace985b390
@ -149,7 +149,7 @@ resolveNativeMethod(Thread* t, const char* undecorated, const char* decorated)
|
||||
|
||||
void*
|
||||
resolveNativeMethod(Thread* t, object method, const char* prefix,
|
||||
unsigned prefixLength)
|
||||
unsigned prefixLength, int footprint UNUSED)
|
||||
{
|
||||
unsigned undecoratedSize = prefixLength + jniNameLength(t, method, false);
|
||||
char undecorated[undecoratedSize + 1 + 6]; // extra 6 is for code below
|
||||
@ -166,10 +166,12 @@ resolveNativeMethod(Thread* t, object method, const char* prefix,
|
||||
|
||||
#ifdef __MINGW32__
|
||||
// on windows, we also try the _%s@%d and %s@%d variants
|
||||
unsigned footprint = methodParameterFootprint(t, method) + 1;
|
||||
if (footprint == -1) {
|
||||
footprint = methodParameterFootprint(t, method) + 1;
|
||||
if (methodFlags(t, method) & ACC_STATIC) {
|
||||
++ footprint;
|
||||
}
|
||||
}
|
||||
|
||||
*undecorated = '_';
|
||||
snprintf(undecorated + undecoratedSize + 1, 5, "@%d",
|
||||
@ -201,12 +203,12 @@ namespace vm {
|
||||
void*
|
||||
resolveNativeMethod(Thread* t, object method)
|
||||
{
|
||||
void* p = ::resolveNativeMethod(t, method, "Java_", 5);
|
||||
void* p = ::resolveNativeMethod(t, method, "Java_", 5, -1);
|
||||
if (p) {
|
||||
return p;
|
||||
}
|
||||
|
||||
p = ::resolveNativeMethod(t, method, "Avian_", 6);
|
||||
p = ::resolveNativeMethod(t, method, "Avian_", 6, 3);
|
||||
if (p) {
|
||||
methodVmFlags(t, method) |= FastNative;
|
||||
return p;
|
||||
|
Loading…
Reference in New Issue
Block a user