diff options
author | Morph <39850852+Morph1984@users.noreply.github.com> | 2021-09-12 18:03:10 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-09-12 18:03:10 +0200 |
commit | 4ab549e62a14de8c0ced8291ec46f659f0897c0e (patch) | |
tree | 2194407c4074dba61af2d288a1098103a13bb5a0 /src/core/hle/service/acc/async_context.cpp | |
parent | Merge pull request #6974 from ogniK5377/fs-recursive-createdir (diff) | |
parent | Mark is_complete as atomic (diff) | |
download | yuzu-4ab549e62a14de8c0ced8291ec46f659f0897c0e.tar yuzu-4ab549e62a14de8c0ced8291ec46f659f0897c0e.tar.gz yuzu-4ab549e62a14de8c0ced8291ec46f659f0897c0e.tar.bz2 yuzu-4ab549e62a14de8c0ced8291ec46f659f0897c0e.tar.lz yuzu-4ab549e62a14de8c0ced8291ec46f659f0897c0e.tar.xz yuzu-4ab549e62a14de8c0ced8291ec46f659f0897c0e.tar.zst yuzu-4ab549e62a14de8c0ced8291ec46f659f0897c0e.zip |
Diffstat (limited to 'src/core/hle/service/acc/async_context.cpp')
-rw-r--r-- | src/core/hle/service/acc/async_context.cpp | 68 |
1 files changed, 68 insertions, 0 deletions
diff --git a/src/core/hle/service/acc/async_context.cpp b/src/core/hle/service/acc/async_context.cpp new file mode 100644 index 000000000..459323132 --- /dev/null +++ b/src/core/hle/service/acc/async_context.cpp @@ -0,0 +1,68 @@ +// Copyright 2021 yuzu emulator team +// Licensed under GPLv2 or any later version +// Refer to the license.txt file included. + +#include "core/core.h" +#include "core/hle/ipc_helpers.h" +#include "core/hle/service/acc/async_context.h" + +namespace Service::Account { +IAsyncContext::IAsyncContext(Core::System& system_) + : ServiceFramework{system_, "IAsyncContext"}, compeletion_event{system_.Kernel()} { + + Kernel::KAutoObject::Create(std::addressof(compeletion_event)); + compeletion_event.Initialize("IAsyncContext:CompletionEvent"); + + // clang-format off + static const FunctionInfo functions[] = { + {0, &IAsyncContext::GetSystemEvent, "GetSystemEvent"}, + {1, &IAsyncContext::Cancel, "Cancel"}, + {2, &IAsyncContext::HasDone, "HasDone"}, + {3, &IAsyncContext::GetResult, "GetResult"}, + }; + // clang-format on + + RegisterHandlers(functions); +} + +void IAsyncContext::GetSystemEvent(Kernel::HLERequestContext& ctx) { + LOG_DEBUG(Service_ACC, "called"); + + IPC::ResponseBuilder rb{ctx, 2, 1}; + rb.Push(ResultSuccess); + rb.PushCopyObjects(compeletion_event.GetReadableEvent()); +} + +void IAsyncContext::Cancel(Kernel::HLERequestContext& ctx) { + LOG_DEBUG(Service_ACC, "called"); + + Cancel(); + MarkComplete(); + + IPC::ResponseBuilder rb{ctx, 2}; + rb.Push(ResultSuccess); +} + +void IAsyncContext::HasDone(Kernel::HLERequestContext& ctx) { + LOG_DEBUG(Service_ACC, "called"); + + is_complete.store(IsComplete()); + + IPC::ResponseBuilder rb{ctx, 3}; + rb.Push(ResultSuccess); + rb.Push(is_complete.load()); +} + +void IAsyncContext::GetResult(Kernel::HLERequestContext& ctx) { + LOG_DEBUG(Service_ACC, "called"); + + IPC::ResponseBuilder rb{ctx, 3}; + rb.Push(GetResult()); +} + +void IAsyncContext::MarkComplete() { + is_complete.store(true); + compeletion_event.GetWritableEvent().Signal(); +} + +} // namespace Service::Account |