rpcsx/rpcs3/Emu/Cell/lv2/sys_rwlock.h

62 lines
1.4 KiB
C
Raw Normal View History

#pragma once
2016-04-14 00:23:53 +02:00
#include "sys_sync.h"
#include "Emu/Memory/vm_ptr.h"
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;
2015-03-08 03:32:41 +01:00
union
{
nse_t<u64, 1> name_u64;
char name[sizeof(u64)];
};
};
struct lv2_rwlock final : lv2_obj
{
2017-01-25 18:50:30 +01:00
static const u32 id_base = 0x88000000;
2015-07-20 18:46:24 +02:00
const u32 protocol;
2017-01-31 21:04:23 +01:00
const u32 shared;
const u64 key;
const u64 name;
const s32 flags;
shared_mutex mutex;
2017-01-31 21:04:23 +01:00
atomic_t<s64> owner{0};
std::deque<cpu_thread*> rq;
std::deque<cpu_thread*> wq;
2017-07-24 17:59:48 +02:00
lv2_rwlock(u32 protocol, u32 shared, u64 key, s32 flags, u64 name)
: protocol(protocol)
2017-07-24 17:59:48 +02:00
, shared(shared)
, key(key)
2015-03-08 03:32:41 +01:00
, name(name)
, flags(flags)
{
}
};
2015-07-20 18:46:24 +02:00
// Aux
class ppu_thread;
2015-07-20 18:46:24 +02:00
2017-01-31 21:04:23 +01:00
// Syscalls
2019-07-14 17:14:15 +02:00
error_code sys_rwlock_create(ppu_thread& ppu, vm::ptr<u32> rw_lock_id, vm::ptr<sys_rwlock_attribute_t> attr);
error_code sys_rwlock_destroy(ppu_thread& ppu, u32 rw_lock_id);
2017-01-31 21:04:23 +01:00
error_code sys_rwlock_rlock(ppu_thread& ppu, u32 rw_lock_id, u64 timeout);
2019-07-14 17:14:15 +02:00
error_code sys_rwlock_tryrlock(ppu_thread& ppu, u32 rw_lock_id);
2017-02-06 19:36:46 +01:00
error_code sys_rwlock_runlock(ppu_thread& ppu, u32 rw_lock_id);
2017-01-31 21:04:23 +01:00
error_code sys_rwlock_wlock(ppu_thread& ppu, u32 rw_lock_id, u64 timeout);
error_code sys_rwlock_trywlock(ppu_thread& ppu, u32 rw_lock_id);
error_code sys_rwlock_wunlock(ppu_thread& ppu, u32 rw_lock_id);
constexpr auto _sys_rwlock_trywlock = sys_rwlock_trywlock;