citra/src/core/hle/kernel/k_event.cpp

65 lines
1.6 KiB
C++
Raw Normal View History

// SPDX-FileCopyrightText: Copyright 2021 yuzu Emulator Project
// SPDX-License-Identifier: GPL-2.0-or-later
2021-01-31 09:37:41 +00:00
#include "core/hle/kernel/k_event.h"
#include "core/hle/kernel/k_process.h"
#include "core/hle/kernel/k_resource_limit.h"
2021-01-31 09:37:41 +00:00
namespace Kernel {
KEvent::KEvent(KernelCore& kernel_)
2022-10-13 00:26:04 +00:00
: KAutoObjectWithSlabHeapAndContainer{kernel_}, m_readable_event{kernel_} {}
2021-01-31 09:37:41 +00:00
KEvent::~KEvent() = default;
2022-10-13 00:26:04 +00:00
void KEvent::Initialize(KProcess* owner) {
// Create our readable event.
KAutoObject::Create(std::addressof(m_readable_event));
2021-01-31 09:37:41 +00:00
2022-10-13 00:26:04 +00:00
// Initialize our readable event.
m_readable_event.Initialize(this);
2021-01-31 09:37:41 +00:00
// Set our owner process.
// HACK: this should never be nullptr, but service threads don't have a
// proper parent process yet.
if (owner != nullptr) {
m_owner = owner;
m_owner->Open();
}
2021-01-31 09:37:41 +00:00
// Mark initialized.
2022-10-13 00:26:04 +00:00
m_initialized = true;
2021-01-31 09:37:41 +00:00
}
void KEvent::Finalize() {
KAutoObjectWithSlabHeapAndContainer<KEvent, KAutoObjectWithList>::Finalize();
}
2022-10-13 00:26:04 +00:00
Result KEvent::Signal() {
KScopedSchedulerLock sl{kernel};
R_SUCCEED_IF(m_readable_event_destroyed);
return m_readable_event.Signal();
}
Result KEvent::Clear() {
KScopedSchedulerLock sl{kernel};
R_SUCCEED_IF(m_readable_event_destroyed);
return m_readable_event.Clear();
}
void KEvent::PostDestroy(uintptr_t arg) {
// Release the event count resource the owner process holds.
KProcess* owner = reinterpret_cast<KProcess*>(arg);
if (owner != nullptr) {
owner->GetResourceLimit()->Release(LimitableResource::EventCountMax, 1);
owner->Close();
}
}
2021-01-31 09:37:41 +00:00
} // namespace Kernel