forked from eden-emu/eden
		
	Mutex: Correct Result writting to clear exclusivity.
This commit is contained in:
		
							parent
							
								
									e4b175ade2
								
							
						
					
					
						commit
						a6bce296ad
					
				
					 1 changed files with 11 additions and 3 deletions
				
			
		|  | @ -9,6 +9,7 @@ | ||||||
| #include "common/assert.h" | #include "common/assert.h" | ||||||
| #include "common/logging/log.h" | #include "common/logging/log.h" | ||||||
| #include "core/core.h" | #include "core/core.h" | ||||||
|  | #include "core/arm/exclusive_monitor.h" | ||||||
| #include "core/hle/kernel/errors.h" | #include "core/hle/kernel/errors.h" | ||||||
| #include "core/hle/kernel/handle_table.h" | #include "core/hle/kernel/handle_table.h" | ||||||
| #include "core/hle/kernel/kernel.h" | #include "core/hle/kernel/kernel.h" | ||||||
|  | @ -133,8 +134,12 @@ std::pair<ResultCode, std::shared_ptr<Thread>> Mutex::Unlock(std::shared_ptr<Thr | ||||||
|      } |      } | ||||||
| 
 | 
 | ||||||
|     auto [new_owner, num_waiters] = GetHighestPriorityMutexWaitingThread(owner, address); |     auto [new_owner, num_waiters] = GetHighestPriorityMutexWaitingThread(owner, address); | ||||||
|  |     auto& monitor = system.Monitor(); | ||||||
|  |     const std::size_t current_core = system.CurrentCoreIndex(); | ||||||
|     if (new_owner == nullptr) { |     if (new_owner == nullptr) { | ||||||
|         system.Memory().Write32(address, 0); |         do { | ||||||
|  |             monitor.SetExclusive(current_core, address); | ||||||
|  |         } while (!monitor.ExclusiveWrite32(current_core, address, 0)); | ||||||
|         return {RESULT_SUCCESS, nullptr}; |         return {RESULT_SUCCESS, nullptr}; | ||||||
|     } |     } | ||||||
|     // Transfer the ownership of the mutex from the previous owner to the new one.
 |     // Transfer the ownership of the mutex from the previous owner to the new one.
 | ||||||
|  | @ -145,9 +150,12 @@ std::pair<ResultCode, std::shared_ptr<Thread>> Mutex::Unlock(std::shared_ptr<Thr | ||||||
|         mutex_value |= Mutex::MutexHasWaitersFlag; |         mutex_value |= Mutex::MutexHasWaitersFlag; | ||||||
|     } |     } | ||||||
|     new_owner->SetSynchronizationResults(nullptr, RESULT_SUCCESS); |     new_owner->SetSynchronizationResults(nullptr, RESULT_SUCCESS); | ||||||
|     new_owner->ResumeFromWait(); |  | ||||||
|     new_owner->SetLockOwner(nullptr); |     new_owner->SetLockOwner(nullptr); | ||||||
|     system.Memory().Write32(address, mutex_value); |     new_owner->ResumeFromWait(); | ||||||
|  | 
 | ||||||
|  |     do { | ||||||
|  |         monitor.SetExclusive(current_core, address); | ||||||
|  |     } while (!monitor.ExclusiveWrite32(current_core, address, mutex_value)); | ||||||
|     return {RESULT_SUCCESS, new_owner}; |     return {RESULT_SUCCESS, new_owner}; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Fernando Sahmkow
						Fernando Sahmkow