| 
									
										
										
										
											2014-05-20 23:03:45 -04:00
										 |  |  | // Copyright 2014 Citra Emulator 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-20 23:03:45 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-22 23:12:19 -02:00
										 |  |  | #include <string>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-20 23:03:45 -04:00
										 |  |  | #include "common/common_types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "core/hle/kernel/kernel.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Kernel { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-22 23:12:19 -02:00
										 |  |  | class Thread; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-27 02:40:21 -02:00
										 |  |  | class Mutex final : public WaitObject { | 
					
						
							| 
									
										
										
										
											2015-01-22 23:12:19 -02:00
										 |  |  | public: | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Creates a mutex. | 
					
						
							|  |  |  |      * @param initial_locked Specifies if the mutex should be locked initially | 
					
						
							|  |  |  |      * @param name Optional name of mutex | 
					
						
							|  |  |  |      * @return Pointer to new Mutex object | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     static ResultVal<SharedPtr<Mutex>> Create(bool initial_locked, std::string name = "Unknown"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     std::string GetTypeName() const override { return "Mutex"; } | 
					
						
							|  |  |  |     std::string GetName() const override { return name; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static const HandleType HANDLE_TYPE = HandleType::Mutex; | 
					
						
							|  |  |  |     HandleType GetHandleType() const override { return HANDLE_TYPE; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     bool initial_locked;                        ///< Initial lock state when mutex was created
 | 
					
						
							|  |  |  |     bool locked;                                ///< Current locked state
 | 
					
						
							|  |  |  |     std::string name;                           ///< Name of mutex (optional)
 | 
					
						
							|  |  |  |     SharedPtr<Thread> holding_thread;           ///< Thread that has acquired the mutex
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     bool ShouldWait() override; | 
					
						
							|  |  |  |     void Acquire() override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |     * Acquires the specified mutex for the specified thread | 
					
						
							|  |  |  |     * @param mutex Mutex that is to be acquired | 
					
						
							|  |  |  |     * @param thread Thread that will acquire the mutex | 
					
						
							|  |  |  |     */ | 
					
						
							|  |  |  |     void Acquire(Thread* thread); | 
					
						
							|  |  |  |     void Release(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     Mutex() = default; | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2014-05-20 23:03:45 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-07 15:44:21 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Releases all the mutexes held by the specified thread | 
					
						
							|  |  |  |  * @param thread Thread that is holding the mutexes | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2015-01-20 18:33:23 -05:00
										 |  |  | void ReleaseThreadMutexes(Thread* thread); | 
					
						
							| 
									
										
										
										
											2014-12-07 15:44:21 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-20 23:03:45 -04:00
										 |  |  | } // namespace
 |