2014-01-20 01:19:37 +04:00
|
|
|
#pragma once
|
|
|
|
|
|
2016-04-14 01:23:53 +03:00
|
|
|
#include "sys_sync.h"
|
2015-06-19 18:49:38 +03:00
|
|
|
|
2014-01-31 03:40:05 +04:00
|
|
|
struct sys_lwmutex_attribute_t
|
|
|
|
|
{
|
2014-09-19 04:19:22 +04:00
|
|
|
be_t<u32> protocol;
|
|
|
|
|
be_t<u32> recursive;
|
2017-02-03 02:16:09 +03:00
|
|
|
|
|
|
|
|
union
|
|
|
|
|
{
|
|
|
|
|
char name[8];
|
|
|
|
|
u64 name_u64;
|
|
|
|
|
};
|
2014-02-09 15:11:48 +04:00
|
|
|
};
|
|
|
|
|
|
2015-03-09 00:56:45 +03:00
|
|
|
enum : u32
|
|
|
|
|
{
|
2015-06-24 14:53:47 +03:00
|
|
|
lwmutex_free = 0xffffffffu,
|
|
|
|
|
lwmutex_dead = 0xfffffffeu,
|
|
|
|
|
lwmutex_reserved = 0xfffffffdu,
|
2015-03-09 00:56:45 +03:00
|
|
|
};
|
|
|
|
|
|
2014-01-20 01:19:37 +04:00
|
|
|
struct sys_lwmutex_t
|
|
|
|
|
{
|
2016-04-14 01:23:53 +03:00
|
|
|
struct alignas(8) sync_var_t
|
2015-03-09 00:56:45 +03:00
|
|
|
{
|
|
|
|
|
be_t<u32> owner;
|
|
|
|
|
be_t<u32> waiter;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
union
|
|
|
|
|
{
|
2015-09-18 01:41:14 +03:00
|
|
|
atomic_t<sync_var_t> lock_var;
|
2015-03-09 00:56:45 +03:00
|
|
|
|
|
|
|
|
struct
|
|
|
|
|
{
|
2015-05-27 06:11:59 +03:00
|
|
|
atomic_be_t<u32> owner;
|
|
|
|
|
atomic_be_t<u32> waiter;
|
2015-06-24 14:53:47 +03:00
|
|
|
}
|
|
|
|
|
vars;
|
2015-03-09 04:30:34 +03:00
|
|
|
|
2015-05-27 06:11:59 +03:00
|
|
|
atomic_be_t<u64> all_info;
|
2015-03-09 00:56:45 +03:00
|
|
|
};
|
|
|
|
|
|
2014-01-20 01:19:37 +04:00
|
|
|
be_t<u32> attribute;
|
2015-03-09 00:56:45 +03:00
|
|
|
be_t<u32> recursive_count;
|
|
|
|
|
be_t<u32> sleep_queue; // lwmutex pseudo-id
|
2014-01-20 01:19:37 +04:00
|
|
|
be_t<u32> pad;
|
2015-03-09 00:56:45 +03:00
|
|
|
};
|
2014-01-31 03:40:05 +04:00
|
|
|
|
2017-01-29 19:50:18 +03:00
|
|
|
struct lv2_lwmutex final : lv2_obj
|
2015-03-09 00:56:45 +03:00
|
|
|
{
|
2017-01-25 20:50:30 +03:00
|
|
|
static const u32 id_base = 0x95000000;
|
|
|
|
|
|
2015-03-09 00:56:45 +03:00
|
|
|
const u32 protocol;
|
2017-02-03 02:16:09 +03:00
|
|
|
const vm::ps3::ptr<sys_lwmutex_t> control;
|
2015-03-09 00:56:45 +03:00
|
|
|
const u64 name;
|
2014-09-19 04:19:22 +04:00
|
|
|
|
2017-02-03 02:16:09 +03:00
|
|
|
semaphore<> mutex;
|
|
|
|
|
atomic_t<u32> signaled{0};
|
|
|
|
|
std::deque<cpu_thread*> sq;
|
2015-03-09 04:30:34 +03:00
|
|
|
|
2017-02-03 02:16:09 +03:00
|
|
|
lv2_lwmutex(u32 protocol, vm::ps3::ptr<sys_lwmutex_t> control, u64 name)
|
2015-03-09 00:56:45 +03:00
|
|
|
: protocol(protocol)
|
2017-02-03 02:16:09 +03:00
|
|
|
, control(control)
|
2015-03-09 00:56:45 +03:00
|
|
|
, name(name)
|
|
|
|
|
{
|
2015-03-11 00:47:13 +03:00
|
|
|
}
|
2014-02-23 17:52:52 +01:00
|
|
|
};
|
2014-06-25 00:38:34 +02:00
|
|
|
|
2015-07-21 19:35:55 +03:00
|
|
|
// Aux
|
2016-07-28 00:43:22 +03:00
|
|
|
class ppu_thread;
|
2015-07-21 19:35:55 +03:00
|
|
|
|
2017-02-03 02:16:09 +03:00
|
|
|
// Syscalls
|
|
|
|
|
|
|
|
|
|
error_code _sys_lwmutex_create(vm::ps3::ptr<u32> lwmutex_id, u32 protocol, vm::ps3::ptr<sys_lwmutex_t> control, u32 arg4, u64 name, u32 arg6);
|
|
|
|
|
error_code _sys_lwmutex_destroy(u32 lwmutex_id);
|
|
|
|
|
error_code _sys_lwmutex_lock(ppu_thread& ppu, u32 lwmutex_id, u64 timeout);
|
|
|
|
|
error_code _sys_lwmutex_trylock(u32 lwmutex_id);
|
2017-02-06 21:36:46 +03:00
|
|
|
error_code _sys_lwmutex_unlock(ppu_thread& ppu, u32 lwmutex_id);
|