2020-12-05 13:08:24 +01:00
|
|
|
#pragma once
|
2014-02-13 20:59:13 +04:00
|
|
|
|
2016-04-14 01:23:53 +03:00
|
|
|
#include "sys_sync.h"
|
2018-09-26 01:14:10 +03:00
|
|
|
#include "sys_mutex.h"
|
2015-06-19 18:49:38 +03:00
|
|
|
|
2017-01-29 19:50:18 +03:00
|
|
|
struct lv2_mutex;
|
2015-03-07 01:10:04 +03:00
|
|
|
|
|
|
|
|
struct sys_cond_attribute_t
|
2014-02-13 20:59:13 +04:00
|
|
|
{
|
|
|
|
|
be_t<u32> pshared;
|
2015-01-02 02:41:29 +03:00
|
|
|
be_t<s32> flags;
|
2015-03-07 01:10:04 +03:00
|
|
|
be_t<u64> ipc_key;
|
|
|
|
|
|
2014-02-13 20:59:13 +04: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)];
|
2014-02-13 20:59:13 +04:00
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
2017-01-29 19:50:18 +03:00
|
|
|
struct lv2_cond final : lv2_obj
|
2014-02-13 20:59:13 +04:00
|
|
|
{
|
2017-01-25 20:50:30 +03:00
|
|
|
static const u32 id_base = 0x86000000;
|
|
|
|
|
|
2017-02-02 20:47:25 +03:00
|
|
|
const u64 key;
|
2015-03-07 01:10:04 +03:00
|
|
|
const u64 name;
|
2020-06-09 18:35:14 +03:00
|
|
|
const u32 mtx_id;
|
2015-03-07 01:10:04 +03:00
|
|
|
|
2017-02-02 20:47:25 +03:00
|
|
|
std::shared_ptr<lv2_mutex> mutex; // Associated Mutex
|
|
|
|
|
atomic_t<u32> waiters{0};
|
|
|
|
|
std::deque<cpu_thread*> sq;
|
2015-03-10 17:42:08 +03:00
|
|
|
|
2021-05-07 13:08:16 +03:00
|
|
|
lv2_cond(u64 key, u64 name, u32 mtx_id, std::shared_ptr<lv2_mutex> mutex)
|
|
|
|
|
: key(key)
|
2015-03-07 01:10:04 +03:00
|
|
|
, name(name)
|
2020-06-09 18:35:14 +03:00
|
|
|
, mtx_id(mtx_id)
|
2017-02-02 20:47:25 +03:00
|
|
|
, mutex(std::move(mutex))
|
2014-02-13 20:59:13 +04:00
|
|
|
{
|
2020-06-04 06:37:25 +03:00
|
|
|
}
|
|
|
|
|
|
2021-05-07 09:58:30 +03:00
|
|
|
CellError on_id_create()
|
2020-06-04 06:37:25 +03:00
|
|
|
{
|
2021-05-07 09:58:30 +03:00
|
|
|
if (mutex->exists)
|
2020-06-04 06:37:25 +03:00
|
|
|
{
|
2021-05-07 09:58:30 +03:00
|
|
|
mutex->cond_count++;
|
|
|
|
|
exists++;
|
|
|
|
|
return {};
|
2020-06-04 06:37:25 +03:00
|
|
|
}
|
|
|
|
|
|
2021-05-07 09:58:30 +03:00
|
|
|
// Mutex has been destroyed, cannot create conditional variable
|
|
|
|
|
return CELL_ESRCH;
|
2014-02-13 20:59:13 +04:00
|
|
|
}
|
2014-06-25 00:38:34 +02:00
|
|
|
};
|
|
|
|
|
|
2016-07-28 00:43:22 +03:00
|
|
|
class ppu_thread;
|
2014-12-23 02:31:11 +03:00
|
|
|
|
2017-02-02 20:47:25 +03:00
|
|
|
// Syscalls
|
|
|
|
|
|
2019-06-09 01:38:01 +03:00
|
|
|
error_code sys_cond_create(ppu_thread& ppu, vm::ptr<u32> cond_id, u32 mutex_id, vm::ptr<sys_cond_attribute_t> attr);
|
|
|
|
|
error_code sys_cond_destroy(ppu_thread& ppu, u32 cond_id);
|
2017-02-02 20:47:25 +03:00
|
|
|
error_code sys_cond_wait(ppu_thread& ppu, u32 cond_id, u64 timeout);
|
2017-02-06 21:36:46 +03:00
|
|
|
error_code sys_cond_signal(ppu_thread& ppu, u32 cond_id);
|
|
|
|
|
error_code sys_cond_signal_all(ppu_thread& ppu, u32 cond_id);
|
|
|
|
|
error_code sys_cond_signal_to(ppu_thread& ppu, u32 cond_id, u32 thread_id);
|