2014-01-19 22:19:37 +01:00
|
|
|
#pragma once
|
|
|
|
|
|
2014-01-31 00:40:05 +01:00
|
|
|
struct sys_lwmutex_attribute_t
|
|
|
|
|
{
|
2014-09-19 02:19:22 +02:00
|
|
|
be_t<u32> protocol;
|
|
|
|
|
be_t<u32> recursive;
|
2015-03-08 22:56:45 +01:00
|
|
|
|
2014-02-09 12:11:48 +01:00
|
|
|
union
|
|
|
|
|
{
|
|
|
|
|
char name[8];
|
|
|
|
|
u64 name_u64;
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
2015-03-08 22:56:45 +01:00
|
|
|
enum : u32
|
|
|
|
|
{
|
2015-03-09 02:30:34 +01:00
|
|
|
lwmutex_zero = 0u,
|
|
|
|
|
lwmutex_free = 0u - 1u,
|
|
|
|
|
lwmutex_dead = 0u - 2u,
|
|
|
|
|
lwmutex_reserved = 0u - 3u,
|
2015-03-08 22:56:45 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
namespace lwmutex
|
|
|
|
|
{
|
|
|
|
|
template<u32 _value>
|
|
|
|
|
struct const_be_u32_t
|
|
|
|
|
{
|
|
|
|
|
operator const be_t<u32>() const
|
|
|
|
|
{
|
2015-04-08 22:43:29 +02:00
|
|
|
return be_t<u32>::make(_value);
|
2015-03-08 22:56:45 +01:00
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
static const_be_u32_t<lwmutex_zero> zero;
|
|
|
|
|
static const_be_u32_t<lwmutex_free> free;
|
|
|
|
|
static const_be_u32_t<lwmutex_dead> dead;
|
2015-03-09 02:30:34 +01:00
|
|
|
static const_be_u32_t<lwmutex_reserved> reserved;
|
2015-03-08 22:56:45 +01:00
|
|
|
}
|
|
|
|
|
|
2014-01-19 22:19:37 +01:00
|
|
|
struct sys_lwmutex_t
|
|
|
|
|
{
|
2015-03-08 22:56:45 +01:00
|
|
|
struct sync_var_t
|
|
|
|
|
{
|
|
|
|
|
be_t<u32> owner;
|
|
|
|
|
be_t<u32> waiter;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
union
|
|
|
|
|
{
|
|
|
|
|
atomic_t<sync_var_t> lock_var;
|
|
|
|
|
|
|
|
|
|
struct
|
|
|
|
|
{
|
|
|
|
|
atomic_t<u32> owner;
|
|
|
|
|
atomic_t<u32> waiter;
|
|
|
|
|
};
|
2015-03-09 02:30:34 +01:00
|
|
|
|
|
|
|
|
atomic_t<u64> all_info;
|
2015-03-08 22:56:45 +01:00
|
|
|
};
|
|
|
|
|
|
2014-01-19 22:19:37 +01:00
|
|
|
be_t<u32> attribute;
|
2015-03-08 22:56:45 +01:00
|
|
|
be_t<u32> recursive_count;
|
|
|
|
|
be_t<u32> sleep_queue; // lwmutex pseudo-id
|
2014-01-19 22:19:37 +01:00
|
|
|
be_t<u32> pad;
|
2015-03-08 22:56:45 +01:00
|
|
|
};
|
2014-01-31 00:40:05 +01:00
|
|
|
|
2015-03-08 22:56:45 +01:00
|
|
|
struct lwmutex_t
|
|
|
|
|
{
|
|
|
|
|
const u32 protocol;
|
|
|
|
|
const u64 name;
|
2014-09-19 02:19:22 +02:00
|
|
|
|
2015-03-09 02:30:34 +01:00
|
|
|
// this object is not truly a mutex and its syscall names are wrong, it's probabably sleep queue or something
|
2015-03-09 20:56:55 +01:00
|
|
|
std::atomic<u32> signaled;
|
2015-03-09 02:30:34 +01:00
|
|
|
|
|
|
|
|
// TODO: use sleep queue, possibly remove condition variable
|
|
|
|
|
std::condition_variable cv;
|
2015-03-11 16:30:50 +01:00
|
|
|
std::atomic<u32> waiters;
|
2015-03-09 02:30:34 +01:00
|
|
|
|
2015-03-08 22:56:45 +01:00
|
|
|
lwmutex_t(u32 protocol, u64 name)
|
|
|
|
|
: protocol(protocol)
|
|
|
|
|
, name(name)
|
2015-03-11 11:39:54 +01:00
|
|
|
, signaled(0)
|
|
|
|
|
, waiters(0)
|
2015-03-08 22:56:45 +01:00
|
|
|
{
|
2015-03-10 22:47:13 +01:00
|
|
|
}
|
2014-02-23 17:52:52 +01:00
|
|
|
};
|
2014-06-25 00:38:34 +02:00
|
|
|
|
2014-09-19 02:19:22 +02:00
|
|
|
// Aux
|
2015-03-08 22:56:45 +01:00
|
|
|
void lwmutex_create(sys_lwmutex_t& lwmutex, bool recursive, u32 protocol, u64 name);
|
2014-09-19 02:19:22 +02:00
|
|
|
|
2014-12-23 00:31:11 +01:00
|
|
|
class PPUThread;
|
|
|
|
|
|
2014-06-25 00:38:34 +02:00
|
|
|
// SysCalls
|
2015-03-08 22:56:45 +01:00
|
|
|
s32 _sys_lwmutex_create(vm::ptr<u32> lwmutex_id, u32 protocol, vm::ptr<sys_lwmutex_t> control, u32 arg4, u64 name, u32 arg6);
|
2015-03-09 02:30:34 +01:00
|
|
|
s32 _sys_lwmutex_destroy(u32 lwmutex_id);
|
|
|
|
|
s32 _sys_lwmutex_lock(u32 lwmutex_id, u64 timeout);
|
|
|
|
|
s32 _sys_lwmutex_trylock(u32 lwmutex_id);
|
|
|
|
|
s32 _sys_lwmutex_unlock(u32 lwmutex_id);
|