From 0039bb639493b2d1e2764cae380311ba8e87704b Mon Sep 17 00:00:00 2001 From: gdkchan Date: Tue, 18 Dec 2018 03:33:36 -0200 Subject: Refactor SVC handler (#540) * Refactor SVC handler * Get rid of KernelErr * Split kernel code files into multiple folders --- Ryujinx.HLE/HOS/Kernel/Threading/KReadableEvent.cs | 64 ++++++++++++++++++++++ 1 file changed, 64 insertions(+) create mode 100644 Ryujinx.HLE/HOS/Kernel/Threading/KReadableEvent.cs (limited to 'Ryujinx.HLE/HOS/Kernel/Threading/KReadableEvent.cs') diff --git a/Ryujinx.HLE/HOS/Kernel/Threading/KReadableEvent.cs b/Ryujinx.HLE/HOS/Kernel/Threading/KReadableEvent.cs new file mode 100644 index 00000000..9821de35 --- /dev/null +++ b/Ryujinx.HLE/HOS/Kernel/Threading/KReadableEvent.cs @@ -0,0 +1,64 @@ +using Ryujinx.HLE.HOS.Kernel.Common; + +namespace Ryujinx.HLE.HOS.Kernel.Threading +{ + class KReadableEvent : KSynchronizationObject + { + private KEvent _parent; + + private bool _signaled; + + public KReadableEvent(Horizon system, KEvent parent) : base(system) + { + _parent = parent; + } + + public override void Signal() + { + System.CriticalSection.Enter(); + + if (!_signaled) + { + _signaled = true; + + base.Signal(); + } + + System.CriticalSection.Leave(); + } + + public KernelResult Clear() + { + _signaled = false; + + return KernelResult.Success; + } + + public KernelResult ClearIfSignaled() + { + KernelResult result; + + System.CriticalSection.Enter(); + + if (_signaled) + { + _signaled = false; + + result = KernelResult.Success; + } + else + { + result = KernelResult.InvalidState; + } + + System.CriticalSection.Leave(); + + return result; + } + + public override bool IsSignaled() + { + return _signaled; + } + } +} \ No newline at end of file -- cgit v1.2.3