forked from eden-emu/eden
		
	kernel: fix incorrect locking order in suspension
This commit is contained in:
		
							parent
							
								
									d2838b3568
								
							
						
					
					
						commit
						31945a6e8b
					
				
					 3 changed files with 26 additions and 34 deletions
				
			
		|  | @ -763,19 +763,6 @@ void KThread::Continue() { | |||
|     KScheduler::OnThreadStateChanged(kernel, this, old_state); | ||||
| } | ||||
| 
 | ||||
| void KThread::WaitUntilSuspended() { | ||||
|     // Make sure we have a suspend requested.
 | ||||
|     ASSERT(IsSuspendRequested()); | ||||
| 
 | ||||
|     // Loop until the thread is not executing on any core.
 | ||||
|     for (std::size_t i = 0; i < static_cast<std::size_t>(Core::Hardware::NUM_CPU_CORES); ++i) { | ||||
|         KThread* core_thread{}; | ||||
|         do { | ||||
|             core_thread = kernel.Scheduler(i).GetSchedulerCurrentThread(); | ||||
|         } while (core_thread == this); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| Result KThread::SetActivity(Svc::ThreadActivity activity) { | ||||
|     // Lock ourselves.
 | ||||
|     KScopedLightLock lk(activity_pause_lock); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Liam
						Liam