| 
									
										
										
										
											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 | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-02-01 00:14:40 -02:00
										 |  |  |     static SharedPtr<Mutex> Create(bool initial_locked, std::string name = "Unknown"); | 
					
						
							| 
									
										
										
										
											2015-01-22 23:12:19 -02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     std::string GetTypeName() const override { | 
					
						
							|  |  |  |         return "Mutex"; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     std::string GetName() const override { | 
					
						
							|  |  |  |         return name; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-01-22 23:12:19 -02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     static const HandleType HANDLE_TYPE = HandleType::Mutex; | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     HandleType GetHandleType() const override { | 
					
						
							|  |  |  |         return HANDLE_TYPE; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-01-22 23:12:19 -02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     int lock_count;                   ///< Number of times the mutex has been acquired
 | 
					
						
							| 
									
										
										
										
											2017-01-01 16:59:30 -05:00
										 |  |  |     u32 priority;                     ///< The priority of the mutex, used for priority inheritance.
 | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     std::string name;                 ///< Name of mutex (optional)
 | 
					
						
							|  |  |  |     SharedPtr<Thread> holding_thread; ///< Thread that has acquired the mutex
 | 
					
						
							| 
									
										
										
										
											2015-01-22 23:12:19 -02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-02 19:38:08 -05:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Elevate the mutex priority to the best priority | 
					
						
							|  |  |  |      * among the priorities of all its waiting threads. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     void UpdatePriority(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-01 16:53:22 -05:00
										 |  |  |     bool ShouldWait(Thread* thread) const override; | 
					
						
							|  |  |  |     void Acquire(Thread* thread) override; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-01 16:59:30 -05:00
										 |  |  |     void AddWaitingThread(SharedPtr<Thread> thread) override; | 
					
						
							| 
									
										
										
										
											2017-01-02 13:53:10 -05:00
										 |  |  |     void RemoveWaitingThread(Thread* thread) override; | 
					
						
							| 
									
										
										
										
											2015-01-22 23:12:19 -02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     void Release(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							| 
									
										
										
										
											2015-01-31 22:56:59 -02:00
										 |  |  |     Mutex(); | 
					
						
							|  |  |  |     ~Mutex() override; | 
					
						
							| 
									
										
										
										
											2015-01-22 23:12:19 -02:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											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
 |