mirror of
https://github.com/RPCS3/rpcs3.git
synced 2025-07-03 13:31:27 +12:00
waiter_reg_t, cellSyncBarrier improved
This commit is contained in:
parent
3c2e0fff07
commit
48eb66383b
3 changed files with 44 additions and 31 deletions
|
@ -235,7 +235,9 @@ bool waiter_is_stopped(const char* func_name, u64 signal_id)
|
|||
return false;
|
||||
}
|
||||
|
||||
void waiter_register(u64 signal_id, NamedThreadBase* thread)
|
||||
waiter_reg_t::waiter_reg_t(u64 signal_id)
|
||||
: signal_id(signal_id)
|
||||
, thread(GetCurrentNamedThread())
|
||||
{
|
||||
std::lock_guard<std::mutex> lock(g_waiter_map.m_mutex);
|
||||
|
||||
|
@ -243,12 +245,12 @@ void waiter_register(u64 signal_id, NamedThreadBase* thread)
|
|||
g_waiter_map.m_waiters.push_back({ signal_id, thread });
|
||||
}
|
||||
|
||||
void waiter_unregister(u64 signal_id, NamedThreadBase* thread)
|
||||
waiter_reg_t::~waiter_reg_t()
|
||||
{
|
||||
std::lock_guard<std::mutex> lock(g_waiter_map.m_mutex);
|
||||
|
||||
// remove waiter
|
||||
for (s32 i = g_waiter_map.m_waiters.size() - 1; i >= 0; i--)
|
||||
for (size_t i = g_waiter_map.m_waiters.size() - 1; i >= 0; i--)
|
||||
{
|
||||
if (g_waiter_map.m_waiters[i].signal_id == signal_id && g_waiter_map.m_waiters[i].thread == thread)
|
||||
{
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue