From e6f7825a248dd0ff9f2e3fdccabdbe3631622861 Mon Sep 17 00:00:00 2001 From: Zach Hilman Date: Tue, 4 Dec 2018 22:11:32 -0500 Subject: svc: Avoid incorrect fast yield condition --- src/core/hle/kernel/svc.cpp | 7 +------ 1 file changed, 1 insertion(+), 6 deletions(-) (limited to 'src/core/hle/kernel') diff --git a/src/core/hle/kernel/svc.cpp b/src/core/hle/kernel/svc.cpp index 29c2c2d03..e3cf3f909 100644 --- a/src/core/hle/kernel/svc.cpp +++ b/src/core/hle/kernel/svc.cpp @@ -960,11 +960,6 @@ static void ExitThread() { static void SleepThread(s64 nanoseconds) { LOG_TRACE(Kernel_SVC, "called nanoseconds={}", nanoseconds); - // Don't attempt to yield execution if there are no available threads to run, - // this way we avoid a useless reschedule to the idle thread. - if (nanoseconds <= 0 && !Core::System::GetInstance().CurrentScheduler().HaveReadyThreads()) - return; - enum class SleepType : s64 { YieldWithoutLoadBalancing = 0, YieldWithLoadBalancing = -1, @@ -995,7 +990,7 @@ static void SleepThread(s64 nanoseconds) { } // Reschedule all CPU cores - for (std::size_t i = 0; i < 4; ++i) + for (std::size_t i = 0; i < Core::NUM_CPU_CORES; ++i) Core::System::GetInstance().CpuCore(i).PrepareReschedule(); } -- cgit v1.2.3