mirror of
https://github.com/corda/corda.git
synced 2025-01-07 13:38:47 +00:00
fix use of uninitialized values at root thread creation time when running in stress mode; allocate Thread::defaultHeap on the heap instead of as part of the Thread structure
This commit is contained in:
parent
5c99edd90e
commit
659555b6ce
@ -4096,12 +4096,14 @@ class MyProcessor: public Processor {
|
|||||||
{
|
{
|
||||||
MyThread* t = static_cast<MyThread*>(vmt);
|
MyThread* t = static_cast<MyThread*>(vmt);
|
||||||
|
|
||||||
|
if (t->m->active) {
|
||||||
for (Reference* r = t->reference; r; r = r->next) {
|
for (Reference* r = t->reference; r; r = r->next) {
|
||||||
v->visit(&(r->target));
|
v->visit(&(r->target));
|
||||||
}
|
}
|
||||||
|
|
||||||
visitStack(t, v);
|
visitStack(t, v);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
virtual uintptr_t
|
virtual uintptr_t
|
||||||
frameStart(Thread* vmt)
|
frameStart(Thread* vmt)
|
||||||
|
@ -1336,6 +1336,7 @@ Machine::Machine(System* system, Heap* heap, Finder* finder,
|
|||||||
weakReferences(0),
|
weakReferences(0),
|
||||||
tenuredWeakReferences(0),
|
tenuredWeakReferences(0),
|
||||||
unsafe(false),
|
unsafe(false),
|
||||||
|
active(false),
|
||||||
heapPoolIndex(0)
|
heapPoolIndex(0)
|
||||||
{
|
{
|
||||||
populateJNITables(&javaVMVTable, &jniEnvVTable);
|
populateJNITables(&javaVMVTable, &jniEnvVTable);
|
||||||
@ -1386,12 +1387,12 @@ Thread::Thread(Machine* m, object javaThread, Thread* parent):
|
|||||||
heapIndex(0),
|
heapIndex(0),
|
||||||
heapOffset(0),
|
heapOffset(0),
|
||||||
protector(0),
|
protector(0),
|
||||||
runnable(this)
|
runnable(this),
|
||||||
|
defaultHeap(static_cast<uintptr_t*>(m->system->allocate(HeapSizeInBytes))),
|
||||||
|
heap(defaultHeap)
|
||||||
#ifdef VM_STRESS
|
#ifdef VM_STRESS
|
||||||
, stress(false),
|
, stress(false)
|
||||||
defaultHeap(static_cast<uintptr_t*>(m->system->allocate(HeapSizeInBytes)))
|
|
||||||
#endif // VM_STRESS
|
#endif // VM_STRESS
|
||||||
, heap(defaultHeap)
|
|
||||||
{
|
{
|
||||||
if (parent == 0) {
|
if (parent == 0) {
|
||||||
assert(this, m->rootThread == 0);
|
assert(this, m->rootThread == 0);
|
||||||
@ -1399,6 +1400,7 @@ Thread::Thread(Machine* m, object javaThread, Thread* parent):
|
|||||||
|
|
||||||
m->rootThread = this;
|
m->rootThread = this;
|
||||||
m->unsafe = true;
|
m->unsafe = true;
|
||||||
|
m->active = false;
|
||||||
|
|
||||||
if (not m->system->success(m->system->attach(&runnable))) {
|
if (not m->system->success(m->system->attach(&runnable))) {
|
||||||
abort(this);
|
abort(this);
|
||||||
@ -1494,6 +1496,7 @@ Thread::Thread(Machine* m, object javaThread, Thread* parent):
|
|||||||
|
|
||||||
if (parent == 0) {
|
if (parent == 0) {
|
||||||
enter(this, Thread::IdleState);
|
enter(this, Thread::IdleState);
|
||||||
|
m->active = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1098,6 +1098,12 @@ class Machine {
|
|||||||
#include "type-enums.cpp"
|
#include "type-enums.cpp"
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum State {
|
||||||
|
UnsafeState,
|
||||||
|
BootState,
|
||||||
|
ActiveState
|
||||||
|
};
|
||||||
|
|
||||||
Machine(System* system, Heap* heap, Finder* finder, Processor* processor);
|
Machine(System* system, Heap* heap, Finder* finder, Processor* processor);
|
||||||
|
|
||||||
~Machine() {
|
~Machine() {
|
||||||
@ -1136,6 +1142,7 @@ class Machine {
|
|||||||
object weakReferences;
|
object weakReferences;
|
||||||
object tenuredWeakReferences;
|
object tenuredWeakReferences;
|
||||||
bool unsafe;
|
bool unsafe;
|
||||||
|
bool active;
|
||||||
JavaVMVTable javaVMVTable;
|
JavaVMVTable javaVMVTable;
|
||||||
JNIEnvVTable jniEnvVTable;
|
JNIEnvVTable jniEnvVTable;
|
||||||
uintptr_t* heapPool[HeapPoolSize];
|
uintptr_t* heapPool[HeapPoolSize];
|
||||||
@ -1242,14 +1249,11 @@ class Thread {
|
|||||||
unsigned heapOffset;
|
unsigned heapOffset;
|
||||||
Protector* protector;
|
Protector* protector;
|
||||||
Runnable runnable;
|
Runnable runnable;
|
||||||
#ifdef VM_STRESS
|
|
||||||
bool stress;
|
|
||||||
uintptr_t* defaultHeap;
|
uintptr_t* defaultHeap;
|
||||||
uintptr_t* heap;
|
uintptr_t* heap;
|
||||||
#else // not VM_STRESS
|
#ifdef VM_STRESS
|
||||||
uintptr_t* heap;
|
bool stress;
|
||||||
uintptr_t defaultHeap[HeapSizeInWords];
|
#endif // VM_STRESS
|
||||||
#endif // not VM_STRESS
|
|
||||||
};
|
};
|
||||||
|
|
||||||
inline object
|
inline object
|
||||||
|
Loading…
Reference in New Issue
Block a user