shutdown: Stop threads before resetting ptrs
This commit is contained in:
parent
1ef57a96b8
commit
faab63111d
1 changed files with 7 additions and 5 deletions
12
src/init.cpp
12
src/init.cpp
|
@ -209,11 +209,7 @@ void Shutdown()
|
|||
// using the other before destroying them.
|
||||
if (peerLogic) UnregisterValidationInterface(peerLogic.get());
|
||||
if (g_connman) g_connman->Stop();
|
||||
peerLogic.reset();
|
||||
g_connman.reset();
|
||||
if (g_txindex) {
|
||||
g_txindex.reset();
|
||||
}
|
||||
if (g_txindex) g_txindex->Stop();
|
||||
|
||||
StopTorControl();
|
||||
|
||||
|
@ -222,6 +218,12 @@ void Shutdown()
|
|||
threadGroup.interrupt_all();
|
||||
threadGroup.join_all();
|
||||
|
||||
// After the threads that potentially access these pointers have been stopped,
|
||||
// destruct and reset all to nullptr.
|
||||
peerLogic.reset();
|
||||
g_connman.reset();
|
||||
g_txindex.reset();
|
||||
|
||||
if (g_is_mempool_loaded && gArgs.GetArg("-persistmempool", DEFAULT_PERSIST_MEMPOOL)) {
|
||||
DumpMempool();
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue