mirror of
https://github.com/corda/corda.git
synced 2025-01-01 10:46:46 +00:00
fix Call*Method() calls to wrong run() function
This commit is contained in:
parent
542888a1d3
commit
dc34707f98
4
makefile
4
makefile
@ -23,8 +23,8 @@ swt-input = $(cls)/HelloSWT.class
|
|||||||
|
|
||||||
cxx = g++
|
cxx = g++
|
||||||
cc = gcc
|
cc = gcc
|
||||||
vg = nice valgrind --leak-check=full --num-callers=32 --db-attach=yes \
|
vg = nice valgrind --suppressions=valgrind.supp --leak-check=full \
|
||||||
--freelist-vol=100000000
|
--num-callers=32 --db-attach=yes --freelist-vol=100000000
|
||||||
db = gdb --args
|
db = gdb --args
|
||||||
javac = javac
|
javac = javac
|
||||||
strip = :
|
strip = :
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
#include "jnienv.h"
|
#include "jnienv.h"
|
||||||
#include "machine.h"
|
#include "machine.h"
|
||||||
|
#include "run.h"
|
||||||
#include "constants.h"
|
#include "constants.h"
|
||||||
|
|
||||||
using namespace vm;
|
using namespace vm;
|
||||||
@ -214,7 +215,7 @@ CallObjectMethodV(Thread* t, jobject o, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return pushReference(t, run(t, getMethod(t, *o, m), *o, true, a));
|
return pushReference(t, runv(t, getMethod(t, *o, m), *o, true, a));
|
||||||
}
|
}
|
||||||
|
|
||||||
jobject JNICALL
|
jobject JNICALL
|
||||||
@ -235,7 +236,7 @@ CallBooleanMethodV(Thread* t, jobject o, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
object r = run(t, getMethod(t, *o, m), *o, true, a);
|
object r = runv(t, getMethod(t, *o, m), *o, true, a);
|
||||||
return (t->exception ? 0 : booleanValue(t, r));
|
return (t->exception ? 0 : booleanValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -257,7 +258,7 @@ CallByteMethodV(Thread* t, jobject o, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
object r = run(t, getMethod(t, *o, m), *o, true, a);
|
object r = runv(t, getMethod(t, *o, m), *o, true, a);
|
||||||
return (t->exception ? 0 : byteValue(t, r));
|
return (t->exception ? 0 : byteValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -279,7 +280,7 @@ CallCharMethodV(Thread* t, jobject o, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
object r = run(t, getMethod(t, *o, m), *o, true, a);
|
object r = runv(t, getMethod(t, *o, m), *o, true, a);
|
||||||
return (t->exception ? 0 : charValue(t, r));
|
return (t->exception ? 0 : charValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -301,7 +302,7 @@ CallShortMethodV(Thread* t, jobject o, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
object r = run(t, getMethod(t, *o, m), *o, true, a);
|
object r = runv(t, getMethod(t, *o, m), *o, true, a);
|
||||||
return (t->exception ? 0 : shortValue(t, r));
|
return (t->exception ? 0 : shortValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -323,7 +324,7 @@ CallIntMethodV(Thread* t, jobject o, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
object r = run(t, getMethod(t, *o, m), *o, true, a);
|
object r = runv(t, getMethod(t, *o, m), *o, true, a);
|
||||||
return (t->exception ? 0 : intValue(t, r));
|
return (t->exception ? 0 : intValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -345,7 +346,7 @@ CallLongMethodV(Thread* t, jobject o, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
object r = run(t, getMethod(t, *o, m), *o, true, a);
|
object r = runv(t, getMethod(t, *o, m), *o, true, a);
|
||||||
return (t->exception ? 0 : longValue(t, r));
|
return (t->exception ? 0 : longValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -367,7 +368,7 @@ CallFloatMethodV(Thread* t, jobject o, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
object r = run(t, getMethod(t, *o, m), *o, true, a);
|
object r = runv(t, getMethod(t, *o, m), *o, true, a);
|
||||||
jint i = (t->exception ? 0 : floatValue(t, r));
|
jint i = (t->exception ? 0 : floatValue(t, r));
|
||||||
jfloat f; memcpy(&f, &i, 4);
|
jfloat f; memcpy(&f, &i, 4);
|
||||||
return f;
|
return f;
|
||||||
@ -391,7 +392,7 @@ CallDoubleMethodV(Thread* t, jobject o, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
object r = run(t, getMethod(t, *o, m), *o, true, a);
|
object r = runv(t, getMethod(t, *o, m), *o, true, a);
|
||||||
jlong i = (t->exception ? 0 : doubleValue(t, r));
|
jlong i = (t->exception ? 0 : doubleValue(t, r));
|
||||||
jdouble f; memcpy(&f, &i, 4);
|
jdouble f; memcpy(&f, &i, 4);
|
||||||
return f;
|
return f;
|
||||||
@ -415,7 +416,7 @@ CallVoidMethodV(Thread* t, jobject o, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
run(t, getMethod(t, *o, m), *o, true, a);
|
runv(t, getMethod(t, *o, m), *o, true, a);
|
||||||
}
|
}
|
||||||
|
|
||||||
void JNICALL
|
void JNICALL
|
||||||
@ -440,7 +441,7 @@ CallStaticObjectMethodV(Thread* t, jclass c, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return pushReference(t, run(t, getStaticMethod(t, *c, m), 0, true, a));
|
return pushReference(t, runv(t, getStaticMethod(t, *c, m), 0, true, a));
|
||||||
}
|
}
|
||||||
|
|
||||||
jobject JNICALL
|
jobject JNICALL
|
||||||
@ -461,7 +462,7 @@ CallStaticBooleanMethodV(Thread* t, jclass c, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
object r = run(t, getStaticMethod(t, *c, m), 0, true, a);
|
object r = runv(t, getStaticMethod(t, *c, m), 0, true, a);
|
||||||
return (t->exception ? 0 : booleanValue(t, r));
|
return (t->exception ? 0 : booleanValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -483,7 +484,7 @@ CallStaticByteMethodV(Thread* t, jclass c, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
object r = run(t, getStaticMethod(t, *c, m), 0, true, a);
|
object r = runv(t, getStaticMethod(t, *c, m), 0, true, a);
|
||||||
return (t->exception ? 0 : byteValue(t, r));
|
return (t->exception ? 0 : byteValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -505,7 +506,7 @@ CallStaticCharMethodV(Thread* t, jclass c, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
object r = run(t, getStaticMethod(t, *c, m), 0, true, a);
|
object r = runv(t, getStaticMethod(t, *c, m), 0, true, a);
|
||||||
return (t->exception ? 0 : charValue(t, r));
|
return (t->exception ? 0 : charValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -527,7 +528,7 @@ CallStaticShortMethodV(Thread* t, jclass c, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
object r = run(t, getStaticMethod(t, *c, m), 0, true, a);
|
object r = runv(t, getStaticMethod(t, *c, m), 0, true, a);
|
||||||
return (t->exception ? 0 : shortValue(t, r));
|
return (t->exception ? 0 : shortValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -549,7 +550,7 @@ CallStaticIntMethodV(Thread* t, jclass c, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
object r = run(t, getStaticMethod(t, *c, m), 0, true, a);
|
object r = runv(t, getStaticMethod(t, *c, m), 0, true, a);
|
||||||
return (t->exception ? 0 : intValue(t, r));
|
return (t->exception ? 0 : intValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -571,7 +572,7 @@ CallStaticLongMethodV(Thread* t, jclass c, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
object r = run(t, getStaticMethod(t, *c, m), 0, true, a);
|
object r = runv(t, getStaticMethod(t, *c, m), 0, true, a);
|
||||||
return (t->exception ? 0 : longValue(t, r));
|
return (t->exception ? 0 : longValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -593,7 +594,7 @@ CallStaticFloatMethodV(Thread* t, jclass c, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
object r = run(t, getStaticMethod(t, *c, m), 0, true, a);
|
object r = runv(t, getStaticMethod(t, *c, m), 0, true, a);
|
||||||
jint i = (t->exception ? 0 : floatValue(t, r));
|
jint i = (t->exception ? 0 : floatValue(t, r));
|
||||||
jfloat f; memcpy(&f, &i, 4);
|
jfloat f; memcpy(&f, &i, 4);
|
||||||
return f;
|
return f;
|
||||||
@ -617,7 +618,7 @@ CallStaticDoubleMethodV(Thread* t, jclass c, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
object r = run(t, getStaticMethod(t, *c, m), 0, true, a);
|
object r = runv(t, getStaticMethod(t, *c, m), 0, true, a);
|
||||||
jlong i = (t->exception ? 0 : doubleValue(t, r));
|
jlong i = (t->exception ? 0 : doubleValue(t, r));
|
||||||
jdouble f; memcpy(&f, &i, 4);
|
jdouble f; memcpy(&f, &i, 4);
|
||||||
return f;
|
return f;
|
||||||
@ -641,7 +642,7 @@ CallStaticVoidMethodV(Thread* t, jclass c, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
run(t, getStaticMethod(t, *c, m), 0, true, a);
|
runv(t, getStaticMethod(t, *c, m), 0, true, a);
|
||||||
}
|
}
|
||||||
|
|
||||||
void JNICALL
|
void JNICALL
|
||||||
|
@ -2661,7 +2661,7 @@ invoke(Thread* t, object method)
|
|||||||
namespace vm {
|
namespace vm {
|
||||||
|
|
||||||
object
|
object
|
||||||
run(Thread* t, object method, object this_, bool indirectObjects, va_list a)
|
runv(Thread* t, object method, object this_, bool indirectObjects, va_list a)
|
||||||
{
|
{
|
||||||
assert(t, t->state == Thread::ActiveState
|
assert(t, t->state == Thread::ActiveState
|
||||||
or t->state == Thread::ExclusiveState);
|
or t->state == Thread::ExclusiveState);
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
namespace vm {
|
namespace vm {
|
||||||
|
|
||||||
object
|
object
|
||||||
run(Thread* t, object method, object this_, bool indirectObjects, va_list a);
|
runv(Thread* t, object method, object this_, bool indirectObjects, va_list a);
|
||||||
|
|
||||||
object
|
object
|
||||||
run(Thread* t, object method, object this_, ...);
|
run(Thread* t, object method, object this_, ...);
|
||||||
|
54
valgrind.supp
Normal file
54
valgrind.supp
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
|
||||||
|
{
|
||||||
|
ld-cond
|
||||||
|
Memcheck:Cond
|
||||||
|
obj:/lib/ld-2.3.6.so
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
ld-addr4
|
||||||
|
Memcheck:Addr4
|
||||||
|
obj:/lib/ld-2.3.6.so
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
ld-addr7
|
||||||
|
Memcheck:Addr8
|
||||||
|
obj:/lib/ld-2.3.6.so
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
gtk-write
|
||||||
|
Memcheck:Param
|
||||||
|
write(buf)
|
||||||
|
obj:/lib/ld-2.3.6.so
|
||||||
|
fun:_X11TransWrite
|
||||||
|
obj:/usr/lib/libX11.so.6.2.0
|
||||||
|
fun:_XReply
|
||||||
|
fun:XInternAtom
|
||||||
|
fun:XSetWMProperties
|
||||||
|
fun:setup_toplevel_window
|
||||||
|
fun:gdk_window_new
|
||||||
|
fun:gdk_display_open
|
||||||
|
fun:gdk_display_open_default_libgtk_only
|
||||||
|
fun:gtk_init_check
|
||||||
|
fun:Java_org_eclipse_swt_internal_gtk_OS__1gtk_1init_1check
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
gtk-writev
|
||||||
|
Memcheck:Param
|
||||||
|
writev(vector[...])
|
||||||
|
obj:/lib/ld-2.3.6.so
|
||||||
|
obj:/usr/lib/libX11.so.6.2.0
|
||||||
|
fun:_X11TransWritev
|
||||||
|
fun:_XSend
|
||||||
|
fun:XQueryExtension
|
||||||
|
fun:XInitExtension
|
||||||
|
fun:XkbUseExtension
|
||||||
|
fun:XkbQueryExtension
|
||||||
|
fun:gdk_display_open
|
||||||
|
fun:gdk_display_open_default_libgtk_only
|
||||||
|
fun:gtk_init_check
|
||||||
|
fun:Java_org_eclipse_swt_internal_gtk_OS__1gtk_1init_1check
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user