Correct implementation for auto reset events.

This commit is contained in:
Skyth 2024-12-20 20:55:10 +03:00
parent 1376a73c55
commit 7942bd3b6a

View file

@ -36,18 +36,35 @@ struct Event final : KernelObject, HostObject<XKEVENT>
{ {
if (timeout == 0) if (timeout == 0)
{ {
if (!signaled) if (manualReset)
return STATUS_TIMEOUT; {
if (!signaled)
if (!manualReset) return STATUS_TIMEOUT;
signaled = false; }
else
{
bool expected = true;
if (!signaled.compare_exchange_strong(expected, false))
return STATUS_TIMEOUT;
}
} }
else if (timeout == INFINITE) else if (timeout == INFINITE)
{ {
signaled.wait(false); if (manualReset)
{
signaled.wait(false);
}
else
{
while (true)
{
bool expected = true;
if (signaled.compare_exchange_weak(expected, false))
break;
if (!manualReset) signaled.wait(expected);
signaled = false; }
}
} }
else else
{ {
@ -60,7 +77,11 @@ struct Event final : KernelObject, HostObject<XKEVENT>
bool Set() bool Set()
{ {
signaled = true; signaled = true;
signaled.notify_all();
if (manualReset)
signaled.notify_all();
else
signaled.notify_one();
return TRUE; return TRUE;
} }