forked from eden-emu/eden
		
	k_thread: Use a mutex and cond_var to sync bool
std::atomic<bool> is broken on MinGW and causes deadlocks there. Use a normal cond var in its stead.
This commit is contained in:
		
							parent
							
								
									4c7987cded
								
							
						
					
					
						commit
						59236a458c
					
				
					 2 changed files with 14 additions and 5 deletions
				
			
		|  | @ -4,6 +4,8 @@ | ||||||
| #include <algorithm> | #include <algorithm> | ||||||
| #include <atomic> | #include <atomic> | ||||||
| #include <cinttypes> | #include <cinttypes> | ||||||
|  | #include <condition_variable> | ||||||
|  | #include <mutex> | ||||||
| #include <optional> | #include <optional> | ||||||
| #include <vector> | #include <vector> | ||||||
| 
 | 
 | ||||||
|  | @ -1313,7 +1315,8 @@ void KThread::RequestDummyThreadWait() { | ||||||
|     ASSERT(this->IsDummyThread()); |     ASSERT(this->IsDummyThread()); | ||||||
| 
 | 
 | ||||||
|     // We will block when the scheduler lock is released.
 |     // We will block when the scheduler lock is released.
 | ||||||
|     m_dummy_thread_runnable.store(false); |     std::scoped_lock lock{m_dummy_thread_mutex}; | ||||||
|  |     m_dummy_thread_runnable = false; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void KThread::DummyThreadBeginWait() { | void KThread::DummyThreadBeginWait() { | ||||||
|  | @ -1323,7 +1326,8 @@ void KThread::DummyThreadBeginWait() { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // Block until runnable is no longer false.
 |     // Block until runnable is no longer false.
 | ||||||
|     m_dummy_thread_runnable.wait(false); |     std::unique_lock lock{m_dummy_thread_mutex}; | ||||||
|  |     m_dummy_thread_cv.wait(lock, [this] { return m_dummy_thread_runnable; }); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void KThread::DummyThreadEndWait() { | void KThread::DummyThreadEndWait() { | ||||||
|  | @ -1331,8 +1335,11 @@ void KThread::DummyThreadEndWait() { | ||||||
|     ASSERT(this->IsDummyThread()); |     ASSERT(this->IsDummyThread()); | ||||||
| 
 | 
 | ||||||
|     // Wake up the waiting thread.
 |     // Wake up the waiting thread.
 | ||||||
|     m_dummy_thread_runnable.store(true); |     { | ||||||
|     m_dummy_thread_runnable.notify_one(); |         std::scoped_lock lock{m_dummy_thread_mutex}; | ||||||
|  |         m_dummy_thread_runnable = true; | ||||||
|  |     } | ||||||
|  |     m_dummy_thread_cv.notify_one(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void KThread::BeginWait(KThreadQueue* queue) { | void KThread::BeginWait(KThreadQueue* queue) { | ||||||
|  |  | ||||||
|  | @ -892,7 +892,9 @@ private: | ||||||
|     std::shared_ptr<Common::Fiber> m_host_context{}; |     std::shared_ptr<Common::Fiber> m_host_context{}; | ||||||
|     ThreadType m_thread_type{}; |     ThreadType m_thread_type{}; | ||||||
|     StepState m_step_state{}; |     StepState m_step_state{}; | ||||||
|     std::atomic<bool> m_dummy_thread_runnable{true}; |     bool m_dummy_thread_runnable{true}; | ||||||
|  |     std::mutex m_dummy_thread_mutex{}; | ||||||
|  |     std::condition_variable m_dummy_thread_cv{}; | ||||||
| 
 | 
 | ||||||
|     // For debugging
 |     // For debugging
 | ||||||
|     std::vector<KSynchronizationObject*> m_wait_objects_for_debugging{}; |     std::vector<KSynchronizationObject*> m_wait_objects_for_debugging{}; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 lat9nq
						lat9nq