mirror of
https://github.com/corda/corda.git
synced 2025-01-01 02:36:44 +00:00
bugfixes for recent refactoring effort
This commit is contained in:
parent
8d983c8a39
commit
1c90708abf
2
makefile
2
makefile
@ -32,7 +32,7 @@ src = src
|
||||
classpath = classpath
|
||||
test = test
|
||||
|
||||
input = $(cls)/Hello.class
|
||||
input = $(cls)/Threads.class
|
||||
|
||||
cxx = g++
|
||||
cc = gcc
|
||||
|
@ -308,11 +308,12 @@ Java_java_lang_reflect_Method_getCaller(Thread* t, jclass)
|
||||
{
|
||||
ENTER(t, Thread::ActiveState);
|
||||
|
||||
FrameIterator it; t->m->processor->start(t, &it);
|
||||
t->m->processor->next(t, &it);
|
||||
t->m->processor->next(t, &it);
|
||||
Processor* p = t->m->processor;
|
||||
uintptr_t frame = p->frameStart(t);
|
||||
frame = p->frameNext(t, frame);
|
||||
frame = p->frameNext(t, frame);
|
||||
|
||||
return makeLocalReference(t, it.method);
|
||||
return makeLocalReference(t, p->frameMethod(t, frame));
|
||||
}
|
||||
|
||||
extern "C" JNIEXPORT jobject JNICALL
|
||||
@ -321,7 +322,7 @@ Java_java_lang_reflect_Method_invoke
|
||||
{
|
||||
ENTER(t, Thread::ActiveState);
|
||||
|
||||
object v = t->m->processor->invoke
|
||||
object v = t->m->processor->invokeArray
|
||||
(t, *method, (instance ? *instance : 0), *arguments);
|
||||
if (t->exception) {
|
||||
t->exception = makeInvocationTargetException(t, t->exception);
|
||||
@ -529,25 +530,27 @@ Java_java_lang_Throwable_trace(Thread* t, jclass, jint skipCount)
|
||||
{
|
||||
ENTER(t, Thread::ActiveState);
|
||||
|
||||
FrameIterator it; t->m->processor->start(t, &it);
|
||||
Processor* p = t->m->processor;
|
||||
uintptr_t frame = p->frameStart(t);
|
||||
|
||||
while (skipCount-- and it.valid()) {
|
||||
t->m->processor->next(t, &it);
|
||||
while (skipCount-- and p->frameValid(t, frame)) {
|
||||
frame = p->frameNext(t, frame);
|
||||
}
|
||||
|
||||
// skip Throwable constructors
|
||||
while (it.valid()
|
||||
while (p->frameValid(t, frame)
|
||||
and isAssignableFrom
|
||||
(t, arrayBody(t, t->m->types, Machine::ThrowableType),
|
||||
methodClass(t, it.method))
|
||||
methodClass(t, p->frameMethod(t, frame)))
|
||||
and strcmp(reinterpret_cast<const int8_t*>("<init>"),
|
||||
&byteArrayBody(t, methodName(t, it.method), 0))
|
||||
&byteArrayBody
|
||||
(t, methodName(t, p->frameMethod(t, frame)), 0))
|
||||
== 0)
|
||||
{
|
||||
t->m->processor->next(t, &it);
|
||||
frame = p->frameNext(t, frame);
|
||||
}
|
||||
|
||||
return makeLocalReference(t, makeTrace(t, &it));
|
||||
return makeLocalReference(t, makeTrace(t, frame));
|
||||
}
|
||||
|
||||
extern "C" JNIEXPORT jarray JNICALL
|
||||
@ -599,8 +602,7 @@ Java_java_lang_Thread_doStart(Thread* t, jobject this_)
|
||||
{
|
||||
ENTER(t, Thread::ActiveState);
|
||||
|
||||
Thread* p = new (t->m->system->allocate(sizeof(Thread)))
|
||||
Thread(t->m, *this_, t);
|
||||
Thread* p = t->m->processor->makeThread(t->m, *this_, t);
|
||||
|
||||
enter(p, Thread::ActiveState);
|
||||
|
||||
|
@ -28,45 +28,6 @@ class Thread: public vm::Thread {
|
||||
uintptr_t stack[StackSizeInWords];
|
||||
};
|
||||
|
||||
class MyProcessor: public Processor {
|
||||
public:
|
||||
MyProcessor(System* s):
|
||||
s(s)
|
||||
{ }
|
||||
|
||||
virtual vm::Thread*
|
||||
makeThread(Machine* m, object javaThread, vm::Thread* parent)
|
||||
{
|
||||
return new (s->allocate(sizeof(Thread))) Thread(m, javaThread, parent);
|
||||
}
|
||||
|
||||
virtual void
|
||||
visitObjects(vm::Thread* t, Heap::Visitor* v);
|
||||
|
||||
virtual void
|
||||
start(vm::Thread* t, FrameIterator* it);
|
||||
|
||||
virtual void
|
||||
next(vm::Thread* t, FrameIterator* it);
|
||||
|
||||
virtual object
|
||||
invokeArray(vm::Thread* t, object method, object this_, object arguments);
|
||||
|
||||
virtual object
|
||||
invokeList(vm::Thread* t, object method, object this_, bool indirectObjects,
|
||||
va_list arguments);
|
||||
|
||||
virtual object
|
||||
invokeList(vm::Thread* t, const char* className, const char* methodName,
|
||||
const char* methodSpec, object this_, va_list arguments);
|
||||
|
||||
virtual void dispose() {
|
||||
s->free(this);
|
||||
}
|
||||
|
||||
System* s;
|
||||
};
|
||||
|
||||
inline void
|
||||
pushObject(Thread* t, object o)
|
||||
{
|
||||
@ -3039,127 +3000,176 @@ invoke(Thread* t, object method)
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
MyProcessor::visitObjects(vm::Thread* vmt, Heap::Visitor* v)
|
||||
{
|
||||
Thread* t = static_cast<Thread*>(vmt);
|
||||
class MyProcessor: public Processor {
|
||||
public:
|
||||
MyProcessor(System* s):
|
||||
s(s)
|
||||
{ }
|
||||
|
||||
v->visit(&(t->code));
|
||||
virtual vm::Thread*
|
||||
makeThread(Machine* m, object javaThread, vm::Thread* parent)
|
||||
{
|
||||
return new (s->allocate(sizeof(Thread))) Thread(m, javaThread, parent);
|
||||
}
|
||||
|
||||
for (unsigned i = 0; i < t->sp; ++i) {
|
||||
if (t->stack[i * 2] == ObjectTag) {
|
||||
v->visit(t->stack + (i * 2) + 1);
|
||||
virtual void
|
||||
visitObjects(vm::Thread* vmt, Heap::Visitor* v)
|
||||
{
|
||||
Thread* t = static_cast<Thread*>(vmt);
|
||||
|
||||
v->visit(&(t->code));
|
||||
|
||||
for (unsigned i = 0; i < t->sp; ++i) {
|
||||
if (t->stack[i * 2] == ObjectTag) {
|
||||
v->visit(t->stack + (i * 2) + 1);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
MyProcessor::start(vm::Thread* vmt, FrameIterator* it)
|
||||
{
|
||||
Thread* t = static_cast<Thread*>(vmt);
|
||||
virtual uintptr_t
|
||||
frameStart(vm::Thread* vmt)
|
||||
{
|
||||
Thread* t = static_cast<Thread*>(vmt);
|
||||
|
||||
int f = t->frame;
|
||||
it->base = f + 1;
|
||||
if (it->valid()) {
|
||||
pokeInt(t, t->frame + FrameIpOffset, t->ip);
|
||||
it->method = frameMethod(t, f);
|
||||
it->ip = frameIp(t, f);
|
||||
if (t->frame >= 0) {
|
||||
pokeInt(t, t->frame + FrameIpOffset, t->ip);
|
||||
}
|
||||
return t->frame;
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
MyProcessor::next(vm::Thread* vmt, FrameIterator* it)
|
||||
{
|
||||
Thread* t = static_cast<Thread*>(vmt);
|
||||
virtual uintptr_t
|
||||
frameNext(vm::Thread* vmt, uintptr_t frame)
|
||||
{
|
||||
Thread* t = static_cast<Thread*>(vmt);
|
||||
|
||||
if (it->valid()) {
|
||||
int f = frameNext(t, it->base - 1);
|
||||
it->base = f + 1;
|
||||
if (it->valid()) {
|
||||
it->method = frameMethod(t, f);
|
||||
it->ip = frameIp(t, f);
|
||||
assert(t, static_cast<intptr_t>(frame) >= 0);
|
||||
return ::frameNext(t, frame);
|
||||
}
|
||||
|
||||
virtual bool
|
||||
frameValid(vm::Thread*, uintptr_t frame)
|
||||
{
|
||||
return static_cast<intptr_t>(frame) >= 0;
|
||||
}
|
||||
|
||||
virtual object
|
||||
frameMethod(vm::Thread* vmt, uintptr_t frame)
|
||||
{
|
||||
Thread* t = static_cast<Thread*>(vmt);
|
||||
|
||||
assert(t, static_cast<intptr_t>(frame) >= 0);
|
||||
return ::frameMethod(t, frame);
|
||||
}
|
||||
|
||||
virtual unsigned
|
||||
frameIp(vm::Thread* vmt, uintptr_t frame)
|
||||
{
|
||||
Thread* t = static_cast<Thread*>(vmt);
|
||||
|
||||
assert(t, static_cast<intptr_t>(frame) >= 0);
|
||||
return ::frameIp(t, frame);
|
||||
}
|
||||
|
||||
virtual object*
|
||||
makeLocalReference(vm::Thread* vmt, object o)
|
||||
{
|
||||
Thread* t = static_cast<Thread*>(vmt);
|
||||
|
||||
return pushReference(t, o);
|
||||
}
|
||||
|
||||
virtual void
|
||||
disposeLocalReference(vm::Thread*, object* r)
|
||||
{
|
||||
if (r) {
|
||||
*r = 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
object
|
||||
MyProcessor::invokeArray(vm::Thread* vmt, object method, object this_,
|
||||
object arguments)
|
||||
{
|
||||
Thread* t = static_cast<Thread*>(vmt);
|
||||
|
||||
assert(t, t->state == Thread::ActiveState
|
||||
or t->state == Thread::ExclusiveState);
|
||||
|
||||
assert(t, ((methodFlags(t, method) & ACC_STATIC) == 0) xor (this_ == 0));
|
||||
|
||||
if (UNLIKELY(t->sp + methodParameterFootprint(t, method) + 1
|
||||
> Thread::StackSizeInWords / 2))
|
||||
virtual object
|
||||
invokeArray(vm::Thread* vmt, object method, object this_, object arguments)
|
||||
{
|
||||
t->exception = makeStackOverflowError(t);
|
||||
return 0;
|
||||
}
|
||||
Thread* t = static_cast<Thread*>(vmt);
|
||||
|
||||
const char* spec = reinterpret_cast<char*>
|
||||
(&byteArrayBody(t, methodSpec(t, method), 0));
|
||||
pushArguments(t, this_, spec, arguments);
|
||||
assert(t, t->state == Thread::ActiveState
|
||||
or t->state == Thread::ExclusiveState);
|
||||
|
||||
return ::invoke(t, method);
|
||||
}
|
||||
|
||||
object
|
||||
MyProcessor::invokeList(vm::Thread* vmt, object method, object this_,
|
||||
bool indirectObjects, va_list arguments)
|
||||
{
|
||||
Thread* t = static_cast<Thread*>(vmt);
|
||||
|
||||
assert(t, t->state == Thread::ActiveState
|
||||
or t->state == Thread::ExclusiveState);
|
||||
|
||||
assert(t, ((methodFlags(t, method) & ACC_STATIC) == 0) xor (this_ == 0));
|
||||
|
||||
if (UNLIKELY(t->sp + methodParameterFootprint(t, method) + 1
|
||||
> Thread::StackSizeInWords / 2))
|
||||
{
|
||||
t->exception = makeStackOverflowError(t);
|
||||
return 0;
|
||||
}
|
||||
|
||||
const char* spec = reinterpret_cast<char*>
|
||||
(&byteArrayBody(t, methodSpec(t, method), 0));
|
||||
pushArguments(t, this_, spec, indirectObjects, arguments);
|
||||
|
||||
return ::invoke(t, method);
|
||||
}
|
||||
|
||||
object
|
||||
MyProcessor::invokeList(vm::Thread* vmt, const char* className,
|
||||
const char* methodName, const char* methodSpec,
|
||||
object this_, va_list arguments)
|
||||
{
|
||||
Thread* t = static_cast<Thread*>(vmt);
|
||||
|
||||
assert(t, t->state == Thread::ActiveState
|
||||
or t->state == Thread::ExclusiveState);
|
||||
|
||||
if (UNLIKELY(t->sp + parameterFootprint(methodSpec) + 1
|
||||
> Thread::StackSizeInWords / 2))
|
||||
{
|
||||
t->exception = makeStackOverflowError(t);
|
||||
return 0;
|
||||
}
|
||||
|
||||
pushArguments(t, this_, methodSpec, false, arguments);
|
||||
|
||||
object method = resolveMethod(t, className, methodName, methodSpec);
|
||||
if (LIKELY(t->exception == 0)) {
|
||||
assert(t, ((methodFlags(t, method) & ACC_STATIC) == 0) xor (this_ == 0));
|
||||
|
||||
if (UNLIKELY(t->sp + methodParameterFootprint(t, method) + 1
|
||||
> Thread::StackSizeInWords / 2))
|
||||
{
|
||||
t->exception = makeStackOverflowError(t);
|
||||
return 0;
|
||||
}
|
||||
|
||||
const char* spec = reinterpret_cast<char*>
|
||||
(&byteArrayBody(t, methodSpec(t, method), 0));
|
||||
pushArguments(t, this_, spec, arguments);
|
||||
|
||||
return ::invoke(t, method);
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
virtual object
|
||||
invokeList(vm::Thread* vmt, object method, object this_,
|
||||
bool indirectObjects,
|
||||
va_list arguments)
|
||||
{
|
||||
Thread* t = static_cast<Thread*>(vmt);
|
||||
|
||||
assert(t, t->state == Thread::ActiveState
|
||||
or t->state == Thread::ExclusiveState);
|
||||
|
||||
assert(t, ((methodFlags(t, method) & ACC_STATIC) == 0) xor (this_ == 0));
|
||||
|
||||
if (UNLIKELY(t->sp + methodParameterFootprint(t, method) + 1
|
||||
> Thread::StackSizeInWords / 2))
|
||||
{
|
||||
t->exception = makeStackOverflowError(t);
|
||||
return 0;
|
||||
}
|
||||
|
||||
const char* spec = reinterpret_cast<char*>
|
||||
(&byteArrayBody(t, methodSpec(t, method), 0));
|
||||
pushArguments(t, this_, spec, indirectObjects, arguments);
|
||||
|
||||
return ::invoke(t, method);
|
||||
}
|
||||
|
||||
virtual object
|
||||
invokeList(vm::Thread* vmt, const char* className, const char* methodName,
|
||||
const char* methodSpec, object this_, va_list arguments)
|
||||
{
|
||||
Thread* t = static_cast<Thread*>(vmt);
|
||||
|
||||
assert(t, t->state == Thread::ActiveState
|
||||
or t->state == Thread::ExclusiveState);
|
||||
|
||||
if (UNLIKELY(t->sp + parameterFootprint(methodSpec) + 1
|
||||
> Thread::StackSizeInWords / 2))
|
||||
{
|
||||
t->exception = makeStackOverflowError(t);
|
||||
return 0;
|
||||
}
|
||||
|
||||
pushArguments(t, this_, methodSpec, false, arguments);
|
||||
|
||||
object method = resolveMethod(t, className, methodName, methodSpec);
|
||||
if (LIKELY(t->exception == 0)) {
|
||||
assert(t, ((methodFlags(t, method) & ACC_STATIC) == 0) xor (this_ == 0));
|
||||
|
||||
return ::invoke(t, method);
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
virtual void dispose() {
|
||||
s->free(this);
|
||||
}
|
||||
|
||||
System* s;
|
||||
};
|
||||
|
||||
} // namespace
|
||||
|
||||
|
@ -2752,21 +2752,28 @@ run(System* system, Heap* heap, Finder* finder, Processor* processor,
|
||||
}
|
||||
|
||||
object
|
||||
makeTrace(Thread* t, FrameIterator* it)
|
||||
makeTrace(Thread* t, uintptr_t start)
|
||||
{
|
||||
Processor* p = t->m->processor;
|
||||
|
||||
unsigned count = 0;
|
||||
FrameIterator copy(it);
|
||||
while (copy.valid()) {
|
||||
for (uintptr_t frame = start;
|
||||
p->frameValid(t, frame);
|
||||
frame = p->frameNext(t, frame))
|
||||
{
|
||||
++ count;
|
||||
t->m->processor->next(t, ©);
|
||||
}
|
||||
|
||||
object trace = makeArray(t, count, true);
|
||||
PROTECT(t, trace);
|
||||
|
||||
unsigned index = 0;
|
||||
while (it->valid()) {
|
||||
object e = makeTraceElement(t, it->method, it->ip);
|
||||
for (uintptr_t frame = start;
|
||||
p->frameValid(t, frame);
|
||||
frame = p->frameNext(t, frame))
|
||||
{
|
||||
object e = makeTraceElement
|
||||
(t, p->frameMethod(t, frame), p->frameIp(t, frame));
|
||||
set(t, arrayBody(t, trace, index++), e);
|
||||
}
|
||||
|
||||
|
@ -1423,13 +1423,12 @@ arrayBodyUnsafe(Thread*, object, unsigned);
|
||||
#include "type-declarations.cpp"
|
||||
|
||||
object
|
||||
makeTrace(Thread* t, FrameIterator* it);
|
||||
makeTrace(Thread* t, uintptr_t start);
|
||||
|
||||
inline object
|
||||
makeTrace(Thread* t)
|
||||
{
|
||||
FrameIterator it; t->m->processor->start(t, &it);
|
||||
return makeTrace(t, &it);
|
||||
return makeTrace(t, t->m->processor->frameStart(t));
|
||||
}
|
||||
|
||||
inline object
|
||||
@ -2054,11 +2053,17 @@ int
|
||||
run(System* system, Heap* heap, Finder* finder, Processor* processor,
|
||||
const char* className, int argc, const char** argv);
|
||||
|
||||
jobject
|
||||
makeLocalReference(Thread* t, object o);
|
||||
inline jobject
|
||||
makeLocalReference(Thread* t, object o)
|
||||
{
|
||||
return t->m->processor->makeLocalReference(t, o);
|
||||
}
|
||||
|
||||
void
|
||||
disposeLocalReference(Thread* t, jobject r);
|
||||
inline void
|
||||
disposeLocalReference(Thread* t, jobject r)
|
||||
{
|
||||
t->m->processor->disposeLocalReference(t, r);
|
||||
}
|
||||
|
||||
} // namespace vm
|
||||
|
||||
|
@ -7,29 +7,6 @@
|
||||
|
||||
namespace vm {
|
||||
|
||||
class FrameIterator {
|
||||
public:
|
||||
FrameIterator():
|
||||
base(0),
|
||||
method(0),
|
||||
ip(0)
|
||||
{ }
|
||||
|
||||
FrameIterator(FrameIterator* it):
|
||||
base(it->base),
|
||||
method(it->method),
|
||||
ip(it->ip)
|
||||
{ }
|
||||
|
||||
bool valid() {
|
||||
return base != 0;
|
||||
}
|
||||
|
||||
uintptr_t base;
|
||||
object method;
|
||||
unsigned ip;
|
||||
};
|
||||
|
||||
class Processor {
|
||||
public:
|
||||
virtual ~Processor() { }
|
||||
@ -40,11 +17,26 @@ class Processor {
|
||||
virtual void
|
||||
visitObjects(Thread* t, Heap::Visitor* v) = 0;
|
||||
|
||||
virtual void
|
||||
start(Thread* t, FrameIterator* it) = 0;
|
||||
virtual uintptr_t
|
||||
frameStart(Thread* t) = 0;
|
||||
|
||||
virtual uintptr_t
|
||||
frameNext(Thread* t, uintptr_t frame) = 0;
|
||||
|
||||
virtual bool
|
||||
frameValid(Thread* t, uintptr_t frame) = 0;
|
||||
|
||||
virtual object
|
||||
frameMethod(Thread* t, uintptr_t frame) = 0;
|
||||
|
||||
virtual unsigned
|
||||
frameIp(Thread* t, uintptr_t frame) = 0;
|
||||
|
||||
virtual object*
|
||||
makeLocalReference(Thread* t, object o) = 0;
|
||||
|
||||
virtual void
|
||||
next(Thread* t, FrameIterator* it) = 0;
|
||||
disposeLocalReference(Thread* t, object* r) = 0;
|
||||
|
||||
virtual object
|
||||
invokeArray(Thread* t, object method, object this_, object arguments) = 0;
|
||||
|
@ -17,28 +17,28 @@
|
||||
obj:/lib/ld-2.3.6.so
|
||||
}
|
||||
|
||||
{
|
||||
<insert a suppression name here>
|
||||
Memcheck:Param
|
||||
write(buf)
|
||||
obj:*
|
||||
}
|
||||
# {
|
||||
# <insert a suppression name here>
|
||||
# Memcheck:Param
|
||||
# write(buf)
|
||||
# obj:*
|
||||
# }
|
||||
|
||||
{
|
||||
<insert a suppression name here>
|
||||
Memcheck:Param
|
||||
writev(vector[...])
|
||||
obj:*
|
||||
}
|
||||
# {
|
||||
# <insert a suppression name here>
|
||||
# Memcheck:Param
|
||||
# writev(vector[...])
|
||||
# obj:*
|
||||
# }
|
||||
|
||||
{
|
||||
<insert a suppression name here>
|
||||
Memcheck:Cond
|
||||
obj:*
|
||||
}
|
||||
# {
|
||||
# <insert a suppression name here>
|
||||
# Memcheck:Cond
|
||||
# obj:*
|
||||
# }
|
||||
|
||||
{
|
||||
<insert a suppression name here>
|
||||
Memcheck:Value8
|
||||
obj:*
|
||||
}
|
||||
# {
|
||||
# <insert a suppression name here>
|
||||
# Memcheck:Value8
|
||||
# obj:*
|
||||
# }
|
||||
|
Loading…
Reference in New Issue
Block a user