Prevent mutex lock fail even if --enable-debug
This PR intends to resolve #15227. "configure --debug-enabled" enables "#ifdef DEBUG_LOCKORDER". Then "lockdata" (in sync.cpp) will be initialized same as other static objects. But unfortunately, lockdata.push_lock() was called before its initialization (via initializing signatureCache which is declared in script/sigcache.cpp) on macOS. This PR apply the "Construct On First Use Idiom" to "lockdata" to prevent it.
This commit is contained in:
parent
94167e2b5b
commit
b09dab0f2d
1 changed files with 7 additions and 1 deletions
|
@ -73,7 +73,11 @@ struct LockData {
|
||||||
LockOrders lockorders;
|
LockOrders lockorders;
|
||||||
InvLockOrders invlockorders;
|
InvLockOrders invlockorders;
|
||||||
std::mutex dd_mutex;
|
std::mutex dd_mutex;
|
||||||
} static lockdata;
|
};
|
||||||
|
LockData& GetLockData() {
|
||||||
|
static LockData lockdata;
|
||||||
|
return lockdata;
|
||||||
|
}
|
||||||
|
|
||||||
static thread_local LockStack g_lockstack;
|
static thread_local LockStack g_lockstack;
|
||||||
|
|
||||||
|
@ -109,6 +113,7 @@ static void potential_deadlock_detected(const std::pair<void*, void*>& mismatch,
|
||||||
|
|
||||||
static void push_lock(void* c, const CLockLocation& locklocation)
|
static void push_lock(void* c, const CLockLocation& locklocation)
|
||||||
{
|
{
|
||||||
|
LockData& lockdata = GetLockData();
|
||||||
std::lock_guard<std::mutex> lock(lockdata.dd_mutex);
|
std::lock_guard<std::mutex> lock(lockdata.dd_mutex);
|
||||||
|
|
||||||
g_lockstack.push_back(std::make_pair(c, locklocation));
|
g_lockstack.push_back(std::make_pair(c, locklocation));
|
||||||
|
@ -173,6 +178,7 @@ void AssertLockNotHeldInternal(const char* pszName, const char* pszFile, int nLi
|
||||||
|
|
||||||
void DeleteLock(void* cs)
|
void DeleteLock(void* cs)
|
||||||
{
|
{
|
||||||
|
LockData& lockdata = GetLockData();
|
||||||
if (!lockdata.available) {
|
if (!lockdata.available) {
|
||||||
// We're already shutting down.
|
// We're already shutting down.
|
||||||
return;
|
return;
|
||||||
|
|
Loading…
Add table
Reference in a new issue