rpcsx/rpcs3/Emu/SysCalls/lv2/sys_rwlock.h
2015-07-10 04:30:41 +03:00

56 lines
1.2 KiB
C++

#pragma once
namespace vm { using namespace ps3; }
struct sys_rwlock_attribute_t
{
be_t<u32> protocol;
be_t<u32> pshared;
be_t<u64> ipc_key;
be_t<s32> flags;
be_t<u32> pad;
union
{
char name[8];
u64 name_u64;
};
};
struct lv2_rwlock_t
{
const u32 protocol;
const u64 name;
std::atomic<u32> readers; // reader count
std::atomic<u32> writer; // writer id
// TODO: use sleep queue, possibly remove condition variables
std::condition_variable rcv;
std::condition_variable wcv;
std::atomic<u32> rwaiters;
std::atomic<u32> wwaiters;
lv2_rwlock_t(u32 protocol, u64 name)
: protocol(protocol)
, name(name)
, readers(0)
, writer(0)
, rwaiters(0)
, wwaiters(0)
{
}
};
REG_ID_TYPE(lv2_rwlock_t, 0x88); // SYS_RWLOCK_OBJECT
// SysCalls
s32 sys_rwlock_create(vm::ptr<u32> rw_lock_id, vm::ptr<sys_rwlock_attribute_t> attr);
s32 sys_rwlock_destroy(u32 rw_lock_id);
s32 sys_rwlock_rlock(u32 rw_lock_id, u64 timeout);
s32 sys_rwlock_tryrlock(u32 rw_lock_id);
s32 sys_rwlock_runlock(u32 rw_lock_id);
s32 sys_rwlock_wlock(PPUThread& CPU, u32 rw_lock_id, u64 timeout);
s32 sys_rwlock_trywlock(PPUThread& CPU, u32 rw_lock_id);
s32 sys_rwlock_wunlock(PPUThread& CPU, u32 rw_lock_id);