@ -37,6 +37,10 @@ void Thread::Acquire() {
 
		
	
		
			
				    ASSERT_MSG ( ! ShouldWait ( ) ,  " object unavailable! " ) ; 
 
		
	
		
			
				}  
		
	
		
			
				
 
		
	
		
			
				// TODO(yuriks): This can be removed if Thread objects are explicitly pooled in the future, allowing
  
		
	
		
			
				//               us to simply use a pool index or similar.
  
		
	
		
			
				static  Kernel : : HandleTable  wakeup_callback_handle_table ;  
		
	
		
			
				
 
		
	
		
			
				// Lists all thread ids that aren't deleted/etc.
  
		
	
		
			
				static  std : : vector < SharedPtr < Thread > >  thread_list ;  
		
	
		
			
				
 
		
	
	
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
				
			
			@ -93,6 +97,8 @@ void Thread::Stop() {
 
		
	
		
			
				
 
		
	
		
			
				    // Cancel any outstanding wakeup events for this thread
 
 
		
	
		
			
				    CoreTiming : : UnscheduleEvent ( ThreadWakeupEventType ,  callback_handle ) ; 
 
		
	
		
			
				    wakeup_callback_handle_table . Close ( callback_handle ) ; 
 
		
	
		
			
				    callback_handle  =  0 ; 
 
		
	
		
			
				
 
		
	
		
			
				    // Clean up thread from ready queue
 
 
		
	
		
			
				    // This is only needed when the thread is termintated forcefully (SVC TerminateProcess)
 
 
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
			
			@ -108,6 +114,7 @@ void Thread::Stop() {
 
		
	
		
			
				    for  ( auto &  wait_object  :  wait_objects )  { 
 
		
	
		
			
				        wait_object - > RemoveWaitingThread ( this ) ; 
 
		
	
		
			
				    } 
 
		
	
		
			
				    wait_objects . clear ( ) ; 
 
		
	
		
			
				
 
		
	
		
			
				    Kernel : : g_current_process - > used_tls_slots [ tls_index ]  =  false ; 
 
		
	
		
			
				
 
		
	
	
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
				
			
			@ -268,10 +275,6 @@ void WaitCurrentThread_ArbitrateAddress(VAddr wait_address) {
 
		
	
		
			
				    thread - > status  =  THREADSTATUS_WAIT_ARB ; 
 
		
	
		
			
				}  
		
	
		
			
				
 
		
	
		
			
				// TODO(yuriks): This can be removed if Thread objects are explicitly pooled in the future, allowing
  
		
	
		
			
				//               us to simply use a pool index or similar.
  
		
	
		
			
				static  Kernel : : HandleTable  wakeup_callback_handle_table ;  
		
	
		
			
				
 
		
	
		
			
				/**
  
		
	
		
			
				 *  Callback  that  will  wake  up  the  thread  it  was  scheduled  for 
 
		
	
		
			
				 *  @ param  thread_handle  The  handle  of  the  thread  that ' s  been  awoken 
 
		
	
	
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
				
			
			@ -503,12 +506,16 @@ void ThreadingInit() {
 
		
	
		
			
				
 
		
	
		
			
				    current_thread  =  nullptr ; 
 
		
	
		
			
				    next_thread_id  =  1 ; 
 
		
	
		
			
				
 
		
	
		
			
				    thread_list . clear ( ) ; 
 
		
	
		
			
				    ready_queue . clear ( ) ; 
 
		
	
		
			
				}  
		
	
		
			
				
 
		
	
		
			
				void  ThreadingShutdown ( )  {  
		
	
		
			
				    current_thread  =  nullptr ; 
 
		
	
		
			
				
 
		
	
		
			
				    for  ( auto &  t  :  thread_list )  { 
 
		
	
		
			
				        t - > Stop ( ) ; 
 
		
	
		
			
				    } 
 
		
	
		
			
				    thread_list . clear ( ) ; 
 
		
	
		
			
				    ready_queue . clear ( ) ; 
 
		
	
		
			
				}  
		
	
		
			
				
 
		
	
		
			
				}  // namespace