forked from eden-emu/eden
		
	Merge pull request #2967 from Subv/thread_wakeup_callbacks
Kernel/Threads: When putting a thread to wait, specify a function to execute when it is awoken
This commit is contained in:
		
						commit
						2e30398e7a
					
				
					 4 changed files with 91 additions and 17 deletions
				
			
		|  | @ -41,6 +41,11 @@ enum ThreadStatus { | |||
|     THREADSTATUS_DEAD            ///< Run to completion, or forcefully terminated
 | ||||
| }; | ||||
| 
 | ||||
| enum class ThreadWakeupReason { | ||||
|     Signal, // The thread was woken up by WakeupAllWaitingThreads due to an object signal.
 | ||||
|     Timeout // The thread was woken up due to a wait timeout.
 | ||||
| }; | ||||
| 
 | ||||
| namespace Kernel { | ||||
| 
 | ||||
| class Mutex; | ||||
|  | @ -199,14 +204,18 @@ public: | |||
| 
 | ||||
|     VAddr wait_address; ///< If waiting on an AddressArbiter, this is the arbitration address
 | ||||
| 
 | ||||
|     /// True if the WaitSynchronizationN output parameter should be set on thread wakeup.
 | ||||
|     bool wait_set_output; | ||||
| 
 | ||||
|     std::string name; | ||||
| 
 | ||||
|     /// Handle used as userdata to reference this object when inserting into the CoreTiming queue.
 | ||||
|     Handle callback_handle; | ||||
| 
 | ||||
|     using WakeupCallback = void(ThreadWakeupReason reason, SharedPtr<Thread> thread, | ||||
|                                 SharedPtr<WaitObject> object); | ||||
|     // Callback that will be invoked when the thread is resumed from a waiting state. If the thread
 | ||||
|     // was waiting via WaitSynchronizationN then the object will be the last object that became
 | ||||
|     // available. In case of a timeout, the object will be nullptr.
 | ||||
|     std::function<WakeupCallback> wakeup_callback; | ||||
| 
 | ||||
| private: | ||||
|     Thread(); | ||||
|     ~Thread() override; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Sebastian Valle
						Sebastian Valle