mirror of
https://github.com/skyline-emu/skyline.git
synced 2025-01-17 03:37:55 +03:00
Log and flush inside KProcess::Kill
We want to know when the `KProcess` is being killed and flushing log during it is important since it can often result in hangs due to joining not working correctly.
This commit is contained in:
parent
597a6ff31d
commit
c874907eb5
@ -26,6 +26,9 @@ namespace skyline::kernel::type {
|
||||
}
|
||||
|
||||
void KProcess::Kill(bool join, bool all, bool disableCreation) {
|
||||
Logger::Warn("Killing {}{}KProcess{}", join ? "and joining " : "", all ? "all threads in " : "HOS-0 in ", disableCreation ? " with new thread creation disabled" : "");
|
||||
Logger::EmulationContext.Flush();
|
||||
|
||||
bool expected{false};
|
||||
if (!join && !alreadyKilled.compare_exchange_strong(expected, true))
|
||||
// If the process has already been killed and we don't want to wait for it to join then just instantly return rather than waiting on the mutex
|
||||
|
Loading…
x
Reference in New Issue
Block a user