mirror of
https://github.com/corda/corda.git
synced 2025-01-16 01:40:17 +00:00
bugfixes
This commit is contained in:
parent
7cb3a30a91
commit
542888a1d3
@ -14,7 +14,7 @@ const unsigned Top = ~static_cast<unsigned>(0);
|
|||||||
|
|
||||||
const unsigned InitialGen2CapacityInBytes = 4 * 1024 * 1024;
|
const unsigned InitialGen2CapacityInBytes = 4 * 1024 * 1024;
|
||||||
|
|
||||||
const bool Verbose = true;
|
const bool Verbose = false;
|
||||||
const bool Verbose2 = false;
|
const bool Verbose2 = false;
|
||||||
const bool Debug = false;
|
const bool Debug = false;
|
||||||
|
|
||||||
|
@ -235,7 +235,8 @@ CallBooleanMethodV(Thread* t, jobject o, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return booleanValue(t, run(t, getMethod(t, *o, m), *o, true, a));
|
object r = run(t, getMethod(t, *o, m), *o, true, a);
|
||||||
|
return (t->exception ? 0 : booleanValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
jboolean JNICALL
|
jboolean JNICALL
|
||||||
@ -256,7 +257,8 @@ CallByteMethodV(Thread* t, jobject o, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return byteValue(t, run(t, getMethod(t, *o, m), *o, true, a));
|
object r = run(t, getMethod(t, *o, m), *o, true, a);
|
||||||
|
return (t->exception ? 0 : byteValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
jbyte JNICALL
|
jbyte JNICALL
|
||||||
@ -277,7 +279,8 @@ CallCharMethodV(Thread* t, jobject o, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return charValue(t, run(t, getMethod(t, *o, m), *o, true, a));
|
object r = run(t, getMethod(t, *o, m), *o, true, a);
|
||||||
|
return (t->exception ? 0 : charValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
jchar JNICALL
|
jchar JNICALL
|
||||||
@ -298,7 +301,8 @@ CallShortMethodV(Thread* t, jobject o, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return shortValue(t, run(t, getMethod(t, *o, m), *o, true, a));
|
object r = run(t, getMethod(t, *o, m), *o, true, a);
|
||||||
|
return (t->exception ? 0 : shortValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
jshort JNICALL
|
jshort JNICALL
|
||||||
@ -319,7 +323,8 @@ CallIntMethodV(Thread* t, jobject o, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return intValue(t, run(t, getMethod(t, *o, m), *o, true, a));
|
object r = run(t, getMethod(t, *o, m), *o, true, a);
|
||||||
|
return (t->exception ? 0 : intValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
jint JNICALL
|
jint JNICALL
|
||||||
@ -340,7 +345,8 @@ CallLongMethodV(Thread* t, jobject o, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return longValue(t, run(t, getMethod(t, *o, m), *o, true, a));
|
object r = run(t, getMethod(t, *o, m), *o, true, a);
|
||||||
|
return (t->exception ? 0 : longValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
jlong JNICALL
|
jlong JNICALL
|
||||||
@ -361,7 +367,10 @@ CallFloatMethodV(Thread* t, jobject o, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return floatValue(t, run(t, getMethod(t, *o, m), *o, true, a));
|
object r = run(t, getMethod(t, *o, m), *o, true, a);
|
||||||
|
jint i = (t->exception ? 0 : floatValue(t, r));
|
||||||
|
jfloat f; memcpy(&f, &i, 4);
|
||||||
|
return f;
|
||||||
}
|
}
|
||||||
|
|
||||||
jfloat JNICALL
|
jfloat JNICALL
|
||||||
@ -382,7 +391,10 @@ CallDoubleMethodV(Thread* t, jobject o, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return doubleValue(t, run(t, getMethod(t, *o, m), *o, true, a));
|
object r = run(t, getMethod(t, *o, m), *o, true, a);
|
||||||
|
jlong i = (t->exception ? 0 : doubleValue(t, r));
|
||||||
|
jdouble f; memcpy(&f, &i, 4);
|
||||||
|
return f;
|
||||||
}
|
}
|
||||||
|
|
||||||
jdouble JNICALL
|
jdouble JNICALL
|
||||||
@ -420,7 +432,7 @@ CallVoidMethod(Thread* t, jobject o, jmethodID m, ...)
|
|||||||
inline object
|
inline object
|
||||||
getStaticMethod(Thread* t, object class_, jmethodID m)
|
getStaticMethod(Thread* t, object class_, jmethodID m)
|
||||||
{
|
{
|
||||||
return arrayBody(t, classMethodTable(t, class_), m);
|
return arrayBody(t, classMethodTable(t, class_), m - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
jobject JNICALL
|
jobject JNICALL
|
||||||
@ -449,7 +461,8 @@ CallStaticBooleanMethodV(Thread* t, jclass c, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return booleanValue(t, run(t, getStaticMethod(t, *c, m), 0, true, a));
|
object r = run(t, getStaticMethod(t, *c, m), 0, true, a);
|
||||||
|
return (t->exception ? 0 : booleanValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
jboolean JNICALL
|
jboolean JNICALL
|
||||||
@ -470,7 +483,8 @@ CallStaticByteMethodV(Thread* t, jclass c, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return byteValue(t, run(t, getStaticMethod(t, *c, m), 0, true, a));
|
object r = run(t, getStaticMethod(t, *c, m), 0, true, a);
|
||||||
|
return (t->exception ? 0 : byteValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
jbyte JNICALL
|
jbyte JNICALL
|
||||||
@ -491,7 +505,8 @@ CallStaticCharMethodV(Thread* t, jclass c, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return charValue(t, run(t, getStaticMethod(t, *c, m), 0, true, a));
|
object r = run(t, getStaticMethod(t, *c, m), 0, true, a);
|
||||||
|
return (t->exception ? 0 : charValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
jchar JNICALL
|
jchar JNICALL
|
||||||
@ -512,7 +527,8 @@ CallStaticShortMethodV(Thread* t, jclass c, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return shortValue(t, run(t, getStaticMethod(t, *c, m), 0, true, a));
|
object r = run(t, getStaticMethod(t, *c, m), 0, true, a);
|
||||||
|
return (t->exception ? 0 : shortValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
jshort JNICALL
|
jshort JNICALL
|
||||||
@ -533,7 +549,8 @@ CallStaticIntMethodV(Thread* t, jclass c, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return intValue(t, run(t, getStaticMethod(t, *c, m), 0, true, a));
|
object r = run(t, getStaticMethod(t, *c, m), 0, true, a);
|
||||||
|
return (t->exception ? 0 : intValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
jint JNICALL
|
jint JNICALL
|
||||||
@ -554,7 +571,8 @@ CallStaticLongMethodV(Thread* t, jclass c, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return longValue(t, run(t, getStaticMethod(t, *c, m), 0, true, a));
|
object r = run(t, getStaticMethod(t, *c, m), 0, true, a);
|
||||||
|
return (t->exception ? 0 : longValue(t, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
jlong JNICALL
|
jlong JNICALL
|
||||||
@ -575,7 +593,10 @@ CallStaticFloatMethodV(Thread* t, jclass c, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return floatValue(t, run(t, getStaticMethod(t, *c, m), 0, true, a));
|
object r = run(t, getStaticMethod(t, *c, m), 0, true, a);
|
||||||
|
jint i = (t->exception ? 0 : floatValue(t, r));
|
||||||
|
jfloat f; memcpy(&f, &i, 4);
|
||||||
|
return f;
|
||||||
}
|
}
|
||||||
|
|
||||||
jfloat JNICALL
|
jfloat JNICALL
|
||||||
@ -596,7 +617,10 @@ CallStaticDoubleMethodV(Thread* t, jclass c, jmethodID m, va_list a)
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
return doubleValue(t, run(t, getStaticMethod(t, *c, m), 0, true, a));
|
object r = run(t, getStaticMethod(t, *c, m), 0, true, a);
|
||||||
|
jlong i = (t->exception ? 0 : doubleValue(t, r));
|
||||||
|
jdouble f; memcpy(&f, &i, 4);
|
||||||
|
return f;
|
||||||
}
|
}
|
||||||
|
|
||||||
jdouble JNICALL
|
jdouble JNICALL
|
||||||
|
@ -361,7 +361,7 @@ postCollect(Thread* t)
|
|||||||
{
|
{
|
||||||
#ifdef VM_STRESS
|
#ifdef VM_STRESS
|
||||||
t->vm->system->free(t->defaultHeap);
|
t->vm->system->free(t->defaultHeap);
|
||||||
t->defaultHeap = static_cast<object*>
|
t->defaultHeap = static_cast<uintptr_t*>
|
||||||
(t->vm->system->allocate(Thread::HeapSizeInBytes));
|
(t->vm->system->allocate(Thread::HeapSizeInBytes));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -996,6 +996,8 @@ parseMethodTable(Thread* t, Stream& s, object class_, object pool)
|
|||||||
PROTECT(t, method);
|
PROTECT(t, method);
|
||||||
|
|
||||||
if (flags & ACC_STATIC) {
|
if (flags & ACC_STATIC) {
|
||||||
|
methodOffset(t, method) = i;
|
||||||
|
|
||||||
if (strcmp(reinterpret_cast<const int8_t*>("<clinit>"),
|
if (strcmp(reinterpret_cast<const int8_t*>("<clinit>"),
|
||||||
&byteArrayBody(t, methodName(t, method), 0)) == 0)
|
&byteArrayBody(t, methodName(t, method), 0)) == 0)
|
||||||
{
|
{
|
||||||
@ -1352,7 +1354,7 @@ Thread::Thread(Machine* m, object javaThread, Thread* parent):
|
|||||||
runnable(this)
|
runnable(this)
|
||||||
#ifdef VM_STRESS
|
#ifdef VM_STRESS
|
||||||
, stress(false),
|
, stress(false),
|
||||||
defaultHeap(static_cast<object*>(m->system->allocate(HeapSizeInBytes)))
|
defaultHeap(static_cast<uintptr_t*>(m->system->allocate(HeapSizeInBytes)))
|
||||||
#endif // VM_STRESS
|
#endif // VM_STRESS
|
||||||
, heap(defaultHeap)
|
, heap(defaultHeap)
|
||||||
{
|
{
|
||||||
|
@ -1097,9 +1097,9 @@ class Reference {
|
|||||||
|
|
||||||
class Machine {
|
class Machine {
|
||||||
public:
|
public:
|
||||||
enum {
|
enum Type {
|
||||||
#include "type-enums.cpp"
|
#include "type-enums.cpp"
|
||||||
} Type;
|
};
|
||||||
|
|
||||||
Machine(System* system, Heap* heap, Finder* finder);
|
Machine(System* system, Heap* heap, Finder* finder);
|
||||||
|
|
||||||
@ -1246,11 +1246,12 @@ class Thread {
|
|||||||
unsigned heapOffset;
|
unsigned heapOffset;
|
||||||
Protector* protector;
|
Protector* protector;
|
||||||
Runnable runnable;
|
Runnable runnable;
|
||||||
uintptr_t* heap;
|
|
||||||
#ifdef VM_STRESS
|
#ifdef VM_STRESS
|
||||||
bool stress;
|
bool stress;
|
||||||
uintptr_t* defaultHeap;
|
uintptr_t* defaultHeap;
|
||||||
|
uintptr_t* heap;
|
||||||
#else // not VM_STRESS
|
#else // not VM_STRESS
|
||||||
|
uintptr_t* heap;
|
||||||
uintptr_t defaultHeap[HeapSizeInWords];
|
uintptr_t defaultHeap[HeapSizeInWords];
|
||||||
#endif // not VM_STRESS
|
#endif // not VM_STRESS
|
||||||
uintptr_t stack[StackSizeInWords];
|
uintptr_t stack[StackSizeInWords];
|
||||||
|
18
src/run.cpp
18
src/run.cpp
@ -2450,8 +2450,13 @@ pushArguments(Thread* t, object this_, const char* spec, bool indirectObjects,
|
|||||||
case 'L':
|
case 'L':
|
||||||
while (*s and *s != ';') ++ s;
|
while (*s and *s != ';') ++ s;
|
||||||
++ s;
|
++ s;
|
||||||
pushObject
|
|
||||||
(t, (indirectObjects ? va_arg(a, object) : *va_arg(a, object*)));
|
if (indirectObjects) {
|
||||||
|
object* v = va_arg(a, object*);
|
||||||
|
pushObject(t, v ? *v : 0);
|
||||||
|
} else {
|
||||||
|
pushObject(t, va_arg(a, object));
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case '[':
|
case '[':
|
||||||
@ -2466,8 +2471,13 @@ pushArguments(Thread* t, object this_, const char* spec, bool indirectObjects,
|
|||||||
++ s;
|
++ s;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
pushObject
|
|
||||||
(t, (indirectObjects ? va_arg(a, object) : *va_arg(a, object*)));
|
if (indirectObjects) {
|
||||||
|
object* v = va_arg(a, object*);
|
||||||
|
pushObject(t, v ? *v : 0);
|
||||||
|
} else {
|
||||||
|
pushObject(t, va_arg(a, object));
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'J':
|
case 'J':
|
||||||
|
Loading…
Reference in New Issue
Block a user