aboutsummaryrefslogtreecommitdiff
path: root/Ryujinx.HLE/HOS/Kernel/Threading/HleCoreManager.cs
diff options
context:
space:
mode:
Diffstat (limited to 'Ryujinx.HLE/HOS/Kernel/Threading/HleCoreManager.cs')
-rw-r--r--Ryujinx.HLE/HOS/Kernel/Threading/HleCoreManager.cs66
1 files changed, 0 insertions, 66 deletions
diff --git a/Ryujinx.HLE/HOS/Kernel/Threading/HleCoreManager.cs b/Ryujinx.HLE/HOS/Kernel/Threading/HleCoreManager.cs
deleted file mode 100644
index c2597990..00000000
--- a/Ryujinx.HLE/HOS/Kernel/Threading/HleCoreManager.cs
+++ /dev/null
@@ -1,66 +0,0 @@
-using System.Collections.Concurrent;
-using System.Threading;
-
-namespace Ryujinx.HLE.HOS.Kernel.Threading
-{
- class HleCoreManager
- {
- private class PausableThread
- {
- public ManualResetEvent Event { get; private set; }
-
- public bool IsExiting { get; set; }
-
- public PausableThread()
- {
- Event = new ManualResetEvent(false);
- }
- }
-
- private ConcurrentDictionary<Thread, PausableThread> _threads;
-
- public HleCoreManager()
- {
- _threads = new ConcurrentDictionary<Thread, PausableThread>();
- }
-
- public void Set(Thread thread)
- {
- GetThread(thread).Event.Set();
- }
-
- public void Reset(Thread thread)
- {
- GetThread(thread).Event.Reset();
- }
-
- public void Wait(Thread thread)
- {
- PausableThread pausableThread = GetThread(thread);
-
- if (!pausableThread.IsExiting)
- {
- pausableThread.Event.WaitOne();
- }
- }
-
- public void Exit(Thread thread)
- {
- GetThread(thread).IsExiting = true;
- }
-
- private PausableThread GetThread(Thread thread)
- {
- return _threads.GetOrAdd(thread, (key) => new PausableThread());
- }
-
- public void RemoveThread(Thread thread)
- {
- if (_threads.TryRemove(thread, out PausableThread pausableThread))
- {
- pausableThread.Event.Set();
- pausableThread.Event.Dispose();
- }
- }
- }
-} \ No newline at end of file