mirror of
https://github.com/yuzu-emu/yuzu-android
synced 2025-01-21 18:21:56 -08:00
a47aaa7f1b
Renames the members to more accurately indicate what they signify. "OneShot" and "Sticky" are kind of ambiguous identifiers for the reset types, and can be kind of misleading. Automatic and Manual communicate the kind of reset type in a clearer manner. Either the event is automatically reset, or it isn't and must be manually cleared. The "OneShot" and "Sticky" terminology is just a hold-over from Citra where the kernel had a third type of event reset type known as "Pulse". Given the Switch kernel only has two forms of event reset types, we don't need to keep the old terminology around anymore.
49 lines
1.0 KiB
C++
49 lines
1.0 KiB
C++
// Copyright 2014 Citra Emulator Project
|
|
// Licensed under GPLv2 or any later version
|
|
// Refer to the license.txt file included.
|
|
|
|
#include <algorithm>
|
|
#include "common/assert.h"
|
|
#include "core/hle/kernel/errors.h"
|
|
#include "core/hle/kernel/object.h"
|
|
#include "core/hle/kernel/readable_event.h"
|
|
#include "core/hle/kernel/thread.h"
|
|
|
|
namespace Kernel {
|
|
|
|
ReadableEvent::ReadableEvent(KernelCore& kernel) : WaitObject{kernel} {}
|
|
ReadableEvent::~ReadableEvent() = default;
|
|
|
|
bool ReadableEvent::ShouldWait(const Thread* thread) const {
|
|
return !signaled;
|
|
}
|
|
|
|
void ReadableEvent::Acquire(Thread* thread) {
|
|
ASSERT_MSG(!ShouldWait(thread), "object unavailable!");
|
|
|
|
if (reset_type == ResetType::Automatic) {
|
|
signaled = false;
|
|
}
|
|
}
|
|
|
|
void ReadableEvent::Signal() {
|
|
signaled = true;
|
|
WakeupAllWaitingThreads();
|
|
}
|
|
|
|
void ReadableEvent::Clear() {
|
|
signaled = false;
|
|
}
|
|
|
|
ResultCode ReadableEvent::Reset() {
|
|
if (!signaled) {
|
|
return ERR_INVALID_STATE;
|
|
}
|
|
|
|
Clear();
|
|
|
|
return RESULT_SUCCESS;
|
|
}
|
|
|
|
} // namespace Kernel
|