From cee712105850ac3385cd0091a923438167433f9f Mon Sep 17 00:00:00 2001 From: TSR Berry <20988865+TSRBerry@users.noreply.github.com> Date: Sat, 8 Apr 2023 01:22:00 +0200 Subject: Move solution and projects to src --- .../HOS/Kernel/Threading/KConditionVariable.cs | 70 ---------------------- 1 file changed, 70 deletions(-) delete mode 100644 Ryujinx.HLE/HOS/Kernel/Threading/KConditionVariable.cs (limited to 'Ryujinx.HLE/HOS/Kernel/Threading/KConditionVariable.cs') diff --git a/Ryujinx.HLE/HOS/Kernel/Threading/KConditionVariable.cs b/Ryujinx.HLE/HOS/Kernel/Threading/KConditionVariable.cs deleted file mode 100644 index 891e632f..00000000 --- a/Ryujinx.HLE/HOS/Kernel/Threading/KConditionVariable.cs +++ /dev/null @@ -1,70 +0,0 @@ -using System.Collections.Generic; -using System.Threading; - -namespace Ryujinx.HLE.HOS.Kernel.Threading -{ - static class KConditionVariable - { - public static void Wait(KernelContext context, LinkedList threadList, object mutex, long timeout) - { - KThread currentThread = KernelStatic.GetCurrentThread(); - - context.CriticalSection.Enter(); - - Monitor.Exit(mutex); - - currentThread.Withholder = threadList; - - currentThread.Reschedule(ThreadSchedState.Paused); - - currentThread.WithholderNode = threadList.AddLast(currentThread); - - if (currentThread.TerminationRequested) - { - threadList.Remove(currentThread.WithholderNode); - - currentThread.Reschedule(ThreadSchedState.Running); - - currentThread.Withholder = null; - - context.CriticalSection.Leave(); - } - else - { - if (timeout > 0) - { - context.TimeManager.ScheduleFutureInvocation(currentThread, timeout); - } - - context.CriticalSection.Leave(); - - if (timeout > 0) - { - context.TimeManager.UnscheduleFutureInvocation(currentThread); - } - } - - Monitor.Enter(mutex); - } - - public static void NotifyAll(KernelContext context, LinkedList threadList) - { - context.CriticalSection.Enter(); - - LinkedListNode node = threadList.First; - - for (; node != null; node = threadList.First) - { - KThread thread = node.Value; - - threadList.Remove(thread.WithholderNode); - - thread.Withholder = null; - - thread.Reschedule(ThreadSchedState.Running); - } - - context.CriticalSection.Leave(); - } - } -} \ No newline at end of file -- cgit v1.2.3