2020-12-05 13:08:24 +01:00
|
|
|
#pragma once
|
2014-06-25 00:38:34 +02:00
|
|
|
|
2017-02-03 02:16:09 +03:00
|
|
|
#include "sys_sync.h"
|
2015-06-19 18:49:38 +03:00
|
|
|
|
2018-09-26 01:14:10 +03:00
|
|
|
#include "Emu/Memory/vm_ptr.h"
|
|
|
|
|
|
2014-09-19 04:19:22 +04:00
|
|
|
struct sys_lwmutex_t;
|
|
|
|
|
|
2014-06-25 00:38:34 +02:00
|
|
|
struct sys_lwcond_attribute_t
|
|
|
|
|
{
|
2017-02-03 02:16:09 +03:00
|
|
|
union
|
|
|
|
|
{
|
2019-10-25 17:50:46 +03:00
|
|
|
nse_t<u64, 1> name_u64;
|
2019-07-08 20:00:27 +03:00
|
|
|
char name[sizeof(u64)];
|
2017-02-03 02:16:09 +03:00
|
|
|
};
|
2014-06-25 00:38:34 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
struct sys_lwcond_t
|
|
|
|
|
{
|
2018-02-09 17:49:37 +03:00
|
|
|
vm::bptr<sys_lwmutex_t> lwmutex;
|
2015-03-09 22:56:55 +03:00
|
|
|
be_t<u32> lwcond_queue; // lwcond pseudo-id
|
2014-06-25 00:38:34 +02:00
|
|
|
};
|
|
|
|
|
|
2017-01-29 19:50:18 +03:00
|
|
|
struct lv2_lwcond final : lv2_obj
|
2014-06-25 00:38:34 +02:00
|
|
|
{
|
2017-01-25 20:50:30 +03:00
|
|
|
static const u32 id_base = 0x97000000;
|
|
|
|
|
|
2020-03-18 16:47:44 +02:00
|
|
|
const be_t<u64> name;
|
2017-02-03 02:16:09 +03:00
|
|
|
const u32 lwid;
|
2020-06-09 18:35:14 +03:00
|
|
|
const lv2_protocol protocol;
|
2018-02-09 17:49:37 +03:00
|
|
|
vm::ptr<sys_lwcond_t> control;
|
2014-06-25 00:38:34 +02:00
|
|
|
|
2018-11-26 18:55:22 +03:00
|
|
|
shared_mutex mutex;
|
2022-07-28 14:10:16 +03:00
|
|
|
ppu_thread* sq{};
|
2014-12-28 16:15:22 +03:00
|
|
|
|
2023-05-24 20:47:29 +03:00
|
|
|
atomic_t<s32> lwmutex_waiters = 0;
|
|
|
|
|
|
2021-05-08 20:08:25 +03:00
|
|
|
lv2_lwcond(u64 name, u32 lwid, u32 protocol, vm::ptr<sys_lwcond_t> control) noexcept
|
2020-03-18 16:47:44 +02:00
|
|
|
: name(std::bit_cast<be_t<u64>>(name))
|
2017-02-03 02:16:09 +03:00
|
|
|
, lwid(lwid)
|
2021-05-08 20:08:25 +03:00
|
|
|
, protocol{static_cast<u8>(protocol)}
|
2017-07-29 21:24:57 +03:00
|
|
|
, control(control)
|
2014-06-25 00:38:34 +02:00
|
|
|
{
|
|
|
|
|
}
|
2022-07-04 16:02:17 +03:00
|
|
|
|
|
|
|
|
lv2_lwcond(utils::serial& ar);
|
|
|
|
|
void save(utils::serial& ar);
|
2014-06-25 00:38:34 +02:00
|
|
|
};
|
|
|
|
|
|
2014-09-19 04:19:22 +04:00
|
|
|
// Aux
|
2016-07-28 00:43:22 +03:00
|
|
|
class ppu_thread;
|
2014-12-23 02:31:11 +03:00
|
|
|
|
2017-02-03 02:16:09 +03:00
|
|
|
// Syscalls
|
|
|
|
|
|
2020-03-17 09:59:28 +02:00
|
|
|
error_code _sys_lwcond_create(ppu_thread& ppu, vm::ptr<u32> lwcond_id, u32 lwmutex_id, vm::ptr<sys_lwcond_t> control, u64 name);
|
2019-06-20 14:45:17 +03:00
|
|
|
error_code _sys_lwcond_destroy(ppu_thread& ppu, u32 lwcond_id);
|
2020-05-14 22:33:41 +03:00
|
|
|
error_code _sys_lwcond_signal(ppu_thread& ppu, u32 lwcond_id, u32 lwmutex_id, u64 ppu_thread_id, u32 mode);
|
2017-02-06 21:36:46 +03:00
|
|
|
error_code _sys_lwcond_signal_all(ppu_thread& ppu, u32 lwcond_id, u32 lwmutex_id, u32 mode);
|
2017-02-03 02:16:09 +03:00
|
|
|
error_code _sys_lwcond_queue_wait(ppu_thread& ppu, u32 lwcond_id, u32 lwmutex_id, u64 timeout);
|