mirror of
				https://github.com/luanti-org/luanti.git
				synced 2025-10-25 13:45:23 +02:00 
			
		
		
		
	Thread: fix a crash on Windows due to data race condition on Thread::m_start_finished_mutex (#6515)
This commit is contained in:
		| @@ -103,8 +103,8 @@ Thread::~Thread() | ||||
| 	kill(); | ||||
| 
 | ||||
| 	// Make sure start finished mutex is unlocked before it's destroyed
 | ||||
| 	m_start_finished_mutex.try_lock(); | ||||
| 	m_start_finished_mutex.unlock(); | ||||
| 	if (m_start_finished_mutex.try_lock()) | ||||
| 		m_start_finished_mutex.unlock(); | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| @@ -267,6 +267,10 @@ DWORD WINAPI Thread::threadProc(LPVOID param) | ||||
| 	thr->m_retval = thr->run(); | ||||
| 
 | ||||
| 	thr->m_running = false; | ||||
| 	// Unlock m_start_finished_mutex to prevent data race condition on Windows.
 | ||||
| 	// On Windows with VS2017 build TerminateThread is called and this mutex is not
 | ||||
| 	// released. We try to unlock it from caller thread and it's refused by system.
 | ||||
| 	thr->m_start_finished_mutex.unlock(); | ||||
| 	g_logger.deregisterThread(); | ||||
| 
 | ||||
| 	// 0 is returned here to avoid an unnecessary ifdef clause
 | ||||
|   | ||||
		Reference in New Issue
	
	Block a user