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:
Eladash 2021-02-13 16:50:07 +02:00 committed by GitHub
parent cf384795d2
commit f43260bd58
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
40 changed files with 375 additions and 234 deletions

View file

@ -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();
}
}