mirror of
https://github.com/RPCS3/rpcs3.git
synced 2025-07-10 08:51:28 +12:00
Atomic waiting refactoring (#9208)
* Use atomic waitables instead instead of global thread wait as often as possible. * Add ::is_stopped() and and ::is_paued() which can be used in atomic loops and with atomic wait. (constexpr cpu flags test functions) * Fix notification bug of sys_spu_thread_group_exit/terminate. (old bug, enhanced by #9117) * Function time statistics at Emu.Stop() restored. (instead of current "X syscall failed with 0x00000000 : 0")
This commit is contained in:
parent
cf384795d2
commit
f43260bd58
40 changed files with 375 additions and 234 deletions
|
@ -530,7 +530,7 @@ namespace rsx
|
|||
on_exit();
|
||||
}
|
||||
|
||||
void thread::cpu_wait()
|
||||
void thread::cpu_wait(bs_t<cpu_flag>)
|
||||
{
|
||||
if (external_interrupt_lock)
|
||||
{
|
||||
|
@ -604,7 +604,7 @@ namespace rsx
|
|||
{ ppu_cmd::sleep, 0 }
|
||||
});
|
||||
|
||||
thread_ctrl::notify(*intr_thread);
|
||||
intr_thread->cmd_notify.notify_one();
|
||||
}
|
||||
}
|
||||
else
|
||||
|
@ -3079,7 +3079,8 @@ namespace rsx
|
|||
{ ppu_cmd::sleep, 0 }
|
||||
});
|
||||
|
||||
thread_ctrl::notify(*intr_thread);
|
||||
intr_thread->cmd_notify++;
|
||||
intr_thread->cmd_notify.notify_one();
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue