mirror of
https://git.suyu.dev/suyu/suyu
synced 2025-01-09 16:03:21 +00:00
Merge pull request #1545 from DarkLordZach/psm
psm: Add psm service and stub commands 0 and 1
This commit is contained in:
commit
ff6b2d4574
5 changed files with 91 additions and 0 deletions
|
@ -91,6 +91,7 @@ enum class Class : ClassType {
|
||||||
Service_PM, ///< The PM service
|
Service_PM, ///< The PM service
|
||||||
Service_PREPO, ///< The PREPO (Play report) service
|
Service_PREPO, ///< The PREPO (Play report) service
|
||||||
Service_PSC, ///< The PSC service
|
Service_PSC, ///< The PSC service
|
||||||
|
Service_PSM, ///< The PSM service
|
||||||
Service_SET, ///< The SET (Settings) service
|
Service_SET, ///< The SET (Settings) service
|
||||||
Service_SM, ///< The SM (Service manager) service
|
Service_SM, ///< The SM (Service manager) service
|
||||||
Service_SPL, ///< The SPL service
|
Service_SPL, ///< The SPL service
|
||||||
|
|
|
@ -331,6 +331,8 @@ add_library(core STATIC
|
||||||
hle/service/prepo/prepo.h
|
hle/service/prepo/prepo.h
|
||||||
hle/service/psc/psc.cpp
|
hle/service/psc/psc.cpp
|
||||||
hle/service/psc/psc.h
|
hle/service/psc/psc.h
|
||||||
|
hle/service/ptm/psm.cpp
|
||||||
|
hle/service/ptm/psm.h
|
||||||
hle/service/service.cpp
|
hle/service/service.cpp
|
||||||
hle/service/service.h
|
hle/service/service.h
|
||||||
hle/service/set/set.cpp
|
hle/service/set/set.cpp
|
||||||
|
|
71
src/core/hle/service/ptm/psm.cpp
Normal file
71
src/core/hle/service/ptm/psm.cpp
Normal file
|
@ -0,0 +1,71 @@
|
||||||
|
// Copyright 2018 yuzu emulator team
|
||||||
|
// Licensed under GPLv2 or any later version
|
||||||
|
// Refer to the license.txt file included.
|
||||||
|
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
|
#include "common/logging/log.h"
|
||||||
|
#include "core/hle/ipc_helpers.h"
|
||||||
|
#include "core/hle/service/ptm/psm.h"
|
||||||
|
#include "core/hle/service/service.h"
|
||||||
|
#include "core/hle/service/sm/sm.h"
|
||||||
|
|
||||||
|
namespace Service::PSM {
|
||||||
|
|
||||||
|
constexpr u32 BATTERY_FULLY_CHARGED = 100; // 100% Full
|
||||||
|
constexpr u32 BATTERY_CURRENTLY_CHARGING = 1; // Plugged into an official dock
|
||||||
|
|
||||||
|
class PSM final : public ServiceFramework<PSM> {
|
||||||
|
public:
|
||||||
|
explicit PSM() : ServiceFramework{"psm"} {
|
||||||
|
// clang-format off
|
||||||
|
static const FunctionInfo functions[] = {
|
||||||
|
{0, &PSM::GetBatteryChargePercentage, "GetBatteryChargePercentage"},
|
||||||
|
{1, &PSM::GetChargerType, "GetChargerType"},
|
||||||
|
{2, nullptr, "EnableBatteryCharging"},
|
||||||
|
{3, nullptr, "DisableBatteryCharging"},
|
||||||
|
{4, nullptr, "IsBatteryChargingEnabled"},
|
||||||
|
{5, nullptr, "AcquireControllerPowerSupply"},
|
||||||
|
{6, nullptr, "ReleaseControllerPowerSupply"},
|
||||||
|
{7, nullptr, "OpenSession"},
|
||||||
|
{8, nullptr, "EnableEnoughPowerChargeEmulation"},
|
||||||
|
{9, nullptr, "DisableEnoughPowerChargeEmulation"},
|
||||||
|
{10, nullptr, "EnableFastBatteryCharging"},
|
||||||
|
{11, nullptr, "DisableFastBatteryCharging"},
|
||||||
|
{12, nullptr, "GetBatteryVoltageState"},
|
||||||
|
{13, nullptr, "GetRawBatteryChargePercentage"},
|
||||||
|
{14, nullptr, "IsEnoughPowerSupplied"},
|
||||||
|
{15, nullptr, "GetBatteryAgePercentage"},
|
||||||
|
{16, nullptr, "GetBatteryChargeInfoEvent"},
|
||||||
|
{17, nullptr, "GetBatteryChargeInfoFields"},
|
||||||
|
};
|
||||||
|
// clang-format on
|
||||||
|
|
||||||
|
RegisterHandlers(functions);
|
||||||
|
}
|
||||||
|
|
||||||
|
~PSM() override = default;
|
||||||
|
|
||||||
|
private:
|
||||||
|
void GetBatteryChargePercentage(Kernel::HLERequestContext& ctx) {
|
||||||
|
LOG_WARNING(Service_PSM, "(STUBBED) called");
|
||||||
|
|
||||||
|
IPC::ResponseBuilder rb{ctx, 3};
|
||||||
|
rb.Push(RESULT_SUCCESS);
|
||||||
|
rb.Push<u32>(BATTERY_FULLY_CHARGED);
|
||||||
|
}
|
||||||
|
|
||||||
|
void GetChargerType(Kernel::HLERequestContext& ctx) {
|
||||||
|
LOG_WARNING(Service_PSM, "(STUBBED) called");
|
||||||
|
|
||||||
|
IPC::ResponseBuilder rb{ctx, 3};
|
||||||
|
rb.Push(RESULT_SUCCESS);
|
||||||
|
rb.Push<u32>(BATTERY_CURRENTLY_CHARGING);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
void InstallInterfaces(SM::ServiceManager& sm) {
|
||||||
|
std::make_shared<PSM>()->InstallAsService(sm);
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace Service::PSM
|
15
src/core/hle/service/ptm/psm.h
Normal file
15
src/core/hle/service/ptm/psm.h
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
// Copyright 2018 yuzu emulator team
|
||||||
|
// Licensed under GPLv2 or any later version
|
||||||
|
// Refer to the license.txt file included.
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
namespace Service::SM {
|
||||||
|
class ServiceManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace Service::PSM {
|
||||||
|
|
||||||
|
void InstallInterfaces(SM::ServiceManager& sm);
|
||||||
|
|
||||||
|
} // namespace Service::PSM
|
|
@ -58,6 +58,7 @@
|
||||||
#include "core/hle/service/pm/pm.h"
|
#include "core/hle/service/pm/pm.h"
|
||||||
#include "core/hle/service/prepo/prepo.h"
|
#include "core/hle/service/prepo/prepo.h"
|
||||||
#include "core/hle/service/psc/psc.h"
|
#include "core/hle/service/psc/psc.h"
|
||||||
|
#include "core/hle/service/ptm/psm.h"
|
||||||
#include "core/hle/service/service.h"
|
#include "core/hle/service/service.h"
|
||||||
#include "core/hle/service/set/settings.h"
|
#include "core/hle/service/set/settings.h"
|
||||||
#include "core/hle/service/sm/sm.h"
|
#include "core/hle/service/sm/sm.h"
|
||||||
|
@ -246,6 +247,7 @@ void Init(std::shared_ptr<SM::ServiceManager>& sm, FileSys::VfsFilesystem& vfs)
|
||||||
PlayReport::InstallInterfaces(*sm);
|
PlayReport::InstallInterfaces(*sm);
|
||||||
PM::InstallInterfaces(*sm);
|
PM::InstallInterfaces(*sm);
|
||||||
PSC::InstallInterfaces(*sm);
|
PSC::InstallInterfaces(*sm);
|
||||||
|
PSM::InstallInterfaces(*sm);
|
||||||
Set::InstallInterfaces(*sm);
|
Set::InstallInterfaces(*sm);
|
||||||
Sockets::InstallInterfaces(*sm);
|
Sockets::InstallInterfaces(*sm);
|
||||||
SPL::InstallInterfaces(*sm);
|
SPL::InstallInterfaces(*sm);
|
||||||
|
|
Loading…
Reference in a new issue