mirror of
https://github.com/corda/corda.git
synced 2025-01-01 02:36:44 +00:00
implement makeJString(); minor tweaks elsewhere
This commit is contained in:
parent
48e49f1fa1
commit
94338e15a8
13
src/class_finder.h
Normal file
13
src/class_finder.h
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
#ifndef CLASS_FINDER_H
|
||||||
|
#define CLASS_FINDER_H
|
||||||
|
|
||||||
|
#include "common.h"
|
||||||
|
|
||||||
|
class ClassFinder {
|
||||||
|
public:
|
||||||
|
virtual ~ClassFinder() { }
|
||||||
|
virtual const uint8_t* find(const char* className) = 0;
|
||||||
|
virtual void free(const uint8_t* class_) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif//CLASS_FINDER_H
|
@ -2,6 +2,9 @@
|
|||||||
#define COMMON_H
|
#define COMMON_H
|
||||||
|
|
||||||
#include "stdint.h"
|
#include "stdint.h"
|
||||||
|
#include "stdarg.h"
|
||||||
|
#include "string.h"
|
||||||
|
#include "stdio.h"
|
||||||
|
|
||||||
#define NO_RETURN __attribute__((noreturn))
|
#define NO_RETURN __attribute__((noreturn))
|
||||||
#define UNLIKELY(v) __builtin_expect(v, 0)
|
#define UNLIKELY(v) __builtin_expect(v, 0)
|
||||||
|
@ -63,9 +63,7 @@ class System {
|
|||||||
|
|
||||||
virtual bool success(Status) = 0;
|
virtual bool success(Status) = 0;
|
||||||
virtual void* allocate(unsigned size) = 0;
|
virtual void* allocate(unsigned size) = 0;
|
||||||
virtual void zero(void*, unsigned size) = 0;
|
|
||||||
virtual void free(void*) = 0;
|
virtual void free(void*) = 0;
|
||||||
virtual void copy(void* src, void* dst, unsigned size);
|
|
||||||
virtual Status start(Thread*) = 0;
|
virtual Status start(Thread*) = 0;
|
||||||
virtual Status make(Monitor**) = 0;
|
virtual Status make(Monitor**) = 0;
|
||||||
virtual Status open(File**, const char* path, int flags, int mode) = 0;
|
virtual Status open(File**, const char* path, int flags, int mode) = 0;
|
||||||
|
@ -49,8 +49,6 @@
|
|||||||
(object spec))
|
(object spec))
|
||||||
|
|
||||||
(type string
|
(type string
|
||||||
(uint32_t hash)
|
|
||||||
(uint32_t id)
|
|
||||||
(array char value))
|
(array char value))
|
||||||
|
|
||||||
(type byte
|
(type byte
|
||||||
|
80
src/vm.cpp
80
src/vm.cpp
@ -2,6 +2,10 @@
|
|||||||
#include "system.h"
|
#include "system.h"
|
||||||
#include "heap.h"
|
#include "heap.h"
|
||||||
|
|
||||||
|
#define PROTECTED(thread, name, value) \
|
||||||
|
Protector MAKE_NAME(protector_) (thread, value); \
|
||||||
|
object& name(thread->stack[thread->sp - 1]);
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
typedef void* object;
|
typedef void* object;
|
||||||
@ -36,6 +40,7 @@ class Machine {
|
|||||||
unsigned activeCount;
|
unsigned activeCount;
|
||||||
unsigned liveCount;
|
unsigned liveCount;
|
||||||
System::Monitor* stateLock;
|
System::Monitor* stateLock;
|
||||||
|
object jstringClass;
|
||||||
};
|
};
|
||||||
|
|
||||||
class Thread {
|
class Thread {
|
||||||
@ -80,7 +85,7 @@ assert(Thread* t, bool v)
|
|||||||
void
|
void
|
||||||
init(Machine* m, System* sys, Heap* heap)
|
init(Machine* m, System* sys, Heap* heap)
|
||||||
{
|
{
|
||||||
sys->zero(m, sizeof(Machine));
|
memset(m, 0, sizeof(Machine));
|
||||||
m->sys = sys;
|
m->sys = sys;
|
||||||
m->heap = heap;
|
m->heap = heap;
|
||||||
if (not sys->success(sys->make(&(m->stateLock)))) {
|
if (not sys->success(sys->make(&(m->stateLock)))) {
|
||||||
@ -97,7 +102,7 @@ dispose(Machine* m)
|
|||||||
void
|
void
|
||||||
init(Thread* t, Machine* m)
|
init(Thread* t, Machine* m)
|
||||||
{
|
{
|
||||||
m->sys->zero(m, sizeof(Thread));
|
memset(m, 0, sizeof(Thread));
|
||||||
t->vm = m;
|
t->vm = m;
|
||||||
m->rootThread = t;
|
m->rootThread = t;
|
||||||
t->state = Thread::NoState;
|
t->state = Thread::NoState;
|
||||||
@ -290,6 +295,60 @@ pop(Thread* t)
|
|||||||
return t->stack[--(t->sp)];
|
return t->stack[--(t->sp)];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class Protector {
|
||||||
|
public:
|
||||||
|
Protector(Thread* t, object value): t(t) {
|
||||||
|
if (t->sp >= Thread::StackSize) abort(t);
|
||||||
|
push(t, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
~Protector() {
|
||||||
|
pop(t);
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
Thread* t;
|
||||||
|
};
|
||||||
|
|
||||||
|
inline object
|
||||||
|
make(Thread* t, object class_)
|
||||||
|
{
|
||||||
|
unsigned size = classFixedSize(t, class_);
|
||||||
|
object instance = allocate(t, size);
|
||||||
|
*static_cast<object*>(instance) = class_;
|
||||||
|
memset(static_cast<object*>(instance) + sizeof(object), 0,
|
||||||
|
size - sizeof(object));
|
||||||
|
return instance;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class T>
|
||||||
|
inline T&
|
||||||
|
cast(object p, unsigned offset)
|
||||||
|
{
|
||||||
|
return *reinterpret_cast<T*>(static_cast<uint8_t*>(p) + offset);
|
||||||
|
}
|
||||||
|
|
||||||
|
object
|
||||||
|
makeJString(Thread* t, const char* format, ...)
|
||||||
|
{
|
||||||
|
static const unsigned Size = 256;
|
||||||
|
char buffer[Size];
|
||||||
|
|
||||||
|
va_list a;
|
||||||
|
va_start(a, format);
|
||||||
|
vsnprintf(buffer, Size - 1, format, a);
|
||||||
|
va_end(a);
|
||||||
|
|
||||||
|
PROTECTED(t, s, makeString(t, strlen(buffer) + 1));
|
||||||
|
memcpy(stringValue(t, s), buffer, stringLength(t, s));
|
||||||
|
|
||||||
|
object r = make(t, t->vm->jstringClass);
|
||||||
|
cast<object>(r, sizeof(void*)) = s;
|
||||||
|
cast<int32_t>(r, sizeof(void*) * 2) = 0;
|
||||||
|
cast<int32_t>(r, (sizeof(void*) * 2) + sizeof(int32_t)) = stringLength(t, s);
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
object
|
object
|
||||||
run(Thread* t)
|
run(Thread* t)
|
||||||
{
|
{
|
||||||
@ -386,7 +445,7 @@ run(Thread* t)
|
|||||||
if (t->exception) goto throw_;
|
if (t->exception) goto throw_;
|
||||||
|
|
||||||
object array = makeObjectArray(t, class_, c);
|
object array = makeObjectArray(t, class_, c);
|
||||||
t->vm->sys->zero(objectArrayBody(t, array), c * 4);
|
memset(objectArrayBody(t, array), 0, c * 4);
|
||||||
|
|
||||||
push(t, array);
|
push(t, array);
|
||||||
} else {
|
} else {
|
||||||
@ -418,8 +477,7 @@ run(Thread* t)
|
|||||||
push(t, makeInt(t, objectArrayLength(t, array)));
|
push(t, makeInt(t, objectArrayLength(t, array)));
|
||||||
} else {
|
} else {
|
||||||
// for all other array types, the length follow the class pointer.
|
// for all other array types, the length follow the class pointer.
|
||||||
push(t, makeInt(t, reinterpret_cast<uint32_t&>
|
push(t, makeInt(t, cast<uint32_t>(array, sizeof(void*))));
|
||||||
(static_cast<uintptr_t*>(array)[1])));
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
t->exception = makeNullPointerException(t, 0);
|
t->exception = makeNullPointerException(t, 0);
|
||||||
@ -1379,13 +1437,7 @@ run(Thread* t)
|
|||||||
goto invoke;
|
goto invoke;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned size = instanceSize(class_);
|
push(t, make(t, class_));
|
||||||
object instance = allocate(t, size);
|
|
||||||
*static_cast<object*>(instance) = class_;
|
|
||||||
t->vm->sys->zero(static_cast<object*>(instance) + sizeof(object),
|
|
||||||
size - sizeof(object));
|
|
||||||
|
|
||||||
push(t, instance);
|
|
||||||
} goto loop;
|
} goto loop;
|
||||||
|
|
||||||
case newarray: {
|
case newarray: {
|
||||||
@ -1442,7 +1494,7 @@ run(Thread* t)
|
|||||||
default: abort(t);
|
default: abort(t);
|
||||||
}
|
}
|
||||||
|
|
||||||
t->vm->sys->zero(static_cast<object*>(instance) + (sizeof(object) * 2),
|
memset(static_cast<object*>(instance) + (sizeof(object) * 2), 0
|
||||||
c * factor);
|
c * factor);
|
||||||
|
|
||||||
push(t, array);
|
push(t, array);
|
||||||
@ -1637,7 +1689,7 @@ run(Thread* t)
|
|||||||
t->sp -= parameterCount;
|
t->sp -= parameterCount;
|
||||||
t->frame = makeFrame(t, t->code, t->frame, 0, t->sp,
|
t->frame = makeFrame(t, t->code, t->frame, 0, t->sp,
|
||||||
codeMaxLocals(t, methodCode(t, t->code)));
|
codeMaxLocals(t, methodCode(t, t->code)));
|
||||||
t->vm->sys->copy(t->stack + t->sp, frameLocals(t, t->frame), parameterCount);
|
memcpy(frameLocals(t, t->frame), t->stack + t->sp, parameterCount);
|
||||||
ip = 0;
|
ip = 0;
|
||||||
goto loop;
|
goto loop;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user