| 
									
										
										
										
											2014-05-09 22:11:18 -04:00
										 |  |  | // Copyright 2014 Citra Emulator Project / PPSSPP Project
 | 
					
						
							| 
									
										
										
										
											2014-12-16 21:38:14 -08:00
										 |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							| 
									
										
										
										
											2014-11-19 08:49:13 +00:00
										 |  |  | // Refer to the license.txt file included.
 | 
					
						
							| 
									
										
										
										
											2014-05-09 22:11:18 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-22 04:32:03 -02:00
										 |  |  | #include <string>
 | 
					
						
							| 
									
										
										
										
											2016-12-03 22:38:14 -05:00
										 |  |  | #include <unordered_map>
 | 
					
						
							| 
									
										
										
										
											2014-12-22 04:32:03 -02:00
										 |  |  | #include <vector>
 | 
					
						
							| 
									
										
										
										
											2016-12-08 10:34:53 -05:00
										 |  |  | #include <boost/container/flat_map.hpp>
 | 
					
						
							| 
									
										
										
										
											2015-01-31 19:22:40 -02:00
										 |  |  | #include <boost/container/flat_set.hpp>
 | 
					
						
							| 
									
										
										
										
											2014-05-09 22:11:18 -04:00
										 |  |  | #include "common/common_types.h"
 | 
					
						
							| 
									
										
										
										
											2016-12-22 00:08:09 -05:00
										 |  |  | #include "core/arm/arm_interface.h"
 | 
					
						
							| 
									
										
										
										
											2014-12-22 04:32:03 -02:00
										 |  |  | #include "core/core.h"
 | 
					
						
							| 
									
										
										
										
											2014-05-13 22:29:31 -04:00
										 |  |  | #include "core/hle/kernel/kernel.h"
 | 
					
						
							| 
									
										
										
										
											2014-10-23 01:20:01 -02:00
										 |  |  | #include "core/hle/result.h"
 | 
					
						
							| 
									
										
										
										
											2014-05-09 22:11:18 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  | enum ThreadPriority : s32 { | 
					
						
							|  |  |  |     THREADPRIO_HIGHEST = 0,       ///< Highest thread priority
 | 
					
						
							|  |  |  |     THREADPRIO_USERLAND_MAX = 24, ///< Highest thread priority for userland apps
 | 
					
						
							|  |  |  |     THREADPRIO_DEFAULT = 48,      ///< Default thread priority for userland apps
 | 
					
						
							|  |  |  |     THREADPRIO_LOWEST = 63,       ///< Lowest thread priority
 | 
					
						
							| 
									
										
										
										
											2014-05-17 00:56:00 -04:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-23 23:55:21 -04:00
										 |  |  | enum ThreadProcessorId : s32 { | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     THREADPROCESSORID_DEFAULT = -2, ///< Run thread on default core specified by exheader
 | 
					
						
							|  |  |  |     THREADPROCESSORID_ALL = -1,     ///< Run thread on either core
 | 
					
						
							|  |  |  |     THREADPROCESSORID_0 = 0,        ///< Run thread on core 0 (AppCore)
 | 
					
						
							|  |  |  |     THREADPROCESSORID_1 = 1,        ///< Run thread on core 1 (SysCore)
 | 
					
						
							|  |  |  |     THREADPROCESSORID_MAX = 2,      ///< Processor ID must be less than this
 | 
					
						
							| 
									
										
										
										
											2014-05-17 00:56:00 -04:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-22 18:50:36 -04:00
										 |  |  | enum ThreadStatus { | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     THREADSTATUS_RUNNING,    ///< Currently running
 | 
					
						
							|  |  |  |     THREADSTATUS_READY,      ///< Ready to run
 | 
					
						
							|  |  |  |     THREADSTATUS_WAIT_ARB,   ///< Waiting on an address arbiter
 | 
					
						
							|  |  |  |     THREADSTATUS_WAIT_SLEEP, ///< Waiting due to a SleepThread SVC
 | 
					
						
							|  |  |  |     THREADSTATUS_WAIT_SYNCH, ///< Waiting due to a WaitSynchronization SVC
 | 
					
						
							|  |  |  |     THREADSTATUS_DORMANT,    ///< Created but not yet made ready
 | 
					
						
							|  |  |  |     THREADSTATUS_DEAD        ///< Run to completion, or forcefully terminated
 | 
					
						
							| 
									
										
										
										
											2014-05-22 18:50:36 -04:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-20 19:37:46 -04:00
										 |  |  | namespace Kernel { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-31 19:22:40 -02:00
										 |  |  | class Mutex; | 
					
						
							| 
									
										
										
										
											2015-05-11 09:15:10 -05:00
										 |  |  | class Process; | 
					
						
							| 
									
										
										
										
											2015-01-31 19:22:40 -02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-27 02:40:21 -02:00
										 |  |  | class Thread final : public WaitObject { | 
					
						
							| 
									
										
										
										
											2014-12-22 04:32:03 -02:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2015-01-25 22:56:17 -08:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Creates and returns a new thread. The new thread is immediately scheduled | 
					
						
							|  |  |  |      * @param name The friendly name desired for the thread | 
					
						
							|  |  |  |      * @param entry_point The address at which the thread should start execution | 
					
						
							|  |  |  |      * @param priority The thread's priority | 
					
						
							|  |  |  |      * @param arg User data to pass to the thread | 
					
						
							|  |  |  |      * @param processor_id The ID(s) of the processors on which the thread is desired to be run | 
					
						
							|  |  |  |      * @param stack_top The address of the thread's stack top | 
					
						
							|  |  |  |      * @return A shared pointer to the newly created thread | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2014-12-29 10:55:30 -02:00
										 |  |  |     static ResultVal<SharedPtr<Thread>> Create(std::string name, VAddr entry_point, s32 priority, | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |                                                u32 arg, s32 processor_id, VAddr stack_top); | 
					
						
							| 
									
										
										
										
											2014-12-22 11:07:22 -02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     std::string GetName() const override { | 
					
						
							|  |  |  |         return name; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     std::string GetTypeName() const override { | 
					
						
							|  |  |  |         return "Thread"; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-12-22 04:32:03 -02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     static const HandleType HANDLE_TYPE = HandleType::Thread; | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     HandleType GetHandleType() const override { | 
					
						
							|  |  |  |         return HANDLE_TYPE; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-12-22 04:32:03 -02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-01 16:53:22 -05:00
										 |  |  |     bool ShouldWait(Thread* thread) const override; | 
					
						
							|  |  |  |     void Acquire(Thread* thread) override; | 
					
						
							| 
									
										
										
										
											2014-12-22 04:32:03 -02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-25 22:56:17 -08:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Gets the thread's current priority | 
					
						
							|  |  |  |      * @return The current thread's priority | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     s32 GetPriority() const { | 
					
						
							|  |  |  |         return current_priority; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-01-25 22:56:17 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Sets the thread's current priority | 
					
						
							|  |  |  |      * @param priority The new priority | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2014-12-22 11:07:22 -02:00
										 |  |  |     void SetPriority(s32 priority); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-03 18:40:16 -04:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Temporarily boosts the thread's priority until the next time it is scheduled | 
					
						
							|  |  |  |      * @param priority The new priority | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     void BoostPriority(s32 priority); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-25 22:56:17 -08:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Gets the thread's thread ID | 
					
						
							|  |  |  |      * @return The thread's ID | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     u32 GetThreadId() const { | 
					
						
							|  |  |  |         return thread_id; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-05-25 20:34:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-25 22:56:17 -08:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Resumes a thread from waiting | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2014-12-22 11:07:22 -02:00
										 |  |  |     void ResumeFromWait(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-30 23:07:54 -02:00
										 |  |  |     /**
 | 
					
						
							| 
									
										
										
										
											2015-01-25 22:56:17 -08:00
										 |  |  |     * Schedules an event to wake up the specified thread after the specified delay | 
					
						
							|  |  |  |     * @param nanoseconds The time this thread will be allowed to sleep for | 
					
						
							| 
									
										
										
										
											2015-01-30 23:07:54 -02:00
										 |  |  |     */ | 
					
						
							|  |  |  |     void WakeAfterDelay(s64 nanoseconds); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-17 02:03:44 -05:00
										 |  |  |     /**
 | 
					
						
							| 
									
										
										
										
											2015-01-20 20:53:52 -05:00
										 |  |  |      * Sets the result after the thread awakens (from either WaitSynchronization SVC) | 
					
						
							|  |  |  |      * @param result Value to set to the returned result | 
					
						
							| 
									
										
										
										
											2015-01-17 02:03:44 -05:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-01-20 20:53:52 -05:00
										 |  |  |     void SetWaitSynchronizationResult(ResultCode result); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Sets the output parameter value after the thread awakens (from WaitSynchronizationN SVC only) | 
					
						
							|  |  |  |      * @param output Value to set to the output parameter | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     void SetWaitSynchronizationOutput(s32 output); | 
					
						
							| 
									
										
										
										
											2015-01-17 02:03:44 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-03 22:38:14 -05:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Retrieves the index that this particular object occupies in the list of objects | 
					
						
							|  |  |  |      * that the thread passed to WaitSynchronizationN. | 
					
						
							|  |  |  |      * It is used to set the output value of WaitSynchronizationN when the thread is awakened. | 
					
						
							|  |  |  |      * @param object Object to query the index of. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-12-04 09:58:36 -05:00
										 |  |  |     s32 GetWaitObjectIndex(const WaitObject* object) const { | 
					
						
							|  |  |  |         return wait_objects_index.at(object->GetObjectId()); | 
					
						
							| 
									
										
										
										
											2016-12-03 22:38:14 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-25 22:56:17 -08:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Stops a thread, invalidating it from further use | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     void Stop(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-10 18:35:37 -05:00
										 |  |  |     /*
 | 
					
						
							|  |  |  |      * Returns the Thread Local Storage address of the current thread | 
					
						
							|  |  |  |      * @returns VAddr of the thread's TLS | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     VAddr GetTLSAddress() const { | 
					
						
							|  |  |  |         return tls_address; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-05-10 18:35:37 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-04 09:58:36 -05:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Returns whether this thread is waiting for all the objects in | 
					
						
							|  |  |  |      * its wait list to become ready, as a result of a WaitSynchronizationN call | 
					
						
							|  |  |  |      * with wait_all = true, or a ReplyAndReceive call. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-12-08 10:34:53 -05:00
										 |  |  |     bool IsSleepingOnWaitAll() const { | 
					
						
							| 
									
										
										
										
											2016-12-04 09:58:36 -05:00
										 |  |  |         return !wait_objects.empty(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-22 00:08:09 -05:00
										 |  |  |     ARM_Interface::ThreadContext context; | 
					
						
							| 
									
										
										
										
											2014-12-22 04:32:03 -02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     u32 thread_id; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     u32 status; | 
					
						
							|  |  |  |     u32 entry_point; | 
					
						
							|  |  |  |     u32 stack_top; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     s32 nominal_priority; ///< Nominal thread priority, as set by the emulated application
 | 
					
						
							|  |  |  |     s32 current_priority; ///< Current thread priority, can be temporarily changed
 | 
					
						
							| 
									
										
										
										
											2015-03-23 23:55:21 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     u64 last_running_ticks; ///< CPU tick when thread was last running
 | 
					
						
							| 
									
										
										
										
											2014-12-22 04:32:03 -02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     s32 processor_id; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-19 17:12:48 -05:00
										 |  |  |     VAddr tls_address; ///< Virtual address of the Thread Local Storage of the thread
 | 
					
						
							| 
									
										
										
										
											2015-05-10 18:43:59 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-31 19:22:40 -02:00
										 |  |  |     /// Mutexes currently held by this thread, which will be released when it exits.
 | 
					
						
							|  |  |  |     boost::container::flat_set<SharedPtr<Mutex>> held_mutexes; | 
					
						
							| 
									
										
										
										
											2015-01-18 13:25:51 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-14 12:13:02 -05:00
										 |  |  |     SharedPtr<Process> owner_process; ///< Process that owns this thread
 | 
					
						
							| 
									
										
										
										
											2016-12-04 09:58:36 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Objects that the thread is waiting on.
 | 
					
						
							|  |  |  |     /// This is only populated when the thread should wait for all the objects to become ready.
 | 
					
						
							|  |  |  |     std::vector<SharedPtr<WaitObject>> wait_objects; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-14 12:13:02 -05:00
										 |  |  |     /// Mapping of Object ids to their position in the last waitlist that this object waited on.
 | 
					
						
							|  |  |  |     boost::container::flat_map<int, s32> wait_objects_index; | 
					
						
							| 
									
										
										
										
											2016-12-03 22:38:14 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-14 12:13:02 -05:00
										 |  |  |     VAddr wait_address; ///< If waiting on an AddressArbiter, this is the arbitration address
 | 
					
						
							| 
									
										
										
										
											2016-12-03 22:38:14 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-14 12:13:02 -05:00
										 |  |  |     /// True if the WaitSynchronizationN output parameter should be set on thread wakeup.
 | 
					
						
							|  |  |  |     bool wait_set_output; | 
					
						
							| 
									
										
										
										
											2014-12-22 04:32:03 -02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     std::string name; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-07 23:39:37 -04:00
										 |  |  |     /// Handle used as userdata to reference this object when inserting into the CoreTiming queue.
 | 
					
						
							|  |  |  |     Handle callback_handle; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-22 04:32:03 -02:00
										 |  |  | private: | 
					
						
							| 
									
										
										
										
											2015-01-31 19:22:40 -02:00
										 |  |  |     Thread(); | 
					
						
							| 
									
										
										
										
											2015-01-31 22:56:59 -02:00
										 |  |  |     ~Thread() override; | 
					
						
							| 
									
										
										
										
											2014-12-22 04:32:03 -02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-25 22:56:17 -08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Sets up the primary application thread | 
					
						
							|  |  |  |  * @param entry_point The address at which the thread should start execution | 
					
						
							|  |  |  |  * @param priority The priority to give the main thread | 
					
						
							|  |  |  |  * @return A shared pointer to the main thread | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2015-05-11 05:08:47 -03:00
										 |  |  | SharedPtr<Thread> SetupMainThread(u32 entry_point, s32 priority); | 
					
						
							| 
									
										
										
										
											2014-05-13 22:00:11 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-25 22:56:17 -08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Reschedules to the next available thread (call after current thread is suspended) | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-05-22 19:32:45 -04:00
										 |  |  | void Reschedule(); | 
					
						
							| 
									
										
										
										
											2014-05-19 22:19:48 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-25 22:56:17 -08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Arbitrate the highest priority thread that is waiting | 
					
						
							|  |  |  |  * @param address The address for which waiting threads should be arbitrated | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2015-01-18 13:56:40 -05:00
										 |  |  | Thread* ArbitrateHighestPriorityThread(u32 address); | 
					
						
							| 
									
										
										
										
											2014-07-06 22:48:19 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-25 22:56:17 -08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Arbitrate all threads currently waiting. | 
					
						
							|  |  |  |  * @param address The address for which waiting threads should be arbitrated | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2015-01-18 13:56:40 -05:00
										 |  |  | void ArbitrateAllThreads(u32 address); | 
					
						
							| 
									
										
										
										
											2014-07-06 22:48:19 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-25 22:56:17 -08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Gets the current thread | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-12-22 04:32:03 -02:00
										 |  |  | Thread* GetCurrentThread(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-25 22:56:17 -08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Waits the current thread on a sleep | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2015-01-18 13:56:40 -05:00
										 |  |  | void WaitCurrentThread_Sleep(); | 
					
						
							| 
									
										
										
										
											2014-06-05 22:35:36 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-07 16:40:08 -05:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2015-01-17 02:03:44 -05:00
										 |  |  |  * Waits the current thread from a WaitSynchronization call | 
					
						
							| 
									
										
										
										
											2015-01-25 22:56:17 -08:00
										 |  |  |  * @param wait_objects Kernel objects that we are waiting on | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |  * @param wait_set_output If true, set the output parameter on thread wakeup (for | 
					
						
							|  |  |  |  * WaitSynchronizationN only) | 
					
						
							| 
									
										
										
										
											2015-01-07 16:40:08 -05:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  | void WaitCurrentThread_WaitSynchronization(std::vector<SharedPtr<WaitObject>> wait_objects, | 
					
						
							| 
									
										
										
										
											2016-12-03 22:38:14 -05:00
										 |  |  |                                            bool wait_set_output); | 
					
						
							| 
									
										
										
										
											2015-01-07 16:40:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-03 00:46:34 -05:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2015-01-17 02:03:44 -05:00
										 |  |  |  * Waits the current thread from an ArbitrateAddress call | 
					
						
							| 
									
										
										
										
											2014-12-03 00:46:34 -05:00
										 |  |  |  * @param wait_address Arbitration address used to resume from wait | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2015-01-18 13:56:40 -05:00
										 |  |  | void WaitCurrentThread_ArbitrateAddress(VAddr wait_address); | 
					
						
							| 
									
										
										
										
											2014-05-20 19:37:46 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-17 13:08:38 +02:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Stops the current thread and removes it from the thread_list | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void ExitCurrentThread(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-25 22:56:17 -08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Initialize threading | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-05-20 19:37:46 -04:00
										 |  |  | void ThreadingInit(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-25 22:56:17 -08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Shutdown threading | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-05-20 19:37:46 -04:00
										 |  |  | void ThreadingShutdown(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-08 19:28:54 +03:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get a const reference to the thread list for debug use | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | const std::vector<SharedPtr<Thread>>& GetThreadList(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-20 19:37:46 -04:00
										 |  |  | } // namespace
 |