mirror of
https://git.suyu.dev/suyu/suyu.git
synced 2025-01-09 17:21:01 +01:00
service: ptm: Rewrite PSM and add TS
This commit is contained in:
parent
01bc0c84f0
commit
c0264d2121
10 changed files with 189 additions and 90 deletions
|
@ -128,7 +128,7 @@ bool ParseFilterRule(Filter& instance, Iterator begin, Iterator end) {
|
||||||
SUB(Service, PM) \
|
SUB(Service, PM) \
|
||||||
SUB(Service, PREPO) \
|
SUB(Service, PREPO) \
|
||||||
SUB(Service, PSC) \
|
SUB(Service, PSC) \
|
||||||
SUB(Service, PSM) \
|
SUB(Service, PTM) \
|
||||||
SUB(Service, SET) \
|
SUB(Service, SET) \
|
||||||
SUB(Service, SM) \
|
SUB(Service, SM) \
|
||||||
SUB(Service, SPL) \
|
SUB(Service, SPL) \
|
||||||
|
|
|
@ -95,7 +95,7 @@ enum class Class : u8 {
|
||||||
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_PTM, ///< The PTM 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
|
||||||
|
|
|
@ -605,6 +605,10 @@ add_library(core STATIC
|
||||||
hle/service/psc/psc.h
|
hle/service/psc/psc.h
|
||||||
hle/service/ptm/psm.cpp
|
hle/service/ptm/psm.cpp
|
||||||
hle/service/ptm/psm.h
|
hle/service/ptm/psm.h
|
||||||
|
hle/service/ptm/ptm.cpp
|
||||||
|
hle/service/ptm/ptm.h
|
||||||
|
hle/service/ptm/ts.cpp
|
||||||
|
hle/service/ptm/ts.h
|
||||||
hle/service/kernel_helpers.cpp
|
hle/service/kernel_helpers.cpp
|
||||||
hle/service/kernel_helpers.h
|
hle/service/kernel_helpers.h
|
||||||
hle/service/service.cpp
|
hle/service/service.cpp
|
||||||
|
|
|
@ -9,10 +9,8 @@
|
||||||
#include "core/hle/kernel/k_event.h"
|
#include "core/hle/kernel/k_event.h"
|
||||||
#include "core/hle/service/kernel_helpers.h"
|
#include "core/hle/service/kernel_helpers.h"
|
||||||
#include "core/hle/service/ptm/psm.h"
|
#include "core/hle/service/ptm/psm.h"
|
||||||
#include "core/hle/service/service.h"
|
|
||||||
#include "core/hle/service/sm/sm.h"
|
|
||||||
|
|
||||||
namespace Service::PSM {
|
namespace Service::PTM {
|
||||||
|
|
||||||
class IPsmSession final : public ServiceFramework<IPsmSession> {
|
class IPsmSession final : public ServiceFramework<IPsmSession> {
|
||||||
public:
|
public:
|
||||||
|
@ -57,7 +55,7 @@ public:
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void BindStateChangeEvent(Kernel::HLERequestContext& ctx) {
|
void BindStateChangeEvent(Kernel::HLERequestContext& ctx) {
|
||||||
LOG_DEBUG(Service_PSM, "called");
|
LOG_DEBUG(Service_PTM, "called");
|
||||||
|
|
||||||
should_signal = true;
|
should_signal = true;
|
||||||
|
|
||||||
|
@ -67,7 +65,7 @@ private:
|
||||||
}
|
}
|
||||||
|
|
||||||
void UnbindStateChangeEvent(Kernel::HLERequestContext& ctx) {
|
void UnbindStateChangeEvent(Kernel::HLERequestContext& ctx) {
|
||||||
LOG_DEBUG(Service_PSM, "called");
|
LOG_DEBUG(Service_PTM, "called");
|
||||||
|
|
||||||
should_signal = false;
|
should_signal = false;
|
||||||
|
|
||||||
|
@ -78,7 +76,7 @@ private:
|
||||||
void SetChargerTypeChangeEventEnabled(Kernel::HLERequestContext& ctx) {
|
void SetChargerTypeChangeEventEnabled(Kernel::HLERequestContext& ctx) {
|
||||||
IPC::RequestParser rp{ctx};
|
IPC::RequestParser rp{ctx};
|
||||||
const auto state = rp.Pop<bool>();
|
const auto state = rp.Pop<bool>();
|
||||||
LOG_DEBUG(Service_PSM, "called, state={}", state);
|
LOG_DEBUG(Service_PTM, "called, state={}", state);
|
||||||
|
|
||||||
should_signal_charger_type = state;
|
should_signal_charger_type = state;
|
||||||
|
|
||||||
|
@ -89,7 +87,7 @@ private:
|
||||||
void SetPowerSupplyChangeEventEnabled(Kernel::HLERequestContext& ctx) {
|
void SetPowerSupplyChangeEventEnabled(Kernel::HLERequestContext& ctx) {
|
||||||
IPC::RequestParser rp{ctx};
|
IPC::RequestParser rp{ctx};
|
||||||
const auto state = rp.Pop<bool>();
|
const auto state = rp.Pop<bool>();
|
||||||
LOG_DEBUG(Service_PSM, "called, state={}", state);
|
LOG_DEBUG(Service_PTM, "called, state={}", state);
|
||||||
|
|
||||||
should_signal_power_supply = state;
|
should_signal_power_supply = state;
|
||||||
|
|
||||||
|
@ -100,7 +98,7 @@ private:
|
||||||
void SetBatteryVoltageStateChangeEventEnabled(Kernel::HLERequestContext& ctx) {
|
void SetBatteryVoltageStateChangeEventEnabled(Kernel::HLERequestContext& ctx) {
|
||||||
IPC::RequestParser rp{ctx};
|
IPC::RequestParser rp{ctx};
|
||||||
const auto state = rp.Pop<bool>();
|
const auto state = rp.Pop<bool>();
|
||||||
LOG_DEBUG(Service_PSM, "called, state={}", state);
|
LOG_DEBUG(Service_PTM, "called, state={}", state);
|
||||||
|
|
||||||
should_signal_battery_voltage = state;
|
should_signal_battery_voltage = state;
|
||||||
|
|
||||||
|
@ -117,76 +115,58 @@ private:
|
||||||
Kernel::KEvent* state_change_event;
|
Kernel::KEvent* state_change_event;
|
||||||
};
|
};
|
||||||
|
|
||||||
class PSM final : public ServiceFramework<PSM> {
|
PSM::PSM(Core::System& system_) : ServiceFramework{system_, "psm"} {
|
||||||
public:
|
// clang-format off
|
||||||
explicit PSM(Core::System& system_) : ServiceFramework{system_, "psm"} {
|
static const FunctionInfo functions[] = {
|
||||||
// clang-format off
|
{0, &PSM::GetBatteryChargePercentage, "GetBatteryChargePercentage"},
|
||||||
static const FunctionInfo functions[] = {
|
{1, &PSM::GetChargerType, "GetChargerType"},
|
||||||
{0, &PSM::GetBatteryChargePercentage, "GetBatteryChargePercentage"},
|
{2, nullptr, "EnableBatteryCharging"},
|
||||||
{1, &PSM::GetChargerType, "GetChargerType"},
|
{3, nullptr, "DisableBatteryCharging"},
|
||||||
{2, nullptr, "EnableBatteryCharging"},
|
{4, nullptr, "IsBatteryChargingEnabled"},
|
||||||
{3, nullptr, "DisableBatteryCharging"},
|
{5, nullptr, "AcquireControllerPowerSupply"},
|
||||||
{4, nullptr, "IsBatteryChargingEnabled"},
|
{6, nullptr, "ReleaseControllerPowerSupply"},
|
||||||
{5, nullptr, "AcquireControllerPowerSupply"},
|
{7, &PSM::OpenSession, "OpenSession"},
|
||||||
{6, nullptr, "ReleaseControllerPowerSupply"},
|
{8, nullptr, "EnableEnoughPowerChargeEmulation"},
|
||||||
{7, &PSM::OpenSession, "OpenSession"},
|
{9, nullptr, "DisableEnoughPowerChargeEmulation"},
|
||||||
{8, nullptr, "EnableEnoughPowerChargeEmulation"},
|
{10, nullptr, "EnableFastBatteryCharging"},
|
||||||
{9, nullptr, "DisableEnoughPowerChargeEmulation"},
|
{11, nullptr, "DisableFastBatteryCharging"},
|
||||||
{10, nullptr, "EnableFastBatteryCharging"},
|
{12, nullptr, "GetBatteryVoltageState"},
|
||||||
{11, nullptr, "DisableFastBatteryCharging"},
|
{13, nullptr, "GetRawBatteryChargePercentage"},
|
||||||
{12, nullptr, "GetBatteryVoltageState"},
|
{14, nullptr, "IsEnoughPowerSupplied"},
|
||||||
{13, nullptr, "GetRawBatteryChargePercentage"},
|
{15, nullptr, "GetBatteryAgePercentage"},
|
||||||
{14, nullptr, "IsEnoughPowerSupplied"},
|
{16, nullptr, "GetBatteryChargeInfoEvent"},
|
||||||
{15, nullptr, "GetBatteryAgePercentage"},
|
{17, nullptr, "GetBatteryChargeInfoFields"},
|
||||||
{16, nullptr, "GetBatteryChargeInfoEvent"},
|
{18, nullptr, "GetBatteryChargeCalibratedEvent"},
|
||||||
{17, nullptr, "GetBatteryChargeInfoFields"},
|
|
||||||
{18, nullptr, "GetBatteryChargeCalibratedEvent"},
|
|
||||||
};
|
|
||||||
// clang-format on
|
|
||||||
|
|
||||||
RegisterHandlers(functions);
|
|
||||||
}
|
|
||||||
|
|
||||||
~PSM() override = default;
|
|
||||||
|
|
||||||
private:
|
|
||||||
void GetBatteryChargePercentage(Kernel::HLERequestContext& ctx) {
|
|
||||||
LOG_DEBUG(Service_PSM, "called");
|
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 3};
|
|
||||||
rb.Push(ResultSuccess);
|
|
||||||
rb.Push<u32>(battery_charge_percentage);
|
|
||||||
}
|
|
||||||
|
|
||||||
void GetChargerType(Kernel::HLERequestContext& ctx) {
|
|
||||||
LOG_DEBUG(Service_PSM, "called");
|
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 3};
|
|
||||||
rb.Push(ResultSuccess);
|
|
||||||
rb.PushEnum(charger_type);
|
|
||||||
}
|
|
||||||
|
|
||||||
void OpenSession(Kernel::HLERequestContext& ctx) {
|
|
||||||
LOG_DEBUG(Service_PSM, "called");
|
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 2, 0, 1};
|
|
||||||
rb.Push(ResultSuccess);
|
|
||||||
rb.PushIpcInterface<IPsmSession>(system);
|
|
||||||
}
|
|
||||||
|
|
||||||
enum class ChargerType : u32 {
|
|
||||||
Unplugged = 0,
|
|
||||||
RegularCharger = 1,
|
|
||||||
LowPowerCharger = 2,
|
|
||||||
Unknown = 3,
|
|
||||||
};
|
};
|
||||||
|
// clang-format on
|
||||||
|
|
||||||
u32 battery_charge_percentage{100}; // 100%
|
RegisterHandlers(functions);
|
||||||
ChargerType charger_type{ChargerType::RegularCharger};
|
|
||||||
};
|
|
||||||
|
|
||||||
void InstallInterfaces(SM::ServiceManager& sm, Core::System& system) {
|
|
||||||
std::make_shared<PSM>(system)->InstallAsService(sm);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace Service::PSM
|
PSM::~PSM() = default;
|
||||||
|
|
||||||
|
void PSM::GetBatteryChargePercentage(Kernel::HLERequestContext& ctx) {
|
||||||
|
LOG_DEBUG(Service_PTM, "called");
|
||||||
|
|
||||||
|
IPC::ResponseBuilder rb{ctx, 3};
|
||||||
|
rb.Push(ResultSuccess);
|
||||||
|
rb.Push<u32>(battery_charge_percentage);
|
||||||
|
}
|
||||||
|
|
||||||
|
void PSM::GetChargerType(Kernel::HLERequestContext& ctx) {
|
||||||
|
LOG_DEBUG(Service_PTM, "called");
|
||||||
|
|
||||||
|
IPC::ResponseBuilder rb{ctx, 3};
|
||||||
|
rb.Push(ResultSuccess);
|
||||||
|
rb.PushEnum(charger_type);
|
||||||
|
}
|
||||||
|
|
||||||
|
void PSM::OpenSession(Kernel::HLERequestContext& ctx) {
|
||||||
|
LOG_DEBUG(Service_PTM, "called");
|
||||||
|
|
||||||
|
IPC::ResponseBuilder rb{ctx, 2, 0, 1};
|
||||||
|
rb.Push(ResultSuccess);
|
||||||
|
rb.PushIpcInterface<IPsmSession>(system);
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace Service::PTM
|
||||||
|
|
|
@ -3,16 +3,29 @@
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
namespace Core {
|
#include "core/hle/service/service.h"
|
||||||
class System;
|
|
||||||
}
|
|
||||||
|
|
||||||
namespace Service::SM {
|
namespace Service::PTM {
|
||||||
class ServiceManager;
|
|
||||||
}
|
|
||||||
|
|
||||||
namespace Service::PSM {
|
class PSM final : public ServiceFramework<PSM> {
|
||||||
|
public:
|
||||||
|
explicit PSM(Core::System& system_);
|
||||||
|
~PSM() override;
|
||||||
|
|
||||||
void InstallInterfaces(SM::ServiceManager& sm, Core::System& system);
|
private:
|
||||||
|
enum class ChargerType : u32 {
|
||||||
|
Unplugged = 0,
|
||||||
|
RegularCharger = 1,
|
||||||
|
LowPowerCharger = 2,
|
||||||
|
Unknown = 3,
|
||||||
|
};
|
||||||
|
|
||||||
} // namespace Service::PSM
|
void GetBatteryChargePercentage(Kernel::HLERequestContext& ctx);
|
||||||
|
void GetChargerType(Kernel::HLERequestContext& ctx);
|
||||||
|
void OpenSession(Kernel::HLERequestContext& ctx);
|
||||||
|
|
||||||
|
u32 battery_charge_percentage{100};
|
||||||
|
ChargerType charger_type{ChargerType::RegularCharger};
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace Service::PTM
|
||||||
|
|
18
src/core/hle/service/ptm/ptm.cpp
Normal file
18
src/core/hle/service/ptm/ptm.cpp
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
// SPDX-FileCopyrightText: Copyright 2022 yuzu Emulator Project
|
||||||
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
|
#include "core/core.h"
|
||||||
|
#include "core/hle/service/ptm/psm.h"
|
||||||
|
#include "core/hle/service/ptm/ptm.h"
|
||||||
|
#include "core/hle/service/ptm/ts.h"
|
||||||
|
|
||||||
|
namespace Service::PTM {
|
||||||
|
|
||||||
|
void InstallInterfaces(SM::ServiceManager& sm, Core::System& system) {
|
||||||
|
std::make_shared<PSM>(system)->InstallAsService(sm);
|
||||||
|
std::make_shared<TS>(system)->InstallAsService(sm);
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace Service::PTM
|
18
src/core/hle/service/ptm/ptm.h
Normal file
18
src/core/hle/service/ptm/ptm.h
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
// SPDX-FileCopyrightText: Copyright 2022 yuzu Emulator Project
|
||||||
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
namespace Core {
|
||||||
|
class System;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace Service::SM {
|
||||||
|
class ServiceManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace Service::PTM {
|
||||||
|
|
||||||
|
void InstallInterfaces(SM::ServiceManager& sm, Core::System& system);
|
||||||
|
|
||||||
|
} // namespace Service::PTM
|
41
src/core/hle/service/ptm/ts.cpp
Normal file
41
src/core/hle/service/ptm/ts.cpp
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
// SPDX-FileCopyrightText: Copyright 2022 yuzu Emulator Project
|
||||||
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
|
#include "core/core.h"
|
||||||
|
#include "core/hle/ipc_helpers.h"
|
||||||
|
#include "core/hle/service/ptm/ts.h"
|
||||||
|
|
||||||
|
namespace Service::PTM {
|
||||||
|
|
||||||
|
TS::TS(Core::System& system_) : ServiceFramework{system_, "ts"} {
|
||||||
|
// clang-format off
|
||||||
|
static const FunctionInfo functions[] = {
|
||||||
|
{0, nullptr, "GetTemperatureRange"},
|
||||||
|
{1, &TS::GetTemperature, "GetTemperature"},
|
||||||
|
{2, nullptr, "SetMeasurementMode"},
|
||||||
|
{3, nullptr, "GetTemperatureMilliC"},
|
||||||
|
{4, nullptr, "OpenSession"},
|
||||||
|
};
|
||||||
|
// clang-format on
|
||||||
|
|
||||||
|
RegisterHandlers(functions);
|
||||||
|
}
|
||||||
|
|
||||||
|
TS::~TS() = default;
|
||||||
|
|
||||||
|
void TS::GetTemperature(Kernel::HLERequestContext& ctx) {
|
||||||
|
IPC::RequestParser rp{ctx};
|
||||||
|
const auto location{rp.PopEnum<Location>()};
|
||||||
|
|
||||||
|
LOG_WARNING(Service_HID, "(STUBBED) called. location={}", location);
|
||||||
|
|
||||||
|
const s32 temperature = location == Location::Internal ? 35 : 20;
|
||||||
|
|
||||||
|
IPC::ResponseBuilder rb{ctx, 3};
|
||||||
|
rb.Push(ResultSuccess);
|
||||||
|
rb.Push(temperature);
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace Service::PTM
|
25
src/core/hle/service/ptm/ts.h
Normal file
25
src/core/hle/service/ptm/ts.h
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
// SPDX-FileCopyrightText: Copyright 2022 yuzu Emulator Project
|
||||||
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "common/common_types.h"
|
||||||
|
#include "core/hle/service/service.h"
|
||||||
|
|
||||||
|
namespace Service::PTM {
|
||||||
|
|
||||||
|
class TS final : public ServiceFramework<TS> {
|
||||||
|
public:
|
||||||
|
explicit TS(Core::System& system_);
|
||||||
|
~TS() override;
|
||||||
|
|
||||||
|
private:
|
||||||
|
enum class Location : u8 {
|
||||||
|
Internal,
|
||||||
|
External,
|
||||||
|
};
|
||||||
|
|
||||||
|
void GetTemperature(Kernel::HLERequestContext& ctx);
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace Service::PTM
|
|
@ -58,7 +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/ptm/ptm.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"
|
||||||
|
@ -287,7 +287,7 @@ Services::Services(std::shared_ptr<SM::ServiceManager>& sm, Core::System& system
|
||||||
PlayReport::InstallInterfaces(*sm, system);
|
PlayReport::InstallInterfaces(*sm, system);
|
||||||
PM::InstallInterfaces(system);
|
PM::InstallInterfaces(system);
|
||||||
PSC::InstallInterfaces(*sm, system);
|
PSC::InstallInterfaces(*sm, system);
|
||||||
PSM::InstallInterfaces(*sm, system);
|
PTM::InstallInterfaces(*sm, system);
|
||||||
Set::InstallInterfaces(*sm, system);
|
Set::InstallInterfaces(*sm, system);
|
||||||
Sockets::InstallInterfaces(*sm, system);
|
Sockets::InstallInterfaces(*sm, system);
|
||||||
SPL::InstallInterfaces(*sm, system);
|
SPL::InstallInterfaces(*sm, system);
|
||||||
|
|
Loading…
Reference in a new issue