From 7e3d746b06d68a7fbadf5b94ef62cad38482c000 Mon Sep 17 00:00:00 2001 From: mailwl Date: Tue, 5 Jun 2018 12:19:29 +0300 Subject: Service/MM: add service and stub some functions --- src/core/hle/service/mm/mm_u.cpp | 50 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+) create mode 100644 src/core/hle/service/mm/mm_u.cpp (limited to 'src/core/hle/service/mm/mm_u.cpp') diff --git a/src/core/hle/service/mm/mm_u.cpp b/src/core/hle/service/mm/mm_u.cpp new file mode 100644 index 000000000..7f12fee27 --- /dev/null +++ b/src/core/hle/service/mm/mm_u.cpp @@ -0,0 +1,50 @@ +// Copyright 2018 yuzu emulator team +// Licensed under GPLv2 or any later version +// Refer to the license.txt file included. + +#include +#include +#include "common/logging/log.h" +#include "core/hle/ipc_helpers.h" +#include "core/hle/kernel/client_session.h" +#include "core/hle/service/mm/mm_u.h" + +namespace Service::MM { + +void InstallInterfaces(SM::ServiceManager& service_manager) { + std::make_shared()->InstallAsService(service_manager); +} + +void MM_U::Initialize(Kernel::HLERequestContext& ctx) { + NGLOG_WARNING(Service_MM, "(STUBBED) called"); + IPC::ResponseBuilder rb{ctx, 2}; + rb.Push(RESULT_SUCCESS); +} + +void MM_U::SetAndWait(Kernel::HLERequestContext& ctx) { + IPC::RequestParser rp{ctx}; + value = rp.Pop(); + + NGLOG_WARNING(Service_MM, "(STUBBED) called, value=0x{:X}", value); + IPC::ResponseBuilder rb{ctx, 2}; + rb.Push(RESULT_SUCCESS); +} + +void MM_U::Get(Kernel::HLERequestContext& ctx) { + NGLOG_WARNING(Service_MM, "(STUBBED) called"); + IPC::ResponseBuilder rb{ctx, 3}; + rb.Push(RESULT_SUCCESS); + rb.Push(value); +} + +MM_U::MM_U() : ServiceFramework("mm:u") { + static const FunctionInfo functions[] = { + {0, nullptr, "InitializeOld"}, {1, nullptr, "FinalizeOld"}, + {2, nullptr, "SetAndWaitOld"}, {3, nullptr, "GetOld"}, + {4, &MM_U::Initialize, "Initialize"}, {5, nullptr, "Finalize"}, + {6, &MM_U::SetAndWait, "SetAndWait"}, {7, &MM_U::Get, "Get"}, + }; + RegisterHandlers(functions); +} + +} // namespace Service::MM -- cgit v1.2.3 From 62cd19e4ae8a917ba17827009e4b543c5da386a4 Mon Sep 17 00:00:00 2001 From: mailwl Date: Tue, 5 Jun 2018 15:34:01 +0300 Subject: Small fixes --- src/core/hle/service/mm/mm_u.cpp | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) (limited to 'src/core/hle/service/mm/mm_u.cpp') diff --git a/src/core/hle/service/mm/mm_u.cpp b/src/core/hle/service/mm/mm_u.cpp index 7f12fee27..b3a85b818 100644 --- a/src/core/hle/service/mm/mm_u.cpp +++ b/src/core/hle/service/mm/mm_u.cpp @@ -2,8 +2,6 @@ // Licensed under GPLv2 or any later version // Refer to the license.txt file included. -#include -#include #include "common/logging/log.h" #include "core/hle/ipc_helpers.h" #include "core/hle/kernel/client_session.h" @@ -23,9 +21,11 @@ void MM_U::Initialize(Kernel::HLERequestContext& ctx) { void MM_U::SetAndWait(Kernel::HLERequestContext& ctx) { IPC::RequestParser rp{ctx}; - value = rp.Pop(); + min = rp.Pop(); + max = rp.Pop(); + current = min; - NGLOG_WARNING(Service_MM, "(STUBBED) called, value=0x{:X}", value); + NGLOG_WARNING(Service_MM, "(STUBBED) called, min=0x{:X}, max=0x{:X}", min, max); IPC::ResponseBuilder rb{ctx, 2}; rb.Push(RESULT_SUCCESS); } @@ -34,7 +34,7 @@ void MM_U::Get(Kernel::HLERequestContext& ctx) { NGLOG_WARNING(Service_MM, "(STUBBED) called"); IPC::ResponseBuilder rb{ctx, 3}; rb.Push(RESULT_SUCCESS); - rb.Push(value); + rb.Push(current); } MM_U::MM_U() : ServiceFramework("mm:u") { -- cgit v1.2.3