summaryrefslogtreecommitdiffstats
path: root/src/core/hle/kernel/k_scheduler.cpp
diff options
context:
space:
mode:
authorLiam <byteslice@airmail.cc>2022-07-11 16:13:13 +0200
committerLiam <byteslice@airmail.cc>2022-07-15 04:47:18 +0200
commita9a83fa726b43a28f4e5a40516efd56fbf99009f (patch)
tree1f9de785b3af0d31ca19aa7d5770437fe17902c1 /src/core/hle/kernel/k_scheduler.cpp
parentkernel: be more careful about initialization path for HLE threads (diff)
downloadyuzu-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.cpp21
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);