Merge pull request #1521 from ogniK5377/imp-mmu

Used better names for mm:u and fixed a bad stub
master
bunnei 2018-10-18 21:46:59 +07:00 committed by GitHub
commit e5d428cf1e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 42 additions and 8 deletions

@ -14,14 +14,14 @@ public:
explicit MM_U() : ServiceFramework{"mm:u"} { explicit MM_U() : ServiceFramework{"mm:u"} {
// clang-format off // clang-format off
static const FunctionInfo functions[] = { static const FunctionInfo functions[] = {
{0, &MM_U::Initialize, "InitializeOld"}, {0, &MM_U::Initialize, "Initialize"},
{1, &MM_U::Finalize, "FinalizeOld"}, {1, &MM_U::Finalize, "Finalize"},
{2, &MM_U::SetAndWait, "SetAndWaitOld"}, {2, &MM_U::SetAndWait, "SetAndWait"},
{3, &MM_U::Get, "GetOld"}, {3, &MM_U::Get, "Get"},
{4, &MM_U::Initialize, "Initialize"}, {4, &MM_U::InitializeWithId, "InitializeWithId"},
{5, &MM_U::Finalize, "Finalize"}, {5, &MM_U::FinalizeWithId, "FinalizeWithId"},
{6, &MM_U::SetAndWait, "SetAndWait"}, {6, &MM_U::SetAndWaitWithId, "SetAndWaitWithId"},
{7, &MM_U::Get, "Get"}, {7, &MM_U::GetWithId, "GetWithId"},
}; };
// clang-format on // clang-format on
@ -59,9 +59,43 @@ private:
rb.Push(current); rb.Push(current);
} }
void InitializeWithId(Kernel::HLERequestContext& ctx) {
LOG_WARNING(Service_MM, "(STUBBED) called");
IPC::ResponseBuilder rb{ctx, 3};
rb.Push(RESULT_SUCCESS);
rb.Push<u32>(id); // Any non zero value
}
void FinalizeWithId(Kernel::HLERequestContext& ctx) {
LOG_WARNING(Service_MM, "(STUBBED) called");
IPC::ResponseBuilder rb{ctx, 2};
rb.Push(RESULT_SUCCESS);
}
void SetAndWaitWithId(Kernel::HLERequestContext& ctx) {
IPC::RequestParser rp{ctx};
u32 input_id = rp.Pop<u32>();
min = rp.Pop<u32>();
max = rp.Pop<u32>();
current = min;
LOG_WARNING(Service_MM, "(STUBBED) called, input_id=0x{:X}, min=0x{:X}, max=0x{:X}",
input_id, min, max);
IPC::ResponseBuilder rb{ctx, 2};
rb.Push(RESULT_SUCCESS);
}
void GetWithId(Kernel::HLERequestContext& ctx) {
LOG_WARNING(Service_MM, "(STUBBED) called");
IPC::ResponseBuilder rb{ctx, 3};
rb.Push(RESULT_SUCCESS);
rb.Push(current);
}
u32 min{0}; u32 min{0};
u32 max{0}; u32 max{0};
u32 current{0}; u32 current{0};
u32 id{1};
}; };
void InstallInterfaces(SM::ServiceManager& service_manager) { void InstallInterfaces(SM::ServiceManager& service_manager) {