mirror of
https://github.com/corda/corda.git
synced 2025-01-22 12:28:11 +00:00
initialize MyThread::dynamicTable on thread creation
Previously, I was lazily initializing this field in addDynamic, but that only worked if a thread compiles an invokedynamic expression prior to the first time it executes one, which is not always the case. This is a bit tricky to write a simple test case for, since it involves multiple threads, but I've tested it with a big, lambda-heavy app and it fixes an otherwise consistent crash there.
This commit is contained in:
parent
bfc71e3a1e
commit
2c05d1515e
@ -1311,10 +1311,6 @@ Allocator* allocator(MyThread* t);
|
|||||||
|
|
||||||
unsigned addDynamic(MyThread* t, GcInvocation* invocation)
|
unsigned addDynamic(MyThread* t, GcInvocation* invocation)
|
||||||
{
|
{
|
||||||
if (t->dynamicTable == nullptr) {
|
|
||||||
t->dynamicTable = dynamicTable(t);
|
|
||||||
}
|
|
||||||
|
|
||||||
ACQUIRE(t, t->m->classLock);
|
ACQUIRE(t, t->m->classLock);
|
||||||
|
|
||||||
int index = invocation->index();
|
int index = invocation->index();
|
||||||
@ -8828,6 +8824,7 @@ class MyProcessor : public Processor {
|
|||||||
t->heapImage = heapImage;
|
t->heapImage = heapImage;
|
||||||
t->codeImage = codeImage;
|
t->codeImage = codeImage;
|
||||||
t->thunkTable = thunkTable;
|
t->thunkTable = thunkTable;
|
||||||
|
t->dynamicTable = local::dynamicTable(t);
|
||||||
|
|
||||||
#if TARGET_BYTES_PER_WORD == BYTES_PER_WORD
|
#if TARGET_BYTES_PER_WORD == BYTES_PER_WORD
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user