#pragma once struct sys_mutex_attribute { be_t protocol; // SYS_SYNC_FIFO, SYS_SYNC_PRIORITY or SYS_SYNC_PRIORITY_INHERIT be_t recursive; // SYS_SYNC_RECURSIVE or SYS_SYNC_NOT_RECURSIVE be_t pshared; // always 0x200 (not shared) be_t adaptive; be_t ipc_key; be_t flags; be_t pad; union { char name[8]; u64 name_u64; }; }; struct Mutex { atomic_le_t id; atomic_le_t owner; std::atomic recursive_count; // recursive locks count std::atomic cond_count; // count of condition variables associated sleep_queue_t queue; const u32 protocol; const bool is_recursive; Mutex(u32 protocol, bool is_recursive, u64 name) : protocol(protocol) , is_recursive(is_recursive) , queue(name) , cond_count(0) { owner.write_relaxed(0); } ~Mutex(); }; class PPUThread; // SysCalls s32 sys_mutex_create(PPUThread& CPU, vm::ptr mutex_id, vm::ptr attr); s32 sys_mutex_destroy(PPUThread& CPU, u32 mutex_id); s32 sys_mutex_lock(PPUThread& CPU, u32 mutex_id, u64 timeout); s32 sys_mutex_trylock(PPUThread& CPU, u32 mutex_id); s32 sys_mutex_unlock(PPUThread& CPU, u32 mutex_id);