Merge pull request #3895 from NarcolepticK/pm-migrate-framework

service/pm: Migrate to ServiceFramework
This commit is contained in:
Weiyi Wang 2018-06-30 13:20:31 +03:00 committed by GitHub
commit ffae5be1ea
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
9 changed files with 121 additions and 42 deletions

View file

@ -322,8 +322,12 @@ add_library(core STATIC
hle/service/nwm/uds_connection.h
hle/service/nwm/uds_data.cpp
hle/service/nwm/uds_data.h
hle/service/pm_app.cpp
hle/service/pm_app.h
hle/service/pm/pm.cpp
hle/service/pm/pm.h
hle/service/pm/pm_app.cpp
hle/service/pm/pm_app.h
hle/service/pm/pm_dbg.cpp
hle/service/pm/pm_dbg.h
hle/service/ptm/ptm.cpp
hle/service/ptm/ptm.h
hle/service/ptm/ptm_gets.cpp

View file

@ -0,0 +1,18 @@
// Copyright 2018 Citra Emulator Project
// Licensed under GPLv2 or any later version
// Refer to the license.txt file included.
#include "core/hle/service/pm/pm.h"
#include "core/hle/service/pm/pm_app.h"
#include "core/hle/service/pm/pm_dbg.h"
namespace Service {
namespace PM {
void InstallInterfaces(SM::ServiceManager& service_manager) {
std::make_shared<PM_APP>()->InstallAsService(service_manager);
std::make_shared<PM_DBG>()->InstallAsService(service_manager);
}
} // namespace PM
} // namespace Service

View file

@ -0,0 +1,16 @@
// Copyright 2018 Citra Emulator Project
// Licensed under GPLv2 or any later version
// Refer to the license.txt file included.
#pragma once
#include "core/hle/service/service.h"
namespace Service {
namespace PM {
/// Initializes the PM services.
void InstallInterfaces(SM::ServiceManager& service_manager);
} // namespace PM
} // namespace Service

View file

@ -0,0 +1,34 @@
// Copyright 2014 Citra Emulator Project
// Licensed under GPLv2 or any later version
// Refer to the license.txt file included.
#include "core/hle/ipc_helpers.h"
#include "core/hle/service/pm/pm_app.h"
namespace Service {
namespace PM {
PM_APP::PM_APP() : ServiceFramework("pm:app", 3) {
static const FunctionInfo functions[] = {
// clang-format off
{0x00010140, nullptr, "LaunchTitle"},
{0x00020082, nullptr, "LaunchFIRM"},
{0x00030080, nullptr, "TerminateApplication"},
{0x00040100, nullptr, "TerminateTitle"},
{0x000500C0, nullptr, "TerminateProcess"},
{0x00060082, nullptr, "PrepareForReboot"},
{0x00070042, nullptr, "GetFIRMLaunchParams"},
{0x00080100, nullptr, "GetTitleExheaderFlags"},
{0x00090042, nullptr, "SetFIRMLaunchParams"},
{0x000A0140, nullptr, "SetAppResourceLimit"},
{0x000B0140, nullptr, "GetAppResourceLimit"},
{0x000C0080, nullptr, "UnregisterProcess"},
{0x000D0240, nullptr, "LaunchTitleUpdate"},
// clang-format on
};
RegisterHandlers(functions);
}
} // namespace PM
} // namespace Service

View file

@ -9,13 +9,10 @@
namespace Service {
namespace PM {
class PM_APP final : public Interface {
class PM_APP final : public ServiceFramework<PM_APP> {
public:
PM_APP();
std::string GetPortName() const override {
return "pm:app";
}
~PM_APP() = default;
};
} // namespace PM

View file

@ -0,0 +1,24 @@
// Copyright 2018 Citra Emulator Project
// Licensed under GPLv2 or any later version
// Refer to the license.txt file included.
#include "core/hle/ipc_helpers.h"
#include "core/hle/service/pm/pm_dbg.h"
namespace Service {
namespace PM {
PM_DBG::PM_DBG() : ServiceFramework("pm:dbg", 3) {
static const FunctionInfo functions[] = {
// clang-format off
{0x00010140, nullptr, "LaunchAppDebug"},
{0x00020140, nullptr, "LaunchApp"},
{0x00030000, nullptr, "RunQueuedProcess"},
// clang-format on
};
RegisterHandlers(functions);
}
} // namespace PM
} // namespace Service

View file

@ -0,0 +1,19 @@
// Copyright 2018 Citra Emulator Project
// Licensed under GPLv2 or any later version
// Refer to the license.txt file included.
#pragma once
#include "core/hle/service/service.h"
namespace Service {
namespace PM {
class PM_DBG final : public ServiceFramework<PM_DBG> {
public:
PM_DBG();
~PM_DBG() = default;
};
} // namespace PM
} // namespace Service

View file

@ -1,33 +0,0 @@
// Copyright 2014 Citra Emulator Project
// Licensed under GPLv2 or any later version
// Refer to the license.txt file included.
#include "core/hle/service/pm_app.h"
namespace Service {
namespace PM {
const Interface::FunctionInfo FunctionTable[] = {
// clang-format off
{0x00010140, nullptr, "LaunchTitle"},
{0x00020082, nullptr, "LaunchFIRM"},
{0x00030080, nullptr, "TerminateApplication"},
{0x00040100, nullptr, "TerminateTitle"},
{0x000500C0, nullptr, "TerminateProcess"},
{0x00060082, nullptr, "PrepareForReboot"},
{0x00070042, nullptr, "GetFIRMLaunchParams"},
{0x00080100, nullptr, "GetTitleExheaderFlags"},
{0x00090042, nullptr, "SetFIRMLaunchParams"},
{0x000A0140, nullptr, "SetAppResourceLimit"},
{0x000B0140, nullptr, "GetAppResourceLimit"},
{0x000C0080, nullptr, "UnregisterProcess"},
{0x000D0240, nullptr, "LaunchTitleUpdate"},
// clang-format on
};
PM_APP::PM_APP() {
Register(FunctionTable);
}
} // namespace PM
} // namespace Service

View file

@ -43,7 +43,7 @@
#include "core/hle/service/nim/nim.h"
#include "core/hle/service/ns/ns.h"
#include "core/hle/service/nwm/nwm.h"
#include "core/hle/service/pm_app.h"
#include "core/hle/service/pm/pm.h"
#include "core/hle/service/ptm/ptm.h"
#include "core/hle/service/pxi/pxi.h"
#include "core/hle/service/qtm/qtm.h"
@ -258,7 +258,7 @@ void Init(std::shared_ptr<SM::ServiceManager>& sm) {
AddService(new CSND::CSND_SND);
AddService(new DSP_DSP::Interface);
AddService(new HTTP::HTTP_C);
AddService(new PM::PM_APP);
PM::InstallInterfaces(*sm);
AddService(new SOC::SOC_U);
SSL::InstallInterfaces(*sm);
Y2R::InstallInterfaces(*sm);