2013-11-09 02:05:58 +01:00
|
|
|
#pragma once
|
|
|
|
|
|
2016-04-14 00:23:53 +02:00
|
|
|
#include "sys_sync.h"
|
2015-06-19 17:49:38 +02:00
|
|
|
|
2018-09-26 00:14:10 +02:00
|
|
|
#include "Emu/Memory/vm_ptr.h"
|
|
|
|
|
|
2013-11-09 02:05:58 +01:00
|
|
|
struct sys_rwlock_attribute_t
|
|
|
|
|
{
|
2015-01-02 00:41:29 +01:00
|
|
|
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
|
|
|
|
2014-02-09 12:11:48 +01:00
|
|
|
union
|
|
|
|
|
{
|
2019-10-25 16:50:46 +02:00
|
|
|
nse_t<u64, 1> name_u64;
|
2019-07-08 19:00:27 +02:00
|
|
|
char name[sizeof(u64)];
|
2014-02-09 12:11:48 +01:00
|
|
|
};
|
2013-11-09 02:05:58 +01:00
|
|
|
};
|
|
|
|
|
|
2017-01-29 17:50:18 +01:00
|
|
|
struct lv2_rwlock final : lv2_obj
|
2014-01-29 21:31:09 +01:00
|
|
|
{
|
2017-01-25 18:50:30 +01:00
|
|
|
static const u32 id_base = 0x88000000;
|
|
|
|
|
|
2020-06-09 17:35:14 +02:00
|
|
|
const lv2_protocol protocol;
|
2017-01-31 21:04:23 +01:00
|
|
|
const u64 key;
|
|
|
|
|
const u64 name;
|
2014-01-29 21:31:09 +01:00
|
|
|
|
2018-11-26 16:55:22 +01:00
|
|
|
shared_mutex mutex;
|
2017-01-31 21:04:23 +01:00
|
|
|
atomic_t<s64> owner{0};
|
2022-07-28 13:10:16 +02:00
|
|
|
ppu_thread* rq{};
|
|
|
|
|
ppu_thread* wq{};
|
2014-01-29 21:31:09 +01:00
|
|
|
|
2021-05-08 19:08:25 +02:00
|
|
|
lv2_rwlock(u32 protocol, u64 key, u64 name) noexcept
|
|
|
|
|
: protocol{static_cast<u8>(protocol)}
|
2017-07-24 17:59:48 +02:00
|
|
|
, key(key)
|
2015-03-08 03:32:41 +01:00
|
|
|
, name(name)
|
2014-01-29 21:31:09 +01:00
|
|
|
{
|
|
|
|
|
}
|
2022-07-04 15:02:17 +02:00
|
|
|
|
|
|
|
|
lv2_rwlock(utils::serial& ar);
|
2024-12-22 19:59:48 +01:00
|
|
|
static std::function<void(void*)> load(utils::serial& ar);
|
2022-07-04 15:02:17 +02:00
|
|
|
void save(utils::serial& ar);
|
2014-04-10 00:54:32 +02:00
|
|
|
};
|
2014-06-25 00:38:34 +02:00
|
|
|
|
2015-07-20 18:46:24 +02:00
|
|
|
// Aux
|
2016-07-27 23:43:22 +02:00
|
|
|
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);
|
2017-07-23 15:01:52 +02:00
|
|
|
|
|
|
|
|
constexpr auto _sys_rwlock_trywlock = sys_rwlock_trywlock;
|