|
|
@ -13,12 +13,54 @@ void InstallInterfaces(SM::ServiceManager& service_manager) {
|
|
|
|
std::make_shared<APM>()->InstallAsService(service_manager);
|
|
|
|
std::make_shared<APM>()->InstallAsService(service_manager);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class ISession final : public ServiceFramework<ISession> {
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
ISession() : ServiceFramework("ISession") {
|
|
|
|
|
|
|
|
static const FunctionInfo functions[] = {
|
|
|
|
|
|
|
|
{0, &ISession::SetPerformanceConfiguration, "SetPerformanceConfiguration"},
|
|
|
|
|
|
|
|
{1, &ISession::GetPerformanceConfiguration, "GetPerformanceConfiguration"},
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
RegisterHandlers(functions);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
void SetPerformanceConfiguration(Kernel::HLERequestContext& ctx) {
|
|
|
|
|
|
|
|
IPC::RequestParser rp{ctx};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
auto mode = static_cast<PerformanceMode>(rp.Pop<u32>());
|
|
|
|
|
|
|
|
u32 config = rp.Pop<u32>();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
IPC::RequestBuilder rb{ctx, 2};
|
|
|
|
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
LOG_WARNING(Service, "(STUBBED) called mode=%u config=%u", static_cast<u32>(mode), config);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void GetPerformanceConfiguration(Kernel::HLERequestContext& ctx) {
|
|
|
|
|
|
|
|
IPC::RequestParser rp{ctx};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
auto mode = static_cast<PerformanceMode>(rp.Pop<u32>());
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
IPC::RequestBuilder rb{ctx, 3};
|
|
|
|
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
|
|
|
|
rb.Push<u32>(0); // Performance configuration
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
LOG_WARNING(Service, "(STUBBED) called mode=%u", static_cast<u32>(mode));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
APM::APM() : ServiceFramework("apm") {
|
|
|
|
APM::APM() : ServiceFramework("apm") {
|
|
|
|
static const FunctionInfo functions[] = {
|
|
|
|
static const FunctionInfo functions[] = {
|
|
|
|
{0x00000000, nullptr, "OpenSession"}, {0x00000001, nullptr, "GetPerformanceMode"},
|
|
|
|
{0x00000000, &APM::OpenSession, "OpenSession"}, {0x00000001, nullptr, "GetPerformanceMode"},
|
|
|
|
};
|
|
|
|
};
|
|
|
|
RegisterHandlers(functions);
|
|
|
|
RegisterHandlers(functions);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void APM::OpenSession(Kernel::HLERequestContext& ctx) {
|
|
|
|
|
|
|
|
IPC::RequestBuilder rb{ctx, 2, 0, 0, 1};
|
|
|
|
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
|
|
|
|
rb.PushIpcInterface<ISession>();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
} // namespace APM
|
|
|
|
} // namespace APM
|
|
|
|
} // namespace Service
|
|
|
|
} // namespace Service
|
|
|
|