2022-04-23 10:59:50 +02:00
|
|
|
// SPDX-FileCopyrightText: Copyright 2021 yuzu Emulator Project
|
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2021-01-31 10:37:41 +01:00
|
|
|
|
|
|
|
#include "core/hle/kernel/k_event.h"
|
2021-04-24 07:04:28 +02:00
|
|
|
#include "core/hle/kernel/k_process.h"
|
2021-04-04 09:56:09 +02:00
|
|
|
#include "core/hle/kernel/k_resource_limit.h"
|
2021-01-31 10:37:41 +01:00
|
|
|
|
|
|
|
namespace Kernel {
|
|
|
|
|
2021-05-08 18:11:36 +02:00
|
|
|
KEvent::KEvent(KernelCore& kernel_)
|
2022-10-13 02:26:04 +02:00
|
|
|
: KAutoObjectWithSlabHeapAndContainer{kernel_}, m_readable_event{kernel_} {}
|
2021-01-31 10:37:41 +01:00
|
|
|
|
|
|
|
KEvent::~KEvent() = default;
|
|
|
|
|
2022-10-13 02:26:04 +02:00
|
|
|
void KEvent::Initialize(KProcess* owner) {
|
|
|
|
// Create our readable event.
|
|
|
|
KAutoObject::Create(std::addressof(m_readable_event));
|
2021-01-31 10:37:41 +01:00
|
|
|
|
2022-10-13 02:26:04 +02:00
|
|
|
// Initialize our readable event.
|
|
|
|
m_readable_event.Initialize(this);
|
2021-01-31 10:37:41 +01:00
|
|
|
|
2021-04-04 09:56:09 +02:00
|
|
|
// Set our owner process.
|
2022-11-10 22:14:03 +01:00
|
|
|
// 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-04-04 09:56:09 +02:00
|
|
|
|
2021-01-31 10:37:41 +01:00
|
|
|
// Mark initialized.
|
2022-10-13 02:26:04 +02:00
|
|
|
m_initialized = true;
|
2021-01-31 10:37:41 +01:00
|
|
|
}
|
|
|
|
|
2021-04-04 09:56:09 +02:00
|
|
|
void KEvent::Finalize() {
|
|
|
|
KAutoObjectWithSlabHeapAndContainer<KEvent, KAutoObjectWithList>::Finalize();
|
|
|
|
}
|
|
|
|
|
2022-10-13 02:26:04 +02: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();
|
|
|
|
}
|
|
|
|
|
2021-04-04 09:56:09 +02:00
|
|
|
void KEvent::PostDestroy(uintptr_t arg) {
|
|
|
|
// Release the event count resource the owner process holds.
|
2021-04-24 07:04:28 +02:00
|
|
|
KProcess* owner = reinterpret_cast<KProcess*>(arg);
|
2022-11-10 22:14:03 +01:00
|
|
|
|
|
|
|
if (owner != nullptr) {
|
|
|
|
owner->GetResourceLimit()->Release(LimitableResource::EventCountMax, 1);
|
|
|
|
owner->Close();
|
|
|
|
}
|
2021-04-04 09:56:09 +02:00
|
|
|
}
|
|
|
|
|
2021-01-31 10:37:41 +01:00
|
|
|
} // namespace Kernel
|