2013-06-30 10:46:29 +02:00
|
|
|
#pragma once
|
|
|
|
|
|
2016-04-14 00:23:53 +02:00
|
|
|
#include "sys_sync.h"
|
2015-06-19 17:49:38 +02:00
|
|
|
|
2015-03-06 23:10:04 +01:00
|
|
|
struct sys_mutex_attribute_t
|
2013-06-30 10:46:29 +02:00
|
|
|
{
|
2014-02-14 12:40:41 +01:00
|
|
|
be_t<u32> protocol; // SYS_SYNC_FIFO, SYS_SYNC_PRIORITY or SYS_SYNC_PRIORITY_INHERIT
|
|
|
|
|
be_t<u32> recursive; // SYS_SYNC_RECURSIVE or SYS_SYNC_NOT_RECURSIVE
|
2015-03-06 23:10:04 +01:00
|
|
|
be_t<u32> pshared;
|
2014-02-14 12:40:41 +01:00
|
|
|
be_t<u32> adaptive;
|
|
|
|
|
be_t<u64> ipc_key;
|
2014-12-28 14:15:22 +01:00
|
|
|
be_t<s32> flags;
|
2014-02-14 12:40:41 +01:00
|
|
|
be_t<u32> pad;
|
2015-03-06 23:10:04 +01:00
|
|
|
|
2014-02-14 12:40:41 +01:00
|
|
|
union
|
|
|
|
|
{
|
|
|
|
|
char name[8];
|
|
|
|
|
u64 name_u64;
|
|
|
|
|
};
|
2013-06-30 10:46:29 +02:00
|
|
|
};
|
|
|
|
|
|
2017-01-29 17:50:18 +01:00
|
|
|
struct lv2_mutex final : lv2_obj
|
2013-06-30 10:46:29 +02:00
|
|
|
{
|
2017-01-25 18:50:30 +01:00
|
|
|
static const u32 id_base = 0x85000000;
|
|
|
|
|
|
2015-03-06 23:10:04 +01:00
|
|
|
const bool recursive;
|
|
|
|
|
const u32 protocol;
|
|
|
|
|
const u64 name;
|
|
|
|
|
|
2016-04-14 00:23:53 +02:00
|
|
|
atomic_t<u32> cond_count{ 0 }; // count of condition variables associated
|
|
|
|
|
atomic_t<u32> recursive_count{ 0 }; // count of recursive locks
|
|
|
|
|
std::shared_ptr<cpu_thread> owner; // current mutex owner
|
2014-02-14 12:40:41 +01:00
|
|
|
|
2016-04-14 00:23:53 +02:00
|
|
|
sleep_queue<cpu_thread> sq;
|
2013-06-30 10:46:29 +02:00
|
|
|
|
2017-01-29 17:50:18 +01:00
|
|
|
lv2_mutex(bool recursive, u32 protocol, u64 name)
|
2015-03-06 23:10:04 +01:00
|
|
|
: recursive(recursive)
|
|
|
|
|
, protocol(protocol)
|
|
|
|
|
, name(name)
|
2013-06-30 10:46:29 +02:00
|
|
|
{
|
|
|
|
|
}
|
2015-07-08 17:01:59 +02:00
|
|
|
|
2016-04-14 00:23:53 +02:00
|
|
|
void unlock(lv2_lock_t);
|
2014-04-10 00:54:32 +02:00
|
|
|
};
|
2014-06-25 00:38:34 +02:00
|
|
|
|
2016-07-27 23:43:22 +02:00
|
|
|
class ppu_thread;
|
2014-12-23 00:31:11 +01:00
|
|
|
|
2014-06-25 00:38:34 +02:00
|
|
|
// SysCalls
|
2016-08-19 23:14:10 +02:00
|
|
|
s32 sys_mutex_create(vm::ps3::ptr<u32> mutex_id, vm::ps3::ptr<sys_mutex_attribute_t> attr);
|
2015-03-06 23:10:04 +01:00
|
|
|
s32 sys_mutex_destroy(u32 mutex_id);
|
2016-07-27 23:43:22 +02:00
|
|
|
s32 sys_mutex_lock(ppu_thread& ppu, u32 mutex_id, u64 timeout);
|
|
|
|
|
s32 sys_mutex_trylock(ppu_thread& ppu, u32 mutex_id);
|
|
|
|
|
s32 sys_mutex_unlock(ppu_thread& ppu, u32 mutex_id);
|