rpcsx/rpcs3/Emu/SysCalls/lv2/sys_lwmutex.h

99 lines
1.8 KiB
C
Raw Normal View History

2014-01-19 22:19:37 +01:00
#pragma once
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
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_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
{
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;
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;
};
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
};
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
// 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;
// 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-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-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;
// 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(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);