mirror of
https://github.com/corda/corda.git
synced 2025-01-03 19:54:13 +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)
|
||||
{
|
||||
if (t->dynamicTable == nullptr) {
|
||||
t->dynamicTable = dynamicTable(t);
|
||||
}
|
||||
|
||||
ACQUIRE(t, t->m->classLock);
|
||||
|
||||
int index = invocation->index();
|
||||
@ -8828,6 +8824,7 @@ class MyProcessor : public Processor {
|
||||
t->heapImage = heapImage;
|
||||
t->codeImage = codeImage;
|
||||
t->thunkTable = thunkTable;
|
||||
t->dynamicTable = local::dynamicTable(t);
|
||||
|
||||
#if TARGET_BYTES_PER_WORD == BYTES_PER_WORD
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user