diff options
author | Lioncash <mathew1800@gmail.com> | 2019-03-14 05:29:54 +0100 |
---|---|---|
committer | Lioncash <mathew1800@gmail.com> | 2019-03-15 01:55:52 +0100 |
commit | 555cd26ec2b848634370a14d41b7e79b6c6beecd (patch) | |
tree | 4ec6b8245280f94b44969356c9f2a44b22abd00e /src/core/hle/kernel/mutex.h | |
parent | Merge pull request #2230 from lioncash/global (diff) | |
download | yuzu-555cd26ec2b848634370a14d41b7e79b6c6beecd.tar yuzu-555cd26ec2b848634370a14d41b7e79b6c6beecd.tar.gz yuzu-555cd26ec2b848634370a14d41b7e79b6c6beecd.tar.bz2 yuzu-555cd26ec2b848634370a14d41b7e79b6c6beecd.tar.lz yuzu-555cd26ec2b848634370a14d41b7e79b6c6beecd.tar.xz yuzu-555cd26ec2b848634370a14d41b7e79b6c6beecd.tar.zst yuzu-555cd26ec2b848634370a14d41b7e79b6c6beecd.zip |
Diffstat (limited to 'src/core/hle/kernel/mutex.h')
-rw-r--r-- | src/core/hle/kernel/mutex.h | 20 |
1 files changed, 11 insertions, 9 deletions
diff --git a/src/core/hle/kernel/mutex.h b/src/core/hle/kernel/mutex.h index 81e62d497..b904de2e8 100644 --- a/src/core/hle/kernel/mutex.h +++ b/src/core/hle/kernel/mutex.h @@ -5,32 +5,34 @@ #pragma once #include "common/common_types.h" -#include "core/hle/kernel/object.h" union ResultCode; -namespace Kernel { +namespace Core { +class System; +} -class HandleTable; -class Thread; +namespace Kernel { class Mutex final { public: + explicit Mutex(Core::System& system); + ~Mutex(); + /// Flag that indicates that a mutex still has threads waiting for it. static constexpr u32 MutexHasWaitersFlag = 0x40000000; /// Mask of the bits in a mutex address value that contain the mutex owner. static constexpr u32 MutexOwnerMask = 0xBFFFFFFF; /// Attempts to acquire a mutex at the specified address. - static ResultCode TryAcquire(HandleTable& handle_table, VAddr address, - Handle holding_thread_handle, Handle requesting_thread_handle); + ResultCode TryAcquire(VAddr address, Handle holding_thread_handle, + Handle requesting_thread_handle); /// Releases the mutex at the specified address. - static ResultCode Release(VAddr address); + ResultCode Release(VAddr address); private: - Mutex() = default; - ~Mutex() = default; + Core::System& system; }; } // namespace Kernel |