2018-06-05 11:19:29 +02:00
|
|
|
// Copyright 2018 yuzu emulator team
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#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<MM_U>()->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};
|
2018-06-05 14:34:01 +02:00
|
|
|
min = rp.Pop<u32>();
|
|
|
|
max = rp.Pop<u32>();
|
|
|
|
current = min;
|
2018-06-05 11:19:29 +02:00
|
|
|
|
2018-06-05 14:34:01 +02:00
|
|
|
NGLOG_WARNING(Service_MM, "(STUBBED) called, min=0x{:X}, max=0x{:X}", min, max);
|
2018-06-05 11:19:29 +02:00
|
|
|
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);
|
2018-06-05 14:34:01 +02:00
|
|
|
rb.Push(current);
|
2018-06-05 11:19:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
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
|