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
|
|
|
|
|
{
|
|
|
|
|
lwmutex_zero = 0u,
|
|
|
|
|
lwmutex_free = 0u - 1u,
|
|
|
|
|
lwmutex_dead = 0u - 2u,
|
|
|
|
|
lwmutex_busy = 0u - 3u,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
namespace lwmutex
|
|
|
|
|
{
|
|
|
|
|
template<u32 _value>
|
|
|
|
|
struct const_be_u32_t
|
|
|
|
|
{
|
|
|
|
|
static const u32 value = _value;
|
|
|
|
|
|
|
|
|
|
operator const be_t<u32>() const
|
|
|
|
|
{
|
|
|
|
|
return be_t<u32>::make(value);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
static const_be_u32_t<lwmutex_zero> zero;
|
|
|
|
|
static const_be_u32_t<lwmutex_free> free;
|
|
|
|
|
static const_be_u32_t<lwmutex_dead> dead;
|
|
|
|
|
static const_be_u32_t<lwmutex_busy> busy;
|
|
|
|
|
}
|
|
|
|
|
|
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;
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
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-08 22:56:45 +01:00
|
|
|
lwmutex_t(u32 protocol, u64 name)
|
|
|
|
|
: protocol(protocol)
|
|
|
|
|
, name(name)
|
|
|
|
|
{
|
|
|
|
|
}
|
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);
|
|
|
|
|
s32 _sys_lwmutex_destroy(PPUThread& CPU, u32 lwmutex_id);
|
|
|
|
|
s32 _sys_lwmutex_lock(PPUThread& CPU, u32 lwmutex_id, u64 timeout);
|
|
|
|
|
s32 _sys_lwmutex_trylock(PPUThread& CPU, u32 lwmutex_id);
|
|
|
|
|
s32 _sys_lwmutex_unlock(PPUThread& CPU, u32 lwmutex_id);
|