diff options
| author | Liam <byteslice@airmail.cc> | 2024-02-06 23:09:43 -0500 |
|---|---|---|
| committer | Liam <byteslice@airmail.cc> | 2024-02-07 12:14:46 -0500 |
| commit | 9404633bfd1e4ea23ccf8ef526b2b4c564ba512d (patch) | |
| tree | fe37bb0acf2383ecc625f3c278000ba5869ccbaa /src/core/hle/service/mutex.cpp | |
| parent | c10e720ba9cb979577b3af53adb1347f13ec4ad5 (diff) | |
service: add os types and multi wait API
Diffstat (limited to 'src/core/hle/service/mutex.cpp')
| -rw-r--r-- | src/core/hle/service/mutex.cpp | 46 |
1 files changed, 0 insertions, 46 deletions
diff --git a/src/core/hle/service/mutex.cpp b/src/core/hle/service/mutex.cpp deleted file mode 100644 index b0ff71d1b..000000000 --- a/src/core/hle/service/mutex.cpp +++ /dev/null @@ -1,46 +0,0 @@ -// SPDX-FileCopyrightText: Copyright 2023 yuzu Emulator Project -// SPDX-License-Identifier: GPL-2.0-or-later - -#include "core/core.h" -#include "core/hle/kernel/k_event.h" -#include "core/hle/kernel/k_synchronization_object.h" -#include "core/hle/service/mutex.h" - -namespace Service { - -Mutex::Mutex(Core::System& system) : m_system(system) { - m_event = Kernel::KEvent::Create(system.Kernel()); - m_event->Initialize(nullptr); - - // Register the event. - Kernel::KEvent::Register(system.Kernel(), m_event); - - ASSERT(R_SUCCEEDED(m_event->Signal())); -} - -Mutex::~Mutex() { - m_event->GetReadableEvent().Close(); - m_event->Close(); -} - -void Mutex::lock() { - // Infinitely retry until we successfully clear the event. - while (R_FAILED(m_event->GetReadableEvent().Reset())) { - s32 index; - Kernel::KSynchronizationObject* obj = &m_event->GetReadableEvent(); - - // The event was already cleared! - // Wait for it to become signaled again. - ASSERT(R_SUCCEEDED( - Kernel::KSynchronizationObject::Wait(m_system.Kernel(), &index, &obj, 1, -1))); - } - - // We successfully cleared the event, and now have exclusive ownership. -} - -void Mutex::unlock() { - // Unlock. - ASSERT(R_SUCCEEDED(m_event->Signal())); -} - -} // namespace Service |
