diff options
author | Liam <byteslice@airmail.cc> | 2022-07-11 16:13:13 +0200 |
---|---|---|
committer | Liam <byteslice@airmail.cc> | 2022-07-15 04:47:18 +0200 |
commit | a9a83fa726b43a28f4e5a40516efd56fbf99009f (patch) | |
tree | 1f9de785b3af0d31ca19aa7d5770437fe17902c1 /src/core/hle/kernel/k_scheduler.cpp | |
parent | kernel: be more careful about initialization path for HLE threads (diff) | |
download | yuzu-a9a83fa726b43a28f4e5a40516efd56fbf99009f.tar yuzu-a9a83fa726b43a28f4e5a40516efd56fbf99009f.tar.gz yuzu-a9a83fa726b43a28f4e5a40516efd56fbf99009f.tar.bz2 yuzu-a9a83fa726b43a28f4e5a40516efd56fbf99009f.tar.lz yuzu-a9a83fa726b43a28f4e5a40516efd56fbf99009f.tar.xz yuzu-a9a83fa726b43a28f4e5a40516efd56fbf99009f.tar.zst yuzu-a9a83fa726b43a28f4e5a40516efd56fbf99009f.zip |
Diffstat (limited to 'src/core/hle/kernel/k_scheduler.cpp')
-rw-r--r-- | src/core/hle/kernel/k_scheduler.cpp | 21 |
1 files changed, 13 insertions, 8 deletions
diff --git a/src/core/hle/kernel/k_scheduler.cpp b/src/core/hle/kernel/k_scheduler.cpp index d9ba8e409..c34ce7a17 100644 --- a/src/core/hle/kernel/k_scheduler.cpp +++ b/src/core/hle/kernel/k_scheduler.cpp @@ -63,14 +63,8 @@ void KScheduler::EnableScheduling(KernelCore& kernel, u64 cores_needing_scheduli auto* scheduler{kernel.CurrentScheduler()}; if (!scheduler || kernel.IsPhantomModeForSingleCore()) { - // HACK: we cannot schedule from this thread, it is not a core thread - RescheduleCores(kernel, cores_needing_scheduling); - if (GetCurrentThread(kernel).GetDisableDispatchCount() == 1) { - // Special case to ensure dummy threads that are waiting block - GetCurrentThread(kernel).IfDummyThreadTryWait(); - } - GetCurrentThread(kernel).EnableDispatch(); - ASSERT(GetCurrentThread(kernel).GetState() != ThreadState::Waiting); + KScheduler::RescheduleCores(kernel, cores_needing_scheduling); + KScheduler::RescheduleCurrentHLEThread(kernel); return; } @@ -83,6 +77,17 @@ void KScheduler::EnableScheduling(KernelCore& kernel, u64 cores_needing_scheduli } } +void KScheduler::RescheduleCurrentHLEThread(KernelCore& kernel) { + // HACK: we cannot schedule from this thread, it is not a core thread + ASSERT(GetCurrentThread(kernel).GetDisableDispatchCount() == 1); + + // Special case to ensure dummy threads that are waiting block + GetCurrentThread(kernel).IfDummyThreadTryWait(); + + ASSERT(GetCurrentThread(kernel).GetState() != ThreadState::Waiting); + GetCurrentThread(kernel).EnableDispatch(); +} + u64 KScheduler::UpdateHighestPriorityThreads(KernelCore& kernel) { if (IsSchedulerUpdateNeeded(kernel)) { return UpdateHighestPriorityThreadsImpl(kernel); |