mirror of
https://github.com/skyline-emu/skyline.git
synced 2025-01-15 05:57:54 +03:00
Rework service API to be cleaner with significantly less boilerplate
This patch reduces the burden of adding services significantly, rather than having to create an enum entry and add strings in the constructor it will all be determined at runtime through RTTI. A macro is also used in the service creation case to reduce clutter.
This commit is contained in:
parent
21e2c826a1
commit
74a150dff1
@ -588,7 +588,7 @@ namespace skyline::kernel::svc {
|
|||||||
|
|
||||||
KHandle handle{};
|
KHandle handle{};
|
||||||
if (port.compare("sm:") >= 0) {
|
if (port.compare("sm:") >= 0) {
|
||||||
handle = state.os->serviceManager.NewSession(service::Service::sm_IUserInterface);
|
handle = state.process->NewHandle<type::KSession>(std::static_pointer_cast<service::BaseService>(state.os->serviceManager.smUserInterface)).handle;
|
||||||
} else {
|
} else {
|
||||||
state.logger->Warn("svcConnectToNamedPort: Connecting to invalid port: '{}'", port);
|
state.logger->Warn("svcConnectToNamedPort: Connecting to invalid port: '{}'", port);
|
||||||
state.ctx->registers.w0 = constant::status::NotFound;
|
state.ctx->registers.w0 = constant::status::NotFound;
|
||||||
|
@ -16,7 +16,6 @@ namespace skyline::kernel::type {
|
|||||||
std::shared_ptr<service::BaseService> serviceObject; //!< A shared pointer to the service class
|
std::shared_ptr<service::BaseService> serviceObject; //!< A shared pointer to the service class
|
||||||
std::unordered_map<KHandle, std::shared_ptr<service::BaseService>> domainTable; //!< This maps from a virtual handle to it's service
|
std::unordered_map<KHandle, std::shared_ptr<service::BaseService>> domainTable; //!< This maps from a virtual handle to it's service
|
||||||
KHandle handleIndex{0x1}; //!< The currently allocated handle index
|
KHandle handleIndex{0x1}; //!< The currently allocated handle index
|
||||||
service::Service serviceType; //!< The type of the service
|
|
||||||
enum class ServiceStatus { Open, Closed } serviceStatus{ServiceStatus::Open}; //!< If the session is open or closed
|
enum class ServiceStatus { Open, Closed } serviceStatus{ServiceStatus::Open}; //!< If the session is open or closed
|
||||||
bool isDomain{}; //!< Holds if this is a domain session or not
|
bool isDomain{}; //!< Holds if this is a domain session or not
|
||||||
|
|
||||||
@ -24,7 +23,7 @@ namespace skyline::kernel::type {
|
|||||||
* @param state The state of the device
|
* @param state The state of the device
|
||||||
* @param serviceObject A shared pointer to the service class
|
* @param serviceObject A shared pointer to the service class
|
||||||
*/
|
*/
|
||||||
KSession(const DeviceState &state, std::shared_ptr<service::BaseService> &serviceObject) : serviceObject(serviceObject), serviceType(serviceObject->serviceType), KSyncObject(state, KType::KSession) {}
|
KSession(const DeviceState &state, std::shared_ptr<service::BaseService> &serviceObject) : serviceObject(serviceObject), KSyncObject(state, KType::KSession) {}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This converts this session into a domain session (https://switchbrew.org/wiki/IPC_Marshalling#Domains)
|
* This converts this session into a domain session (https://switchbrew.org/wiki/IPC_Marshalling#Domains)
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
#include "IAccountServiceForApplication.h"
|
#include "IAccountServiceForApplication.h"
|
||||||
|
|
||||||
namespace skyline::service::account {
|
namespace skyline::service::account {
|
||||||
IAccountServiceForApplication::IAccountServiceForApplication(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::account_IAccountServiceForApplication, "account:IAccountServiceForApplication", {
|
IAccountServiceForApplication::IAccountServiceForApplication(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x1, SFUNC(IAccountServiceForApplication::GetUserExistence)},
|
{0x1, SFUNC(IAccountServiceForApplication::GetUserExistence)},
|
||||||
{0x2, SFUNC(IAccountServiceForApplication::ListAllUsers)},
|
{0x2, SFUNC(IAccountServiceForApplication::ListAllUsers)},
|
||||||
{0x3, SFUNC(IAccountServiceForApplication::ListOpenUsers)},
|
{0x3, SFUNC(IAccountServiceForApplication::ListOpenUsers)},
|
||||||
|
@ -4,6 +4,6 @@
|
|||||||
#include "IManagerForApplication.h"
|
#include "IManagerForApplication.h"
|
||||||
|
|
||||||
namespace skyline::service::account {
|
namespace skyline::service::account {
|
||||||
IManagerForApplication::IManagerForApplication(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::account_IManagerForApplication, "account:IManagerForApplication", {
|
IManagerForApplication::IManagerForApplication(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
}) {}
|
}) {}
|
||||||
}
|
}
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "IProfile.h"
|
#include "IProfile.h"
|
||||||
|
|
||||||
namespace skyline::service::account {
|
namespace skyline::service::account {
|
||||||
IProfile::IProfile(const DeviceState &state, ServiceManager &manager, const UserId &userId) : userId(userId), BaseService(state, manager, Service::account_IProfile, "account:IProfile", {
|
IProfile::IProfile(const DeviceState &state, ServiceManager &manager, const UserId &userId) : userId(userId), BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IProfile::Get)},
|
{0x0, SFUNC(IProfile::Get)},
|
||||||
{0x1, SFUNC(IProfile::GetBase)}
|
{0x1, SFUNC(IProfile::GetBase)}
|
||||||
}) {}
|
}) {}
|
||||||
|
@ -8,7 +8,7 @@
|
|||||||
#include "IAllSystemAppletProxiesService.h"
|
#include "IAllSystemAppletProxiesService.h"
|
||||||
|
|
||||||
namespace skyline::service::am {
|
namespace skyline::service::am {
|
||||||
IAllSystemAppletProxiesService::IAllSystemAppletProxiesService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::am_IAllSystemAppletProxiesService, "am:IAllSystemAppletProxiesService", {
|
IAllSystemAppletProxiesService::IAllSystemAppletProxiesService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x64, SFUNC(IAllSystemAppletProxiesService::OpenSystemAppletProxy)},
|
{0x64, SFUNC(IAllSystemAppletProxiesService::OpenSystemAppletProxy)},
|
||||||
{0xC8, SFUNC(IAllSystemAppletProxiesService::OpenLibraryAppletProxy)},
|
{0xC8, SFUNC(IAllSystemAppletProxiesService::OpenLibraryAppletProxy)},
|
||||||
{0xC9, SFUNC(IAllSystemAppletProxiesService::OpenLibraryAppletProxy)},
|
{0xC9, SFUNC(IAllSystemAppletProxiesService::OpenLibraryAppletProxy)},
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "IApplicationProxyService.h"
|
#include "IApplicationProxyService.h"
|
||||||
|
|
||||||
namespace skyline::service::am {
|
namespace skyline::service::am {
|
||||||
IApplicationProxyService::IApplicationProxyService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::am_IApplicationProxyService, "am:IApplicationProxyService", {
|
IApplicationProxyService::IApplicationProxyService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IApplicationProxyService::OpenApplicationProxy)}
|
{0x0, SFUNC(IApplicationProxyService::OpenApplicationProxy)}
|
||||||
}) {}
|
}) {}
|
||||||
|
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
#include "ILibraryAppletAccessor.h"
|
#include "ILibraryAppletAccessor.h"
|
||||||
|
|
||||||
namespace skyline::service::am {
|
namespace skyline::service::am {
|
||||||
ILibraryAppletAccessor::ILibraryAppletAccessor(const DeviceState &state, ServiceManager &manager) : stateChangeEvent(std::make_shared<type::KEvent>(state)), BaseService(state, manager, Service::am_ILibraryAppletAccessor, "am:ILibraryAppletAccessor", {
|
ILibraryAppletAccessor::ILibraryAppletAccessor(const DeviceState &state, ServiceManager &manager) : stateChangeEvent(std::make_shared<type::KEvent>(state)), BaseService(state, manager, {
|
||||||
{0x0, SFUNC(ILibraryAppletAccessor::GetAppletStateChangedEvent)},
|
{0x0, SFUNC(ILibraryAppletAccessor::GetAppletStateChangedEvent)},
|
||||||
{0xA, SFUNC(ILibraryAppletAccessor::Start)},
|
{0xA, SFUNC(ILibraryAppletAccessor::Start)},
|
||||||
{0x1E, SFUNC(ILibraryAppletAccessor::GetResult)},
|
{0x1E, SFUNC(ILibraryAppletAccessor::GetResult)},
|
||||||
|
@ -4,6 +4,6 @@
|
|||||||
#include "IAppletCommonFunctions.h"
|
#include "IAppletCommonFunctions.h"
|
||||||
|
|
||||||
namespace skyline::service::am {
|
namespace skyline::service::am {
|
||||||
IAppletCommonFunctions::IAppletCommonFunctions(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::am_IAppletCommonFunctions, "am:IAppletCommonFunctions", {
|
IAppletCommonFunctions::IAppletCommonFunctions(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
}) {}
|
}) {}
|
||||||
}
|
}
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
#include "IApplicationFunctions.h"
|
#include "IApplicationFunctions.h"
|
||||||
|
|
||||||
namespace skyline::service::am {
|
namespace skyline::service::am {
|
||||||
IApplicationFunctions::IApplicationFunctions(const DeviceState &state, ServiceManager &manager) : gpuErrorEvent(std::make_shared<type::KEvent>(state)), BaseService(state, manager, Service::am_IApplicationFunctions, "am:IApplicationFunctions", {
|
IApplicationFunctions::IApplicationFunctions(const DeviceState &state, ServiceManager &manager) : gpuErrorEvent(std::make_shared<type::KEvent>(state)), BaseService(state, manager, {
|
||||||
{0x1, SFUNC(IApplicationFunctions::PopLaunchParameter)},
|
{0x1, SFUNC(IApplicationFunctions::PopLaunchParameter)},
|
||||||
{0x14, SFUNC(IApplicationFunctions::EnsureSaveData)},
|
{0x14, SFUNC(IApplicationFunctions::EnsureSaveData)},
|
||||||
{0x15, SFUNC(IApplicationFunctions::GetDesiredLanguage)},
|
{0x15, SFUNC(IApplicationFunctions::GetDesiredLanguage)},
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
#include "IAudioController.h"
|
#include "IAudioController.h"
|
||||||
|
|
||||||
namespace skyline::service::am {
|
namespace skyline::service::am {
|
||||||
IAudioController::IAudioController(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::am_IAudioController, "am:IAudioController", {
|
IAudioController::IAudioController(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IAudioController::SetExpectedMasterVolume)},
|
{0x0, SFUNC(IAudioController::SetExpectedMasterVolume)},
|
||||||
{0x1, SFUNC(IAudioController::GetMainAppletExpectedMasterVolume)},
|
{0x1, SFUNC(IAudioController::GetMainAppletExpectedMasterVolume)},
|
||||||
{0x2, SFUNC(IAudioController::GetLibraryAppletExpectedMasterVolume)}
|
{0x2, SFUNC(IAudioController::GetLibraryAppletExpectedMasterVolume)}
|
||||||
|
@ -10,7 +10,7 @@ namespace skyline::service::am {
|
|||||||
messageEvent->Signal();
|
messageEvent->Signal();
|
||||||
}
|
}
|
||||||
|
|
||||||
ICommonStateGetter::ICommonStateGetter(const DeviceState &state, ServiceManager &manager) : messageEvent(std::make_shared<type::KEvent>(state)), BaseService(state, manager, Service::am_ICommonStateGetter, "am:ICommonStateGetter", {
|
ICommonStateGetter::ICommonStateGetter(const DeviceState &state, ServiceManager &manager) : messageEvent(std::make_shared<type::KEvent>(state)), BaseService(state, manager, {
|
||||||
{0x0, SFUNC(ICommonStateGetter::GetEventHandle)},
|
{0x0, SFUNC(ICommonStateGetter::GetEventHandle)},
|
||||||
{0x1, SFUNC(ICommonStateGetter::ReceiveMessage)},
|
{0x1, SFUNC(ICommonStateGetter::ReceiveMessage)},
|
||||||
{0x5, SFUNC(ICommonStateGetter::GetOperationMode)},
|
{0x5, SFUNC(ICommonStateGetter::GetOperationMode)},
|
||||||
|
@ -4,6 +4,6 @@
|
|||||||
#include "IDebugFunctions.h"
|
#include "IDebugFunctions.h"
|
||||||
|
|
||||||
namespace skyline::service::am {
|
namespace skyline::service::am {
|
||||||
IDebugFunctions::IDebugFunctions(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::am_IDebugFunctions, "am:IDebugFunctions", {
|
IDebugFunctions::IDebugFunctions(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
}) {}
|
}) {}
|
||||||
}
|
}
|
||||||
|
@ -4,6 +4,6 @@
|
|||||||
#include "IDisplayController.h"
|
#include "IDisplayController.h"
|
||||||
|
|
||||||
namespace skyline::service::am {
|
namespace skyline::service::am {
|
||||||
IDisplayController::IDisplayController(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::am_IDisplayController, "am:IDisplayController", {
|
IDisplayController::IDisplayController(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
}) {}
|
}) {}
|
||||||
}
|
}
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
#include "ILibraryAppletCreator.h"
|
#include "ILibraryAppletCreator.h"
|
||||||
|
|
||||||
namespace skyline::service::am {
|
namespace skyline::service::am {
|
||||||
ILibraryAppletCreator::ILibraryAppletCreator(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::am_ILibraryAppletCreator, "am:ILibraryAppletCreator", {
|
ILibraryAppletCreator::ILibraryAppletCreator(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(ILibraryAppletCreator::CreateLibraryApplet)},
|
{0x0, SFUNC(ILibraryAppletCreator::CreateLibraryApplet)},
|
||||||
{0xA, SFUNC(ILibraryAppletCreator::CreateStorage)}
|
{0xA, SFUNC(ILibraryAppletCreator::CreateStorage)}
|
||||||
}) {}
|
}) {}
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
#include "ISelfController.h"
|
#include "ISelfController.h"
|
||||||
|
|
||||||
namespace skyline::service::am {
|
namespace skyline::service::am {
|
||||||
ISelfController::ISelfController(const DeviceState &state, ServiceManager &manager) : libraryAppletLaunchableEvent(std::make_shared<type::KEvent>(state)), accumulatedSuspendedTickChangedEvent(std::make_shared<type::KEvent>(state)), BaseService(state, manager, Service::am_ISelfController, "am:ISelfController", {
|
ISelfController::ISelfController(const DeviceState &state, ServiceManager &manager) : libraryAppletLaunchableEvent(std::make_shared<type::KEvent>(state)), accumulatedSuspendedTickChangedEvent(std::make_shared<type::KEvent>(state)), BaseService(state, manager, {
|
||||||
{0x1, SFUNC(ISelfController::LockExit)},
|
{0x1, SFUNC(ISelfController::LockExit)},
|
||||||
{0x2, SFUNC(ISelfController::UnlockExit)},
|
{0x2, SFUNC(ISelfController::UnlockExit)},
|
||||||
{0x9, SFUNC(ISelfController::GetLibraryAppletLaunchableEvent)},
|
{0x9, SFUNC(ISelfController::GetLibraryAppletLaunchableEvent)},
|
||||||
@ -46,7 +46,7 @@ namespace skyline::service::am {
|
|||||||
void ISelfController::CreateManagedDisplayLayer(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
void ISelfController::CreateManagedDisplayLayer(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
||||||
state.logger->Debug("Creating Managed Layer on Default Display");
|
state.logger->Debug("Creating Managed Layer on Default Display");
|
||||||
|
|
||||||
auto hosBinder = state.os->serviceManager.GetService<hosbinder::IHOSBinderDriver>(Service::hosbinder_IHOSBinderDriver);
|
auto hosBinder = state.os->serviceManager.GetService<hosbinder::IHOSBinderDriver>("dispdrv");
|
||||||
if (hosBinder->layerStatus != hosbinder::LayerStatus::Uninitialized)
|
if (hosBinder->layerStatus != hosbinder::LayerStatus::Uninitialized)
|
||||||
throw exception("The application is creating more than one layer");
|
throw exception("The application is creating more than one layer");
|
||||||
hosBinder->layerStatus = hosbinder::LayerStatus::Managed;
|
hosBinder->layerStatus = hosbinder::LayerStatus::Managed;
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "IWindowController.h"
|
#include "IWindowController.h"
|
||||||
|
|
||||||
namespace skyline::service::am {
|
namespace skyline::service::am {
|
||||||
IWindowController::IWindowController(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::am_IWindowController, "am:IWindowController", {
|
IWindowController::IWindowController(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x1, SFUNC(IWindowController::GetAppletResourceUserId)},
|
{0x1, SFUNC(IWindowController::GetAppletResourceUserId)},
|
||||||
{0xA, SFUNC(IWindowController::AcquireForegroundRights)}
|
{0xA, SFUNC(IWindowController::AcquireForegroundRights)}
|
||||||
}) {}
|
}) {}
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "IApplicationProxy.h"
|
#include "IApplicationProxy.h"
|
||||||
|
|
||||||
namespace skyline::service::am {
|
namespace skyline::service::am {
|
||||||
IApplicationProxy::IApplicationProxy(const DeviceState &state, ServiceManager &manager) : BaseProxy(state, manager, Service::am_IApplicationProxy, "am:IApplicationProxy", {
|
IApplicationProxy::IApplicationProxy(const DeviceState &state, ServiceManager &manager) : BaseProxy(state, manager, {
|
||||||
{0x0, SFUNC(BaseProxy::GetCommonStateGetter)},
|
{0x0, SFUNC(BaseProxy::GetCommonStateGetter)},
|
||||||
{0x1, SFUNC(BaseProxy::GetSelfController)},
|
{0x1, SFUNC(BaseProxy::GetSelfController)},
|
||||||
{0x2, SFUNC(BaseProxy::GetWindowController)},
|
{0x2, SFUNC(BaseProxy::GetWindowController)},
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
#include "ILibraryAppletProxy.h"
|
#include "ILibraryAppletProxy.h"
|
||||||
|
|
||||||
namespace skyline::service::am {
|
namespace skyline::service::am {
|
||||||
ILibraryAppletProxy::ILibraryAppletProxy(const DeviceState &state, ServiceManager &manager) : BaseProxy(state, manager, Service::am_ILibraryAppletProxy, "am:ILibraryAppletProxy", {
|
ILibraryAppletProxy::ILibraryAppletProxy(const DeviceState &state, ServiceManager &manager) : BaseProxy(state, manager, {
|
||||||
{0x0, SFUNC(BaseProxy::GetCommonStateGetter)},
|
{0x0, SFUNC(BaseProxy::GetCommonStateGetter)},
|
||||||
{0x1, SFUNC(BaseProxy::GetSelfController)},
|
{0x1, SFUNC(BaseProxy::GetSelfController)},
|
||||||
{0x2, SFUNC(BaseProxy::GetWindowController)},
|
{0x2, SFUNC(BaseProxy::GetWindowController)},
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
#include "IOverlayAppletProxy.h"
|
#include "IOverlayAppletProxy.h"
|
||||||
|
|
||||||
namespace skyline::service::am {
|
namespace skyline::service::am {
|
||||||
IOverlayAppletProxy::IOverlayAppletProxy(const DeviceState &state, ServiceManager &manager) : BaseProxy(state, manager, Service::am_IOverlayAppletProxy, "am:IOverlayAppletProxy", {
|
IOverlayAppletProxy::IOverlayAppletProxy(const DeviceState &state, ServiceManager &manager) : BaseProxy(state, manager, {
|
||||||
{0x0, SFUNC(BaseProxy::GetCommonStateGetter)},
|
{0x0, SFUNC(BaseProxy::GetCommonStateGetter)},
|
||||||
{0x1, SFUNC(BaseProxy::GetSelfController)},
|
{0x1, SFUNC(BaseProxy::GetSelfController)},
|
||||||
{0x2, SFUNC(BaseProxy::GetWindowController)},
|
{0x2, SFUNC(BaseProxy::GetWindowController)},
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
#include "ISystemAppletProxy.h"
|
#include "ISystemAppletProxy.h"
|
||||||
|
|
||||||
namespace skyline::service::am {
|
namespace skyline::service::am {
|
||||||
ISystemAppletProxy::ISystemAppletProxy(const DeviceState &state, ServiceManager &manager) : BaseProxy(state, manager, Service::am_ISystemAppletProxy, "am:ISystemAppletProxy", {
|
ISystemAppletProxy::ISystemAppletProxy(const DeviceState &state, ServiceManager &manager) : BaseProxy(state, manager, {
|
||||||
{0x0, SFUNC(BaseProxy::GetCommonStateGetter)},
|
{0x0, SFUNC(BaseProxy::GetCommonStateGetter)},
|
||||||
{0x1, SFUNC(BaseProxy::GetSelfController)},
|
{0x1, SFUNC(BaseProxy::GetSelfController)},
|
||||||
{0x2, SFUNC(BaseProxy::GetWindowController)},
|
{0x2, SFUNC(BaseProxy::GetWindowController)},
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
#include "base_proxy.h"
|
#include "base_proxy.h"
|
||||||
|
|
||||||
namespace skyline::service::am {
|
namespace skyline::service::am {
|
||||||
BaseProxy::BaseProxy(const DeviceState &state, ServiceManager &manager, const Service serviceType, const std::string &serviceName, const std::unordered_map<u32, std::function<void(type::KSession &, ipc::IpcRequest &, ipc::IpcResponse &)>> &vTable) : BaseService(state, manager, serviceType, serviceName, vTable) {}
|
BaseProxy::BaseProxy(const DeviceState &state, ServiceManager &manager, const std::unordered_map<u32, std::function<void(type::KSession &, ipc::IpcRequest &, ipc::IpcResponse &)>> &vTable) : BaseService(state, manager, vTable) {}
|
||||||
|
|
||||||
void BaseProxy::GetCommonStateGetter(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
void BaseProxy::GetCommonStateGetter(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
||||||
manager.RegisterService(SRVREG(ICommonStateGetter), session, response);
|
manager.RegisterService(SRVREG(ICommonStateGetter), session, response);
|
||||||
|
@ -12,7 +12,7 @@ namespace skyline::service::am {
|
|||||||
*/
|
*/
|
||||||
class BaseProxy : public BaseService {
|
class BaseProxy : public BaseService {
|
||||||
public:
|
public:
|
||||||
BaseProxy(const DeviceState &state, ServiceManager &manager, const Service serviceType, const std::string &serviceName, const std::unordered_map<u32, std::function<void(type::KSession & , ipc::IpcRequest & , ipc::IpcResponse & )>> &vTable);
|
BaseProxy(const DeviceState &state, ServiceManager &manager, const std::unordered_map<u32, std::function<void(type::KSession & , ipc::IpcRequest & , ipc::IpcResponse & )>> &vTable);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This returns #ICommonStateGetter (https://switchbrew.org/wiki/Applet_Manager_services#ICommonStateGetter)
|
* @brief This returns #ICommonStateGetter (https://switchbrew.org/wiki/Applet_Manager_services#ICommonStateGetter)
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "IStorage.h"
|
#include "IStorage.h"
|
||||||
|
|
||||||
namespace skyline::service::am {
|
namespace skyline::service::am {
|
||||||
IStorage::IStorage(const DeviceState &state, ServiceManager &manager, size_t size) : content(size), BaseService(state, manager, Service::am_IStorage, "am:IStorage", {
|
IStorage::IStorage(const DeviceState &state, ServiceManager &manager, size_t size) : content(size), BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IStorage::Open)}
|
{0x0, SFUNC(IStorage::Open)}
|
||||||
}) {}
|
}) {}
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
#include "IStorageAccessor.h"
|
#include "IStorageAccessor.h"
|
||||||
|
|
||||||
namespace skyline::service::am {
|
namespace skyline::service::am {
|
||||||
IStorageAccessor::IStorageAccessor(const DeviceState &state, ServiceManager &manager, std::shared_ptr<IStorage> parent) : parent(parent), BaseService(state, manager, Service::am_IStorageAccessor, "am:IStorageAccessor", {
|
IStorageAccessor::IStorageAccessor(const DeviceState &state, ServiceManager &manager, std::shared_ptr<IStorage> parent) : parent(parent), BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IStorageAccessor::GetSize)},
|
{0x0, SFUNC(IStorageAccessor::GetSize)},
|
||||||
{0xA, SFUNC(IStorageAccessor::Write)},
|
{0xA, SFUNC(IStorageAccessor::Write)},
|
||||||
{0xB, SFUNC(IStorageAccessor::Read)}
|
{0xB, SFUNC(IStorageAccessor::Read)}
|
||||||
|
@ -4,6 +4,6 @@
|
|||||||
#include "IAddOnContentManager.h"
|
#include "IAddOnContentManager.h"
|
||||||
|
|
||||||
namespace skyline::service::aocsrv {
|
namespace skyline::service::aocsrv {
|
||||||
IAddOnContentManager::IAddOnContentManager(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::aocsrv_IAddOnContentManager, "aocsrv:IAddOnContentManager", {
|
IAddOnContentManager::IAddOnContentManager(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
}) {}
|
}) {}
|
||||||
}
|
}
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "IManager.h"
|
#include "IManager.h"
|
||||||
|
|
||||||
namespace skyline::service::apm {
|
namespace skyline::service::apm {
|
||||||
IManager::IManager(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::apm_IManager, "apm:IManager", {
|
IManager::IManager(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IManager::OpenSession)}
|
{0x0, SFUNC(IManager::OpenSession)}
|
||||||
}) {}
|
}) {}
|
||||||
|
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
#include "ISession.h"
|
#include "ISession.h"
|
||||||
|
|
||||||
namespace skyline::service::apm {
|
namespace skyline::service::apm {
|
||||||
ISession::ISession(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::apm_ISession, "apm:ISession", {
|
ISession::ISession(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(ISession::SetPerformanceConfiguration)},
|
{0x0, SFUNC(ISession::SetPerformanceConfiguration)},
|
||||||
{0x1, SFUNC(ISession::GetPerformanceConfiguration)}
|
{0x1, SFUNC(ISession::GetPerformanceConfiguration)}
|
||||||
}) {}
|
}) {}
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
#include "IAudioDevice.h"
|
#include "IAudioDevice.h"
|
||||||
|
|
||||||
namespace skyline::service::audio {
|
namespace skyline::service::audio {
|
||||||
IAudioDevice::IAudioDevice(const DeviceState &state, ServiceManager &manager) : systemEvent(std::make_shared<type::KEvent>(state)), BaseService(state, manager, Service::audio_IAudioDevice, "audio:IAudioDevice", {
|
IAudioDevice::IAudioDevice(const DeviceState &state, ServiceManager &manager) : systemEvent(std::make_shared<type::KEvent>(state)), BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IAudioDevice::ListAudioDeviceName)},
|
{0x0, SFUNC(IAudioDevice::ListAudioDeviceName)},
|
||||||
{0x1, SFUNC(IAudioDevice::SetAudioDeviceOutputVolume)},
|
{0x1, SFUNC(IAudioDevice::SetAudioDeviceOutputVolume)},
|
||||||
{0x3, SFUNC(IAudioDevice::GetActiveAudioDeviceName)},
|
{0x3, SFUNC(IAudioDevice::GetActiveAudioDeviceName)},
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "IAudioOut.h"
|
#include "IAudioOut.h"
|
||||||
|
|
||||||
namespace skyline::service::audio {
|
namespace skyline::service::audio {
|
||||||
IAudioOut::IAudioOut(const DeviceState &state, ServiceManager &manager, u8 channelCount, u32 sampleRate) : sampleRate(sampleRate), channelCount(channelCount), releaseEvent(std::make_shared<type::KEvent>(state)), BaseService(state, manager, Service::audio_IAudioOut, "audio:IAudioOut", {
|
IAudioOut::IAudioOut(const DeviceState &state, ServiceManager &manager, u8 channelCount, u32 sampleRate) : sampleRate(sampleRate), channelCount(channelCount), releaseEvent(std::make_shared<type::KEvent>(state)), BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IAudioOut::GetAudioOutState)},
|
{0x0, SFUNC(IAudioOut::GetAudioOutState)},
|
||||||
{0x1, SFUNC(IAudioOut::StartAudioOut)},
|
{0x1, SFUNC(IAudioOut::StartAudioOut)},
|
||||||
{0x2, SFUNC(IAudioOut::StopAudioOut)},
|
{0x2, SFUNC(IAudioOut::StopAudioOut)},
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
#include "IAudioOut.h"
|
#include "IAudioOut.h"
|
||||||
|
|
||||||
namespace skyline::service::audio {
|
namespace skyline::service::audio {
|
||||||
IAudioOutManager::IAudioOutManager(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::audio_IAudioOutManager, "audio:IAudioOutManager", {
|
IAudioOutManager::IAudioOutManager(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IAudioOutManager::ListAudioOuts)},
|
{0x0, SFUNC(IAudioOutManager::ListAudioOuts)},
|
||||||
{0x1, SFUNC(IAudioOutManager::OpenAudioOut)},
|
{0x1, SFUNC(IAudioOutManager::OpenAudioOut)},
|
||||||
{0x2, SFUNC(IAudioOutManager::ListAudioOuts)},
|
{0x2, SFUNC(IAudioOutManager::ListAudioOuts)},
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
namespace skyline::service::audio::IAudioRenderer {
|
namespace skyline::service::audio::IAudioRenderer {
|
||||||
IAudioRenderer::IAudioRenderer(const DeviceState &state, ServiceManager &manager, AudioRendererParameters ¶meters)
|
IAudioRenderer::IAudioRenderer(const DeviceState &state, ServiceManager &manager, AudioRendererParameters ¶meters)
|
||||||
: systemEvent(std::make_shared<type::KEvent>(state)), parameters(parameters), BaseService(state, manager, Service::audio_IAudioRenderer, "audio:IAudioRenderer", {
|
: systemEvent(std::make_shared<type::KEvent>(state)), parameters(parameters), BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IAudioRenderer::GetSampleRate)},
|
{0x0, SFUNC(IAudioRenderer::GetSampleRate)},
|
||||||
{0x1, SFUNC(IAudioRenderer::GetSampleCount)},
|
{0x1, SFUNC(IAudioRenderer::GetSampleCount)},
|
||||||
{0x2, SFUNC(IAudioRenderer::GetMixBufferCount)},
|
{0x2, SFUNC(IAudioRenderer::GetMixBufferCount)},
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
#include "IAudioRendererManager.h"
|
#include "IAudioRendererManager.h"
|
||||||
|
|
||||||
namespace skyline::service::audio {
|
namespace skyline::service::audio {
|
||||||
IAudioRendererManager::IAudioRendererManager(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::audio_IAudioRendererManager, "audio:IAudioRendererManager", {
|
IAudioRendererManager::IAudioRendererManager(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IAudioRendererManager::OpenAudioRenderer)},
|
{0x0, SFUNC(IAudioRendererManager::OpenAudioRenderer)},
|
||||||
{0x1, SFUNC(IAudioRendererManager::GetAudioRendererWorkBufferSize)},
|
{0x1, SFUNC(IAudioRendererManager::GetAudioRendererWorkBufferSize)},
|
||||||
{0x2, SFUNC(IAudioRendererManager::GetAudioDeviceService)},
|
{0x2, SFUNC(IAudioRendererManager::GetAudioDeviceService)},
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <functional>
|
#include <functional>
|
||||||
|
#include <cxxabi.h>
|
||||||
#include <kernel/ipc.h>
|
#include <kernel/ipc.h>
|
||||||
#include <common.h>
|
#include <common.h>
|
||||||
|
|
||||||
@ -16,119 +17,7 @@ namespace skyline::kernel::type {
|
|||||||
|
|
||||||
namespace skyline::service {
|
namespace skyline::service {
|
||||||
using namespace kernel;
|
using namespace kernel;
|
||||||
|
using ServiceName = u64; //!< Service names are a maximum of 8 bytes so we use a u64 to reference them
|
||||||
/**
|
|
||||||
* @brief This contains an enum for every service that's present
|
|
||||||
*/
|
|
||||||
enum class Service {
|
|
||||||
sm_IUserInterface,
|
|
||||||
fatalsrv_IService,
|
|
||||||
settings_ISettingsServer,
|
|
||||||
settings_ISystemSettingsServer,
|
|
||||||
apm_IManager,
|
|
||||||
apm_ISession,
|
|
||||||
am_IAllSystemAppletProxiesService,
|
|
||||||
am_IApplicationProxyService,
|
|
||||||
am_IApplicationProxy,
|
|
||||||
am_ILibraryAppletProxy,
|
|
||||||
am_ISystemAppletProxy,
|
|
||||||
am_IOverlayAppletProxy,
|
|
||||||
am_ICommonStateGetter,
|
|
||||||
am_IApplicationFunctions,
|
|
||||||
am_ISelfController,
|
|
||||||
am_IWindowController,
|
|
||||||
am_IAudioController,
|
|
||||||
am_IDisplayController,
|
|
||||||
am_ILibraryAppletCreator,
|
|
||||||
am_ILibraryAppletAccessor,
|
|
||||||
am_IDebugFunctions,
|
|
||||||
am_IAppletCommonFunctions,
|
|
||||||
am_IStorage,
|
|
||||||
am_IStorageAccessor,
|
|
||||||
audio_IAudioOutManager,
|
|
||||||
audio_IAudioOut,
|
|
||||||
audio_IAudioRendererManager,
|
|
||||||
audio_IAudioRenderer,
|
|
||||||
audio_IAudioDevice,
|
|
||||||
hid_IHidServer,
|
|
||||||
hid_IAppletResource,
|
|
||||||
hid_IActiveVibrationDeviceList,
|
|
||||||
timesrv_IStaticService,
|
|
||||||
timesrv_ISystemClock,
|
|
||||||
timesrv_ITimeZoneService,
|
|
||||||
timesrv_ISteadyClock,
|
|
||||||
fssrv_IFileSystemProxy,
|
|
||||||
fssrv_IFileSystem,
|
|
||||||
fssrv_IFile,
|
|
||||||
fssrv_IStorage,
|
|
||||||
nvdrv_INvDrvServices,
|
|
||||||
visrv_IManagerRootService,
|
|
||||||
visrv_IApplicationDisplayService,
|
|
||||||
visrv_ISystemDisplayService,
|
|
||||||
visrv_IManagerDisplayService,
|
|
||||||
hosbinder_IHOSBinderDriver,
|
|
||||||
pl_IPlatformServiceManager,
|
|
||||||
aocsrv_IAddOnContentManager,
|
|
||||||
pctl_IParentalControlServiceFactory,
|
|
||||||
pctl_IParentalControlService,
|
|
||||||
lm_ILogService,
|
|
||||||
lm_ILogger,
|
|
||||||
account_IAccountServiceForApplication,
|
|
||||||
account_IManagerForApplication,
|
|
||||||
account_IProfile,
|
|
||||||
friends_IServiceCreator,
|
|
||||||
friends_IFriendService,
|
|
||||||
friends_INotificationService,
|
|
||||||
nfp_IUserManager,
|
|
||||||
nfp_IUser,
|
|
||||||
nifm_IStaticService,
|
|
||||||
nifm_IGeneralService,
|
|
||||||
nifm_IRequest,
|
|
||||||
socket_IClient,
|
|
||||||
ssl_ISslService,
|
|
||||||
ssl_ISslContext,
|
|
||||||
prepo_IPrepoService
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief A map from every service's name as a std::string to the corresponding serviceEnum
|
|
||||||
*/
|
|
||||||
const static std::unordered_map<std::string, Service> ServiceString{
|
|
||||||
{"fatal:u", Service::fatalsrv_IService},
|
|
||||||
{"set", Service::settings_ISettingsServer},
|
|
||||||
{"set:sys", Service::settings_ISystemSettingsServer},
|
|
||||||
{"apm", Service::apm_IManager},
|
|
||||||
{"appletOE", Service::am_IApplicationProxyService},
|
|
||||||
{"appletAE", Service::am_IAllSystemAppletProxiesService},
|
|
||||||
{"audout:u", Service::audio_IAudioOutManager},
|
|
||||||
{"audren:u", Service::audio_IAudioRendererManager},
|
|
||||||
{"hid", Service::hid_IHidServer},
|
|
||||||
{"time:s", Service::timesrv_IStaticService},
|
|
||||||
{"time:a", Service::timesrv_IStaticService},
|
|
||||||
{"time:u", Service::timesrv_IStaticService},
|
|
||||||
{"fsp-srv", Service::fssrv_IFileSystemProxy},
|
|
||||||
{"nvdrv", Service::nvdrv_INvDrvServices},
|
|
||||||
{"nvdrv:a", Service::nvdrv_INvDrvServices},
|
|
||||||
{"nvdrv:s", Service::nvdrv_INvDrvServices},
|
|
||||||
{"nvdrv:t", Service::nvdrv_INvDrvServices},
|
|
||||||
{"vi:m", Service::visrv_IManagerRootService},
|
|
||||||
{"vi:u", Service::visrv_IManagerRootService},
|
|
||||||
{"vi:s", Service::visrv_IManagerRootService},
|
|
||||||
{"pl:u", Service::pl_IPlatformServiceManager},
|
|
||||||
{"aoc:u", Service::aocsrv_IAddOnContentManager},
|
|
||||||
{"pctl", Service::pctl_IParentalControlServiceFactory},
|
|
||||||
{"pctl:a", Service::pctl_IParentalControlServiceFactory},
|
|
||||||
{"pctl:s", Service::pctl_IParentalControlServiceFactory},
|
|
||||||
{"pctl:r", Service::pctl_IParentalControlServiceFactory},
|
|
||||||
{"lm", Service::lm_ILogService},
|
|
||||||
{"acc:u0", Service::account_IAccountServiceForApplication},
|
|
||||||
{"friend:u", Service::friends_IServiceCreator},
|
|
||||||
{"nfp:user", Service::nfp_IUserManager},
|
|
||||||
{"nifm:u", Service::nifm_IStaticService},
|
|
||||||
{"bsd:u", Service::socket_IClient},
|
|
||||||
{"ssl", Service::ssl_ISslService},
|
|
||||||
{"prepo:u", Service::prepo_IPrepoService}
|
|
||||||
};
|
|
||||||
|
|
||||||
class ServiceManager;
|
class ServiceManager;
|
||||||
|
|
||||||
@ -142,17 +31,26 @@ namespace skyline::service {
|
|||||||
std::unordered_map<u32, std::function<void(type::KSession &, ipc::IpcRequest &, ipc::IpcResponse &)>> vTable; //!< This holds the mapping from a function's CmdId to the actual function
|
std::unordered_map<u32, std::function<void(type::KSession &, ipc::IpcRequest &, ipc::IpcResponse &)>> vTable; //!< This holds the mapping from a function's CmdId to the actual function
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Service serviceType; //!< The type of this service
|
|
||||||
std::string serviceName; //!< The name of this service
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param state The state of the device
|
* @param state The state of the device
|
||||||
* @param hasLoop If the service has a loop or not
|
|
||||||
* @param serviceType The type of the service
|
|
||||||
* @param serviceName The name of the service
|
|
||||||
* @param vTable The functions of the service
|
* @param vTable The functions of the service
|
||||||
*/
|
*/
|
||||||
BaseService(const DeviceState &state, ServiceManager &manager, Service serviceType, const std::string &serviceName, const std::unordered_map<u32, std::function<void(type::KSession &, ipc::IpcRequest &, ipc::IpcResponse &)>> &vTable) : state(state), manager(manager), serviceType(serviceType), serviceName(serviceName), vTable(vTable) {}
|
BaseService(const DeviceState &state, ServiceManager &manager, const std::unordered_map<u32, std::function<void(type::KSession &, ipc::IpcRequest &, ipc::IpcResponse &)>> &vTable) : state(state), manager(manager), vTable(vTable) {}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @note To be able to extract the name of the underlying class and ensure correct destruction order
|
||||||
|
*/
|
||||||
|
virtual ~BaseService() = default;
|
||||||
|
|
||||||
|
std::string GetName() {
|
||||||
|
int status{};
|
||||||
|
size_t length{};
|
||||||
|
auto mangledName{typeid(*this).name()};
|
||||||
|
|
||||||
|
std::unique_ptr<char, decltype(&std::free)> demangled{ abi::__cxa_demangle(mangledName, nullptr, &length, &status), std::free};
|
||||||
|
|
||||||
|
return (status == 0) ? std::string(demangled.get() + std::char_traits<char>::length("skyline::service::")) : mangledName;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This handles all IPC commands with type request to a service
|
* @brief This handles all IPC commands with type request to a service
|
||||||
@ -164,14 +62,14 @@ namespace skyline::service {
|
|||||||
try {
|
try {
|
||||||
function = vTable.at(request.payload->value);
|
function = vTable.at(request.payload->value);
|
||||||
} catch (std::out_of_range &) {
|
} catch (std::out_of_range &) {
|
||||||
state.logger->Warn("Cannot find function in service '{0}' (Type: {1}): 0x{2:X} ({2})", serviceName, serviceType, static_cast<u32>(request.payload->value));
|
state.logger->Warn("Cannot find function in service '{0}': 0x{1:X} ({1})", GetName(), static_cast<u32>(request.payload->value));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
function(session, request, response);
|
function(session, request, response);
|
||||||
} catch (std::exception &e) {
|
} catch (std::exception &e) {
|
||||||
throw exception("{} (Service: {})", e.what(), serviceName);
|
throw exception("{} (Service: {})", e.what(), GetName());
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
#include "IService.h"
|
#include "IService.h"
|
||||||
|
|
||||||
namespace skyline::service::fatalsrv {
|
namespace skyline::service::fatalsrv {
|
||||||
IService::IService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::fatalsrv_IService, "fatalsrv:IService", {
|
IService::IService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IService::ThrowFatal)},
|
{0x0, SFUNC(IService::ThrowFatal)},
|
||||||
{0x1, SFUNC(IService::ThrowFatal)},
|
{0x1, SFUNC(IService::ThrowFatal)},
|
||||||
{0x2, SFUNC(IService::ThrowFatal)}
|
{0x2, SFUNC(IService::ThrowFatal)}
|
||||||
|
@ -4,6 +4,6 @@
|
|||||||
#include "IFriendService.h"
|
#include "IFriendService.h"
|
||||||
|
|
||||||
namespace skyline::service::friends {
|
namespace skyline::service::friends {
|
||||||
IFriendService::IFriendService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::friends_IFriendService, "friends:IFriendService", {
|
IFriendService::IFriendService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
}) {}
|
}) {}
|
||||||
}
|
}
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "INotificationService.h"
|
#include "INotificationService.h"
|
||||||
|
|
||||||
namespace skyline::service::friends {
|
namespace skyline::service::friends {
|
||||||
INotificationService::INotificationService(const DeviceState &state, ServiceManager &manager) : notificationEvent(std::make_shared<type::KEvent>(state)), BaseService(state, manager, Service::friends_INotificationService, "friends:INotificationService", {
|
INotificationService::INotificationService(const DeviceState &state, ServiceManager &manager) : notificationEvent(std::make_shared<type::KEvent>(state)), BaseService(state, manager, {
|
||||||
{0x0, SFUNC(INotificationService::GetEvent)},
|
{0x0, SFUNC(INotificationService::GetEvent)},
|
||||||
}) {}
|
}) {}
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
#include "IServiceCreator.h"
|
#include "IServiceCreator.h"
|
||||||
|
|
||||||
namespace skyline::service::friends {
|
namespace skyline::service::friends {
|
||||||
IServiceCreator::IServiceCreator(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::friends_IServiceCreator, "friends:IServiceCreator", {
|
IServiceCreator::IServiceCreator(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IServiceCreator::CreateFriendService)},
|
{0x0, SFUNC(IServiceCreator::CreateFriendService)},
|
||||||
{0x1, SFUNC(IServiceCreator::CreateNotificationService)},
|
{0x1, SFUNC(IServiceCreator::CreateNotificationService)},
|
||||||
}) {}
|
}) {}
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "IFile.h"
|
#include "IFile.h"
|
||||||
|
|
||||||
namespace skyline::service::fssrv {
|
namespace skyline::service::fssrv {
|
||||||
IFile::IFile(std::shared_ptr<vfs::Backing> &backing, const DeviceState &state, ServiceManager &manager) : backing(backing), BaseService(state, manager, Service::fssrv_IFile, "fssrv:IFile", {
|
IFile::IFile(std::shared_ptr<vfs::Backing> &backing, const DeviceState &state, ServiceManager &manager) : backing(backing), BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IFile::Read)},
|
{0x0, SFUNC(IFile::Read)},
|
||||||
{0x1, SFUNC(IFile::Write)},
|
{0x1, SFUNC(IFile::Write)},
|
||||||
{0x2, SFUNC(IFile::Flush)},
|
{0x2, SFUNC(IFile::Flush)},
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
#include "IFileSystem.h"
|
#include "IFileSystem.h"
|
||||||
|
|
||||||
namespace skyline::service::fssrv {
|
namespace skyline::service::fssrv {
|
||||||
IFileSystem::IFileSystem(std::shared_ptr<vfs::FileSystem> backing, const DeviceState &state, ServiceManager &manager) : backing(backing), BaseService(state, manager, Service::fssrv_IFileSystem, "fssrv:IFileSystem", {
|
IFileSystem::IFileSystem(std::shared_ptr<vfs::FileSystem> backing, const DeviceState &state, ServiceManager &manager) : backing(backing), BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IFileSystem::CreateFile)},
|
{0x0, SFUNC(IFileSystem::CreateFile)},
|
||||||
{0x7, SFUNC(IFileSystem::GetEntryType)},
|
{0x7, SFUNC(IFileSystem::GetEntryType)},
|
||||||
{0x8, SFUNC(IFileSystem::OpenFile)},
|
{0x8, SFUNC(IFileSystem::OpenFile)},
|
||||||
|
@ -8,7 +8,7 @@
|
|||||||
#include "IStorage.h"
|
#include "IStorage.h"
|
||||||
|
|
||||||
namespace skyline::service::fssrv {
|
namespace skyline::service::fssrv {
|
||||||
IFileSystemProxy::IFileSystemProxy(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::fssrv_IFileSystemProxy, "fssrv:IFileSystemProxy", {
|
IFileSystemProxy::IFileSystemProxy(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x1, SFUNC(IFileSystemProxy::SetCurrentProcess)},
|
{0x1, SFUNC(IFileSystemProxy::SetCurrentProcess)},
|
||||||
{0x12, SFUNC(IFileSystemProxy::OpenSdCardFileSystem)},
|
{0x12, SFUNC(IFileSystemProxy::OpenSdCardFileSystem)},
|
||||||
{0x33, SFUNC(IFileSystemProxy::OpenSaveDataFileSystem)},
|
{0x33, SFUNC(IFileSystemProxy::OpenSaveDataFileSystem)},
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "IStorage.h"
|
#include "IStorage.h"
|
||||||
|
|
||||||
namespace skyline::service::fssrv {
|
namespace skyline::service::fssrv {
|
||||||
IStorage::IStorage(std::shared_ptr<vfs::Backing> &backing, const DeviceState &state, ServiceManager &manager) : backing(backing), BaseService(state, manager, Service::fssrv_IStorage, "fssrv:IStorage", {
|
IStorage::IStorage(std::shared_ptr<vfs::Backing> &backing, const DeviceState &state, ServiceManager &manager) : backing(backing), BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IStorage::Read)},
|
{0x0, SFUNC(IStorage::Read)},
|
||||||
{0x4, SFUNC(IStorage::GetSize)}
|
{0x4, SFUNC(IStorage::GetSize)}
|
||||||
}) {}
|
}) {}
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
using namespace skyline::input;
|
using namespace skyline::input;
|
||||||
|
|
||||||
namespace skyline::service::hid {
|
namespace skyline::service::hid {
|
||||||
IActiveVibrationDeviceList::IActiveVibrationDeviceList(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::hid_IActiveVibrationDeviceList, "hid:IActiveVibrationDeviceList", {
|
IActiveVibrationDeviceList::IActiveVibrationDeviceList(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IActiveVibrationDeviceList::ActivateVibrationDevice)}
|
{0x0, SFUNC(IActiveVibrationDeviceList::ActivateVibrationDevice)}
|
||||||
}) {}
|
}) {}
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "IAppletResource.h"
|
#include "IAppletResource.h"
|
||||||
|
|
||||||
namespace skyline::service::hid {
|
namespace skyline::service::hid {
|
||||||
IAppletResource::IAppletResource(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::hid_IAppletResource, "hid:IAppletResource", {
|
IAppletResource::IAppletResource(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IAppletResource::GetSharedMemoryHandle)}
|
{0x0, SFUNC(IAppletResource::GetSharedMemoryHandle)}
|
||||||
}) {}
|
}) {}
|
||||||
|
|
||||||
|
@ -8,7 +8,7 @@
|
|||||||
using namespace skyline::input;
|
using namespace skyline::input;
|
||||||
|
|
||||||
namespace skyline::service::hid {
|
namespace skyline::service::hid {
|
||||||
IHidServer::IHidServer(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::hid_IHidServer, "hid:IHidServer", {
|
IHidServer::IHidServer(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IHidServer::CreateAppletResource)},
|
{0x0, SFUNC(IHidServer::CreateAppletResource)},
|
||||||
{0x64, SFUNC(IHidServer::SetSupportedNpadStyleSet)},
|
{0x64, SFUNC(IHidServer::SetSupportedNpadStyleSet)},
|
||||||
{0x64, SFUNC(IHidServer::GetSupportedNpadStyleSet)},
|
{0x64, SFUNC(IHidServer::GetSupportedNpadStyleSet)},
|
||||||
|
@ -11,7 +11,7 @@
|
|||||||
#include "display.h"
|
#include "display.h"
|
||||||
|
|
||||||
namespace skyline::service::hosbinder {
|
namespace skyline::service::hosbinder {
|
||||||
IHOSBinderDriver::IHOSBinderDriver(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::hosbinder_IHOSBinderDriver, "hosbinder_IHOSBinderDriver", {
|
IHOSBinderDriver::IHOSBinderDriver(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IHOSBinderDriver::TransactParcel)},
|
{0x0, SFUNC(IHOSBinderDriver::TransactParcel)},
|
||||||
{0x1, SFUNC(IHOSBinderDriver::AdjustRefcount)},
|
{0x1, SFUNC(IHOSBinderDriver::AdjustRefcount)},
|
||||||
{0x2, SFUNC(IHOSBinderDriver::GetNativeHandle)},
|
{0x2, SFUNC(IHOSBinderDriver::GetNativeHandle)},
|
||||||
@ -124,7 +124,7 @@ namespace skyline::service::hosbinder {
|
|||||||
auto gbpBuffer = reinterpret_cast<GbpBuffer *>(pointer);
|
auto gbpBuffer = reinterpret_cast<GbpBuffer *>(pointer);
|
||||||
|
|
||||||
std::shared_ptr<nvdrv::device::NvMap::NvMapObject> nvBuffer{};
|
std::shared_ptr<nvdrv::device::NvMap::NvMapObject> nvBuffer{};
|
||||||
auto nvmap = state.os->serviceManager.GetService<nvdrv::INvDrvServices>(Service::nvdrv_INvDrvServices)->GetDevice<nvdrv::device::NvMap>(nvdrv::device::NvDeviceType::nvmap);
|
auto nvmap = state.os->serviceManager.GetService<nvdrv::INvDrvServices>("nvdrv")->GetDevice<nvdrv::device::NvMap>(nvdrv::device::NvDeviceType::nvmap);
|
||||||
|
|
||||||
if (gbpBuffer->nvmapHandle) {
|
if (gbpBuffer->nvmapHandle) {
|
||||||
nvBuffer = nvmap->handleTable.at(gbpBuffer->nvmapHandle);
|
nvBuffer = nvmap->handleTable.at(gbpBuffer->nvmapHandle);
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "ILogService.h"
|
#include "ILogService.h"
|
||||||
|
|
||||||
namespace skyline::service::lm {
|
namespace skyline::service::lm {
|
||||||
ILogService::ILogService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::lm_ILogService, "lm:ILogService", {
|
ILogService::ILogService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(ILogService::OpenLogger)}
|
{0x0, SFUNC(ILogService::OpenLogger)}
|
||||||
}) {}
|
}) {}
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "ILogger.h"
|
#include "ILogger.h"
|
||||||
|
|
||||||
namespace skyline::service::lm {
|
namespace skyline::service::lm {
|
||||||
ILogger::ILogger(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::lm_ILogger, "lm:ILogger", {
|
ILogger::ILogger(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(ILogger::Log)},
|
{0x0, SFUNC(ILogger::Log)},
|
||||||
{0x1, SFUNC(ILogger::SetDestination)}
|
{0x1, SFUNC(ILogger::SetDestination)}
|
||||||
}) {}
|
}) {}
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "IUserManager.h"
|
#include "IUserManager.h"
|
||||||
|
|
||||||
namespace skyline::service::nfp {
|
namespace skyline::service::nfp {
|
||||||
IUser::IUser(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::nfp_IUser, "nfp:IUser", {
|
IUser::IUser(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IUser::Initialize)}
|
{0x0, SFUNC(IUser::Initialize)}
|
||||||
}) {}
|
}) {}
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "IUserManager.h"
|
#include "IUserManager.h"
|
||||||
|
|
||||||
namespace skyline::service::nfp {
|
namespace skyline::service::nfp {
|
||||||
IUserManager::IUserManager(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::nfp_IUserManager, "nfp:IUserManager", {
|
IUserManager::IUserManager(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IUserManager::CreateUserInterface)}
|
{0x0, SFUNC(IUserManager::CreateUserInterface)}
|
||||||
}) {}
|
}) {}
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "IGeneralService.h"
|
#include "IGeneralService.h"
|
||||||
|
|
||||||
namespace skyline::service::nifm {
|
namespace skyline::service::nifm {
|
||||||
IGeneralService::IGeneralService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::nifm_IGeneralService, "nifm:IGeneralService", {
|
IGeneralService::IGeneralService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x4, SFUNC(IGeneralService::CreateRequest)}
|
{0x4, SFUNC(IGeneralService::CreateRequest)}
|
||||||
}) {}
|
}) {}
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "IRequest.h"
|
#include "IRequest.h"
|
||||||
|
|
||||||
namespace skyline::service::nifm {
|
namespace skyline::service::nifm {
|
||||||
IRequest::IRequest(const DeviceState &state, ServiceManager &manager) : event0(std::make_shared<type::KEvent>(state)), event1(std::make_shared<type::KEvent>(state)), BaseService(state, manager, Service::nifm_IRequest, "nifm:IRequest", {
|
IRequest::IRequest(const DeviceState &state, ServiceManager &manager) : event0(std::make_shared<type::KEvent>(state)), event1(std::make_shared<type::KEvent>(state)), BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IRequest::GetRequestState)},
|
{0x0, SFUNC(IRequest::GetRequestState)},
|
||||||
{0x1, SFUNC(IRequest::GetResult)},
|
{0x1, SFUNC(IRequest::GetResult)},
|
||||||
{0x2, SFUNC(IRequest::GetSystemEventReadableHandles)},
|
{0x2, SFUNC(IRequest::GetSystemEventReadableHandles)},
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "IStaticService.h"
|
#include "IStaticService.h"
|
||||||
|
|
||||||
namespace skyline::service::nifm {
|
namespace skyline::service::nifm {
|
||||||
IStaticService::IStaticService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::nifm_IStaticService, "nifm:IStaticService", {
|
IStaticService::IStaticService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x4, SFUNC(IStaticService::CreateGeneralService)},
|
{0x4, SFUNC(IStaticService::CreateGeneralService)},
|
||||||
{0x5, SFUNC(IStaticService::CreateGeneralService)}
|
{0x5, SFUNC(IStaticService::CreateGeneralService)}
|
||||||
}) {}
|
}) {}
|
||||||
|
@ -54,7 +54,7 @@ namespace skyline::service::nvdrv {
|
|||||||
return fdIndex++;
|
return fdIndex++;
|
||||||
}
|
}
|
||||||
|
|
||||||
INvDrvServices::INvDrvServices(const DeviceState &state, ServiceManager &manager) : hostSyncpoint(state), BaseService(state, manager, Service::nvdrv_INvDrvServices, "INvDrvServices", {
|
INvDrvServices::INvDrvServices(const DeviceState &state, ServiceManager &manager) : hostSyncpoint(state), BaseService(state, manager, {
|
||||||
{0x0, SFUNC(INvDrvServices::Open)},
|
{0x0, SFUNC(INvDrvServices::Open)},
|
||||||
{0x1, SFUNC(INvDrvServices::Ioctl)},
|
{0x1, SFUNC(INvDrvServices::Ioctl)},
|
||||||
{0x2, SFUNC(INvDrvServices::Close)},
|
{0x2, SFUNC(INvDrvServices::Close)},
|
||||||
|
@ -70,7 +70,7 @@ namespace skyline::service::nvdrv::device {
|
|||||||
if (!region.nvmapHandle)
|
if (!region.nvmapHandle)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
auto nvmap = state.os->serviceManager.GetService<nvdrv::INvDrvServices>(Service::nvdrv_INvDrvServices)->GetDevice<nvdrv::device::NvMap>(nvdrv::device::NvDeviceType::nvmap)->handleTable.at(region.nvmapHandle);
|
auto nvmap = state.os->serviceManager.GetService<nvdrv::INvDrvServices>("nvdrv")->GetDevice<nvdrv::device::NvMap>(nvdrv::device::NvDeviceType::nvmap)->handleTable.at(region.nvmapHandle);
|
||||||
|
|
||||||
u64 mapPhysicalAddress = region.bufferOffset + nvmap->address;
|
u64 mapPhysicalAddress = region.bufferOffset + nvmap->address;
|
||||||
u64 mapSize = region.mappingSize ? region.mappingSize : nvmap->size;
|
u64 mapSize = region.mappingSize ? region.mappingSize : nvmap->size;
|
||||||
@ -133,7 +133,7 @@ namespace skyline::service::nvdrv::device {
|
|||||||
|
|
||||||
for (auto entry : entries) {
|
for (auto entry : entries) {
|
||||||
try {
|
try {
|
||||||
auto nvmap = state.os->serviceManager.GetService<nvdrv::INvDrvServices>(Service::nvdrv_INvDrvServices)->GetDevice<nvdrv::device::NvMap>(nvdrv::device::NvDeviceType::nvmap)->handleTable.at(entry.nvmapHandle);
|
auto nvmap = state.os->serviceManager.GetService<nvdrv::INvDrvServices>("nvdrv")->GetDevice<nvdrv::device::NvMap>(nvdrv::device::NvDeviceType::nvmap)->handleTable.at(entry.nvmapHandle);
|
||||||
|
|
||||||
u64 mapAddress = static_cast<u64>(entry.gpuOffset) << MinAlignmentShift;
|
u64 mapAddress = static_cast<u64>(entry.gpuOffset) << MinAlignmentShift;
|
||||||
u64 mapPhysicalAddress = nvmap->address + (static_cast<u64>(entry.mapOffset) << MinAlignmentShift);
|
u64 mapPhysicalAddress = nvmap->address + (static_cast<u64>(entry.mapOffset) << MinAlignmentShift);
|
||||||
|
@ -19,7 +19,7 @@ namespace skyline::service::nvdrv::device {
|
|||||||
{0x481A, NFUNC(NvHostChannel::AllocGpfifoEx2)},
|
{0x481A, NFUNC(NvHostChannel::AllocGpfifoEx2)},
|
||||||
{0x4714, NFUNC(NvHostChannel::SetUserData)},
|
{0x4714, NFUNC(NvHostChannel::SetUserData)},
|
||||||
}) {
|
}) {
|
||||||
auto &hostSyncpoint = state.os->serviceManager.GetService<nvdrv::INvDrvServices>(Service::nvdrv_INvDrvServices)->hostSyncpoint;
|
auto &hostSyncpoint = state.os->serviceManager.GetService<nvdrv::INvDrvServices>("nvdrv")->hostSyncpoint;
|
||||||
|
|
||||||
channelFence.id = hostSyncpoint.AllocateSyncpoint(false);
|
channelFence.id = hostSyncpoint.AllocateSyncpoint(false);
|
||||||
channelFence.UpdateValue(hostSyncpoint);
|
channelFence.UpdateValue(hostSyncpoint);
|
||||||
@ -48,7 +48,7 @@ namespace skyline::service::nvdrv::device {
|
|||||||
Fence fence;
|
Fence fence;
|
||||||
} &args = state.process->GetReference<Data>(buffer.output.at(0).address);
|
} &args = state.process->GetReference<Data>(buffer.output.at(0).address);
|
||||||
|
|
||||||
auto &hostSyncpoint = state.os->serviceManager.GetService<nvdrv::INvDrvServices>(Service::nvdrv_INvDrvServices)->hostSyncpoint;
|
auto &hostSyncpoint = state.os->serviceManager.GetService<nvdrv::INvDrvServices>("nvdrv")->hostSyncpoint;
|
||||||
|
|
||||||
if (args.flags.fenceWait) {
|
if (args.flags.fenceWait) {
|
||||||
if (args.flags.incrementWithValue) {
|
if (args.flags.incrementWithValue) {
|
||||||
@ -104,7 +104,7 @@ namespace skyline::service::nvdrv::device {
|
|||||||
u32 reserved[3];
|
u32 reserved[3];
|
||||||
} &args = state.process->GetReference<Data>(buffer.input.at(0).address);
|
} &args = state.process->GetReference<Data>(buffer.input.at(0).address);
|
||||||
|
|
||||||
channelFence.UpdateValue(state.os->serviceManager.GetService<nvdrv::INvDrvServices>(Service::nvdrv_INvDrvServices)->hostSyncpoint);
|
channelFence.UpdateValue(state.os->serviceManager.GetService<nvdrv::INvDrvServices>("nvdrv")->hostSyncpoint);
|
||||||
args.fence = channelFence;
|
args.fence = channelFence;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -95,7 +95,7 @@ namespace skyline::service::nvdrv::device {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto &hostSyncpoint = state.os->serviceManager.GetService<nvdrv::INvDrvServices>(Service::nvdrv_INvDrvServices)->hostSyncpoint;
|
auto &hostSyncpoint = state.os->serviceManager.GetService<nvdrv::INvDrvServices>("nvdrv")->hostSyncpoint;
|
||||||
|
|
||||||
// Check if the syncpoint has already expired using the last known values
|
// Check if the syncpoint has already expired using the last known values
|
||||||
if (hostSyncpoint.HasSyncpointExpired(args.fence.id, args.fence.value)) {
|
if (hostSyncpoint.HasSyncpointExpired(args.fence.id, args.fence.value)) {
|
||||||
@ -173,7 +173,7 @@ namespace skyline::service::nvdrv::device {
|
|||||||
|
|
||||||
event.state = NvHostEvent::State::Cancelled;
|
event.state = NvHostEvent::State::Cancelled;
|
||||||
|
|
||||||
auto &hostSyncpoint = state.os->serviceManager.GetService<nvdrv::INvDrvServices>(Service::nvdrv_INvDrvServices)->hostSyncpoint;
|
auto &hostSyncpoint = state.os->serviceManager.GetService<nvdrv::INvDrvServices>("nvdrv")->hostSyncpoint;
|
||||||
hostSyncpoint.UpdateMin(event.fence.id);
|
hostSyncpoint.UpdateMin(event.fence.id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4,6 +4,6 @@
|
|||||||
#include "IParentalControlService.h"
|
#include "IParentalControlService.h"
|
||||||
|
|
||||||
namespace skyline::service::pctl {
|
namespace skyline::service::pctl {
|
||||||
IParentalControlService::IParentalControlService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::pctl_IParentalControlService, "pctl:IParentalControlService", {
|
IParentalControlService::IParentalControlService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
}) {}
|
}) {}
|
||||||
}
|
}
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "IParentalControlServiceFactory.h"
|
#include "IParentalControlServiceFactory.h"
|
||||||
|
|
||||||
namespace skyline::service::pctl {
|
namespace skyline::service::pctl {
|
||||||
IParentalControlServiceFactory::IParentalControlServiceFactory(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::pctl_IParentalControlServiceFactory, "pctl:IParentalControlServiceFactory", {
|
IParentalControlServiceFactory::IParentalControlServiceFactory(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IParentalControlServiceFactory::CreateService)},
|
{0x0, SFUNC(IParentalControlServiceFactory::CreateService)},
|
||||||
{0x1, SFUNC(IParentalControlServiceFactory::CreateService)}
|
{0x1, SFUNC(IParentalControlServiceFactory::CreateService)}
|
||||||
}) {}
|
}) {}
|
||||||
|
@ -29,7 +29,7 @@ namespace skyline::service::pl {
|
|||||||
{FontStandard, FontStandardLength}
|
{FontStandard, FontStandardLength}
|
||||||
}};
|
}};
|
||||||
|
|
||||||
IPlatformServiceManager::IPlatformServiceManager(const DeviceState &state, ServiceManager &manager) : fontSharedMem(std::make_shared<kernel::type::KSharedMemory>(state, NULL, constant::FontSharedMemSize, memory::Permission{true, false, false})), BaseService(state, manager, Service::pl_IPlatformServiceManager, "pl:IPlatformServiceManager", {
|
IPlatformServiceManager::IPlatformServiceManager(const DeviceState &state, ServiceManager &manager) : fontSharedMem(std::make_shared<kernel::type::KSharedMemory>(state, NULL, constant::FontSharedMemSize, memory::Permission{true, false, false})), BaseService(state, manager, {
|
||||||
{0x1, SFUNC(IPlatformServiceManager::GetLoadState)},
|
{0x1, SFUNC(IPlatformServiceManager::GetLoadState)},
|
||||||
{0x2, SFUNC(IPlatformServiceManager::GetSize)},
|
{0x2, SFUNC(IPlatformServiceManager::GetSize)},
|
||||||
{0x3, SFUNC(IPlatformServiceManager::GetSharedMemoryAddressOffset)},
|
{0x3, SFUNC(IPlatformServiceManager::GetSharedMemoryAddressOffset)},
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
#include "IPrepoService.h"
|
#include "IPrepoService.h"
|
||||||
|
|
||||||
namespace skyline::service::prepo {
|
namespace skyline::service::prepo {
|
||||||
IPrepoService::IPrepoService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::prepo_IPrepoService, "prepo:IPrepoService", {
|
IPrepoService::IPrepoService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x2775, SFUNC(IPrepoService::SaveReportWithUser)},
|
{0x2775, SFUNC(IPrepoService::SaveReportWithUser)},
|
||||||
}) {}
|
}) {}
|
||||||
|
|
||||||
|
@ -29,106 +29,64 @@
|
|||||||
#include "prepo/IPrepoService.h"
|
#include "prepo/IPrepoService.h"
|
||||||
#include "serviceman.h"
|
#include "serviceman.h"
|
||||||
|
|
||||||
namespace skyline::service {
|
#define SERVICE_CASE(class, name) \
|
||||||
ServiceManager::ServiceManager(const DeviceState &state) : state(state) {}
|
case util::MakeMagic<ServiceName>(name): { \
|
||||||
|
std::shared_ptr<BaseService> serviceObject = std::make_shared<class>(state, *this); \
|
||||||
|
serviceMap[util::MakeMagic<ServiceName>(name)] = serviceObject; \
|
||||||
|
return serviceObject; \
|
||||||
|
}
|
||||||
|
|
||||||
std::shared_ptr<BaseService> ServiceManager::CreateService(Service serviceType) {
|
namespace skyline::service {
|
||||||
auto serviceIter = serviceMap.find(serviceType);
|
ServiceManager::ServiceManager(const DeviceState &state) : state(state), smUserInterface(std::make_shared<sm::IUserInterface>(state, *this)) {}
|
||||||
|
|
||||||
|
std::shared_ptr<BaseService> ServiceManager::CreateService(ServiceName name) {
|
||||||
|
auto serviceIter = serviceMap.find(name);
|
||||||
if (serviceIter != serviceMap.end())
|
if (serviceIter != serviceMap.end())
|
||||||
return (*serviceIter).second;
|
return (*serviceIter).second;
|
||||||
|
|
||||||
std::shared_ptr<BaseService> serviceObj;
|
switch (name) {
|
||||||
switch (serviceType) {
|
SERVICE_CASE(fatalsrv::IService, "fatal:u")
|
||||||
case Service::sm_IUserInterface:
|
SERVICE_CASE(settings::ISettingsServer, "set")
|
||||||
serviceObj = std::make_shared<sm::IUserInterface>(state, *this);
|
SERVICE_CASE(settings::ISystemSettingsServer, "set:sys")
|
||||||
break;
|
SERVICE_CASE(apm::IManager, "apm")
|
||||||
case Service::fatalsrv_IService:
|
SERVICE_CASE(am::IApplicationProxyService, "appletOE")
|
||||||
serviceObj = std::make_shared<fatalsrv::IService>(state, *this);
|
SERVICE_CASE(am::IAllSystemAppletProxiesService, "appletAE")
|
||||||
break;
|
SERVICE_CASE(audio::IAudioOutManager, "audout:u")
|
||||||
case Service::settings_ISettingsServer:
|
SERVICE_CASE(audio::IAudioRendererManager, "audren:u")
|
||||||
serviceObj = std::make_shared<settings::ISettingsServer>(state, *this);
|
SERVICE_CASE(hid::IHidServer, "hid")
|
||||||
break;
|
SERVICE_CASE(timesrv::IStaticService, "time:s")
|
||||||
case Service::settings_ISystemSettingsServer:
|
SERVICE_CASE(timesrv::IStaticService, "time:a")
|
||||||
serviceObj = std::make_shared<settings::ISystemSettingsServer>(state, *this);
|
SERVICE_CASE(timesrv::IStaticService, "time:u")
|
||||||
break;
|
SERVICE_CASE(fssrv::IFileSystemProxy, "fsp-srv")
|
||||||
case Service::apm_IManager:
|
SERVICE_CASE(nvdrv::INvDrvServices, "nvdrv")
|
||||||
serviceObj = std::make_shared<apm::IManager>(state, *this);
|
SERVICE_CASE(nvdrv::INvDrvServices, "nvdrv:a")
|
||||||
break;
|
SERVICE_CASE(nvdrv::INvDrvServices, "nvdrv:s")
|
||||||
case Service::am_IApplicationProxyService:
|
SERVICE_CASE(nvdrv::INvDrvServices, "nvdrv:t")
|
||||||
serviceObj = std::make_shared<am::IApplicationProxyService>(state, *this);
|
SERVICE_CASE(visrv::IManagerRootService, "vi:m")
|
||||||
break;
|
SERVICE_CASE(visrv::IManagerRootService, "vi:u")
|
||||||
case Service::am_IAllSystemAppletProxiesService:
|
SERVICE_CASE(visrv::IManagerRootService, "vi:s")
|
||||||
serviceObj = std::make_shared<am::IAllSystemAppletProxiesService>(state, *this);
|
SERVICE_CASE(pl::IPlatformServiceManager, "pl:u")
|
||||||
break;
|
SERVICE_CASE(aocsrv::IAddOnContentManager, "aoc:u")
|
||||||
case Service::audio_IAudioOutManager:
|
SERVICE_CASE(pctl::IParentalControlServiceFactory, "pctl")
|
||||||
serviceObj = std::make_shared<audio::IAudioOutManager>(state, *this);
|
SERVICE_CASE(pctl::IParentalControlServiceFactory, "pctl:a")
|
||||||
break;
|
SERVICE_CASE(pctl::IParentalControlServiceFactory, "pctl:s")
|
||||||
case Service::audio_IAudioRendererManager:
|
SERVICE_CASE(pctl::IParentalControlServiceFactory, "pctl:r")
|
||||||
serviceObj = std::make_shared<audio::IAudioRendererManager>(state, *this);
|
SERVICE_CASE(lm::ILogService, "lm")
|
||||||
break;
|
SERVICE_CASE(account::IAccountServiceForApplication, "acc:u0")
|
||||||
case Service::hid_IHidServer:
|
SERVICE_CASE(friends::IServiceCreator, "friend")
|
||||||
serviceObj = std::make_shared<hid::IHidServer>(state, *this);
|
SERVICE_CASE(nfp::IUserManager, "nfp:user")
|
||||||
break;
|
SERVICE_CASE(nifm::IStaticService, "nifm:u")
|
||||||
case Service::timesrv_IStaticService:
|
SERVICE_CASE(socket::IClient, "bsd:u")
|
||||||
serviceObj = std::make_shared<timesrv::IStaticService>(state, *this);
|
SERVICE_CASE(ssl::ISslService, "ssl")
|
||||||
break;
|
SERVICE_CASE(prepo::IPrepoService, "prepo:u")
|
||||||
case Service::fssrv_IFileSystemProxy:
|
|
||||||
serviceObj = std::make_shared<fssrv::IFileSystemProxy>(state, *this);
|
|
||||||
break;
|
|
||||||
case Service::nvdrv_INvDrvServices:
|
|
||||||
serviceObj = std::make_shared<nvdrv::INvDrvServices>(state, *this);
|
|
||||||
break;
|
|
||||||
case Service::visrv_IManagerRootService:
|
|
||||||
serviceObj = std::make_shared<visrv::IManagerRootService>(state, *this);
|
|
||||||
break;
|
|
||||||
case Service::pl_IPlatformServiceManager:
|
|
||||||
serviceObj = std::make_shared<pl::IPlatformServiceManager>(state, *this);
|
|
||||||
break;
|
|
||||||
case Service::aocsrv_IAddOnContentManager:
|
|
||||||
serviceObj = std::make_shared<aocsrv::IAddOnContentManager>(state, *this);
|
|
||||||
break;
|
|
||||||
case Service::pctl_IParentalControlServiceFactory:
|
|
||||||
serviceObj = std::make_shared<pctl::IParentalControlServiceFactory>(state, *this);
|
|
||||||
break;
|
|
||||||
case Service::lm_ILogService:
|
|
||||||
serviceObj = std::make_shared<lm::ILogService>(state, *this);
|
|
||||||
break;
|
|
||||||
case Service::account_IAccountServiceForApplication:
|
|
||||||
serviceObj = std::make_shared<account::IAccountServiceForApplication>(state, *this);
|
|
||||||
break;
|
|
||||||
case Service::friends_IServiceCreator:
|
|
||||||
serviceObj = std::make_shared<friends::IServiceCreator>(state, *this);
|
|
||||||
break;
|
|
||||||
case Service::nfp_IUserManager:
|
|
||||||
serviceObj = std::make_shared<nfp::IUserManager>(state, *this);
|
|
||||||
break;
|
|
||||||
case Service::nifm_IStaticService:
|
|
||||||
serviceObj = std::make_shared<nifm::IStaticService>(state, *this);
|
|
||||||
break;
|
|
||||||
case Service::socket_IClient:
|
|
||||||
serviceObj = std::make_shared<socket::IClient>(state, *this);
|
|
||||||
break;
|
|
||||||
case Service::ssl_ISslService:
|
|
||||||
serviceObj = std::make_shared<ssl::ISslService>(state, *this);
|
|
||||||
break;
|
|
||||||
case Service::prepo_IPrepoService:
|
|
||||||
serviceObj = std::make_shared<prepo::IPrepoService>(state, *this);
|
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
throw exception("CreateService called on missing object, type: {}", serviceType);
|
throw exception("CreateService called with an unknown service name: {}", name);
|
||||||
}
|
}
|
||||||
serviceMap[serviceType] = serviceObj;
|
|
||||||
return serviceObj;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
KHandle ServiceManager::NewSession(Service serviceType) {
|
std::shared_ptr<BaseService> ServiceManager::NewService(ServiceName name, type::KSession &session, ipc::IpcResponse &response) {
|
||||||
std::lock_guard serviceGuard(mutex);
|
std::lock_guard serviceGuard(mutex);
|
||||||
return state.process->NewHandle<type::KSession>(CreateService(serviceType)).handle;
|
auto serviceObject = CreateService(name);
|
||||||
}
|
|
||||||
|
|
||||||
std::shared_ptr<BaseService> ServiceManager::NewService(const std::string &serviceName, type::KSession &session, ipc::IpcResponse &response) {
|
|
||||||
std::lock_guard serviceGuard(mutex);
|
|
||||||
auto serviceObject = CreateService(ServiceString.at(serviceName));
|
|
||||||
KHandle handle{};
|
KHandle handle{};
|
||||||
if (session.isDomain) {
|
if (session.isDomain) {
|
||||||
session.domainTable[++session.handleIndex] = serviceObject;
|
session.domainTable[++session.handleIndex] = serviceObject;
|
||||||
@ -138,13 +96,14 @@ namespace skyline::service {
|
|||||||
handle = state.process->NewHandle<type::KSession>(serviceObject).handle;
|
handle = state.process->NewHandle<type::KSession>(serviceObject).handle;
|
||||||
response.moveHandles.push_back(handle);
|
response.moveHandles.push_back(handle);
|
||||||
}
|
}
|
||||||
state.logger->Debug("Service has been created: \"{}\" (0x{:X})", serviceName, handle);
|
state.logger->Debug("Service has been created: \"{}\" (0x{:X})", serviceObject->GetName(), handle);
|
||||||
return serviceObject;
|
return serviceObject;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ServiceManager::RegisterService(std::shared_ptr<BaseService> serviceObject, type::KSession &session, ipc::IpcResponse &response, bool submodule) { // NOLINT(performance-unnecessary-value-param)
|
void ServiceManager::RegisterService(std::shared_ptr<BaseService> serviceObject, type::KSession &session, ipc::IpcResponse &response, bool submodule, ServiceName name) { // NOLINT(performance-unnecessary-value-param)
|
||||||
std::lock_guard serviceGuard(mutex);
|
std::lock_guard serviceGuard(mutex);
|
||||||
KHandle handle{};
|
KHandle handle{};
|
||||||
|
|
||||||
if (session.isDomain) {
|
if (session.isDomain) {
|
||||||
session.domainTable[session.handleIndex] = serviceObject;
|
session.domainTable[session.handleIndex] = serviceObject;
|
||||||
response.domainObjects.push_back(session.handleIndex);
|
response.domainObjects.push_back(session.handleIndex);
|
||||||
@ -153,9 +112,11 @@ namespace skyline::service {
|
|||||||
handle = state.process->NewHandle<type::KSession>(serviceObject).handle;
|
handle = state.process->NewHandle<type::KSession>(serviceObject).handle;
|
||||||
response.moveHandles.push_back(handle);
|
response.moveHandles.push_back(handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!submodule)
|
if (!submodule)
|
||||||
serviceMap[serviceObject->serviceType] = serviceObject;
|
serviceMap[name] = serviceObject;
|
||||||
state.logger->Debug("Service has been registered: \"{}\" (0x{:X})", serviceObject->serviceName, handle);
|
|
||||||
|
state.logger->Debug("Service has been registered: \"{}\" (0x{:X})", serviceObject->GetName(), handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ServiceManager::CloseSession(KHandle handle) {
|
void ServiceManager::CloseSession(KHandle handle) {
|
||||||
@ -163,10 +124,14 @@ namespace skyline::service {
|
|||||||
auto session = state.process->GetHandle<type::KSession>(handle);
|
auto session = state.process->GetHandle<type::KSession>(handle);
|
||||||
if (session->serviceStatus == type::KSession::ServiceStatus::Open) {
|
if (session->serviceStatus == type::KSession::ServiceStatus::Open) {
|
||||||
if (session->isDomain) {
|
if (session->isDomain) {
|
||||||
for (const auto &[objectId, service] : session->domainTable)
|
for (const auto &domainEntry : session->domainTable)
|
||||||
serviceMap.erase(service->serviceType);
|
std::erase_if(serviceMap, [domainEntry](const auto &entry) {
|
||||||
|
return entry.second == domainEntry.second;
|
||||||
|
});
|
||||||
} else {
|
} else {
|
||||||
serviceMap.erase(session->serviceObject->serviceType);
|
std::erase_if(serviceMap, [session](const auto &entry) {
|
||||||
|
return entry.second == session->serviceObject;
|
||||||
|
});
|
||||||
}
|
}
|
||||||
session->serviceStatus = type::KSession::ServiceStatus::Closed;
|
session->serviceStatus = type::KSession::ServiceStatus::Closed;
|
||||||
}
|
}
|
||||||
@ -192,7 +157,9 @@ namespace skyline::service {
|
|||||||
service->HandleRequest(*session, request, response);
|
service->HandleRequest(*session, request, response);
|
||||||
break;
|
break;
|
||||||
case ipc::DomainCommand::CloseVHandle:
|
case ipc::DomainCommand::CloseVHandle:
|
||||||
serviceMap.erase(service->serviceType);
|
std::erase_if(serviceMap, [service](const auto &entry) {
|
||||||
|
return entry.second == service;
|
||||||
|
});
|
||||||
session->domainTable.erase(request.domain->objectId);
|
session->domainTable.erase(request.domain->objectId);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -10,40 +10,36 @@
|
|||||||
namespace skyline::service {
|
namespace skyline::service {
|
||||||
/**
|
/**
|
||||||
* @brief The ServiceManager class manages passing IPC requests to the right Service and running event loops of Services
|
* @brief The ServiceManager class manages passing IPC requests to the right Service and running event loops of Services
|
||||||
|
* @todo This implementation varies significantly from HOS, this should be rectified much later on
|
||||||
*/
|
*/
|
||||||
class ServiceManager {
|
class ServiceManager {
|
||||||
private:
|
private:
|
||||||
const DeviceState &state; //!< The state of the device
|
const DeviceState &state; //!< The state of the device
|
||||||
std::unordered_map<Service, std::shared_ptr<BaseService>> serviceMap; //!< A mapping from a Service to the underlying object
|
std::unordered_map<ServiceName, std::shared_ptr<BaseService>> serviceMap; //!< A mapping from a Service to the underlying object
|
||||||
Mutex mutex; //!< This mutex is used to ensure concurrent access to services doesn't cause crashes
|
Mutex mutex; //!< This mutex is used to ensure concurrent access to services doesn't cause crashes
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Creates an instance of the service if it doesn't already exist, otherwise returns an existing instance
|
* @brief Creates an instance of the service if it doesn't already exist, otherwise returns an existing instance
|
||||||
* @param serviceType The type of service requested
|
* @param name The name of the service to create
|
||||||
* @return A shared pointer to an instance of the service
|
* @return A shared pointer to an instance of the service
|
||||||
*/
|
*/
|
||||||
std::shared_ptr<BaseService> CreateService(Service serviceType);
|
std::shared_ptr<BaseService> CreateService(ServiceName name);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
std::shared_ptr<BaseService> smUserInterface; //!< This is used by applications to open connections to services
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param state The state of the device
|
* @param state The state of the device
|
||||||
*/
|
*/
|
||||||
ServiceManager(const DeviceState &state);
|
ServiceManager(const DeviceState &state);
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Creates a new service and returns it's handle
|
|
||||||
* @param serviceType The type of the service
|
|
||||||
* @return Handle to KService object of the service
|
|
||||||
*/
|
|
||||||
KHandle NewSession(Service serviceType);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Creates a new service using it's type enum and writes it's handle or virtual handle (If it's a domain request) to IpcResponse
|
* @brief Creates a new service using it's type enum and writes it's handle or virtual handle (If it's a domain request) to IpcResponse
|
||||||
* @param serviceName The name of the service
|
* @param name The service's name
|
||||||
* @param session The session object of the command
|
* @param session The session object of the command
|
||||||
* @param response The response object to write the handle or virtual handle to
|
* @param response The response object to write the handle or virtual handle to
|
||||||
*/
|
*/
|
||||||
std::shared_ptr<BaseService> NewService(const std::string &serviceName, type::KSession &session, ipc::IpcResponse &response);
|
std::shared_ptr<BaseService> NewService(ServiceName name, type::KSession &session, ipc::IpcResponse &response);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Registers a service object in the manager and writes it's handle or virtual handle (If it's a domain request) to IpcResponse
|
* @brief Registers a service object in the manager and writes it's handle or virtual handle (If it's a domain request) to IpcResponse
|
||||||
@ -51,8 +47,9 @@ namespace skyline::service {
|
|||||||
* @param session The session object of the command
|
* @param session The session object of the command
|
||||||
* @param response The response object to write the handle or virtual handle to
|
* @param response The response object to write the handle or virtual handle to
|
||||||
* @param submodule If the registered service is a submodule or not
|
* @param submodule If the registered service is a submodule or not
|
||||||
|
* @param name The name of the service to register if it's not a submodule - it will be added to the service map
|
||||||
*/
|
*/
|
||||||
void RegisterService(std::shared_ptr<BaseService> serviceObject, type::KSession &session, ipc::IpcResponse &response, bool submodule = true);
|
void RegisterService(std::shared_ptr<BaseService> serviceObject, type::KSession &session, ipc::IpcResponse &response, bool submodule = true, ServiceName name = {});
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param serviceType The type of the service
|
* @param serviceType The type of the service
|
||||||
@ -61,8 +58,13 @@ namespace skyline::service {
|
|||||||
* @note This only works for services created with `NewService` as sub-interfaces used with `RegisterService` can have multiple instances
|
* @note This only works for services created with `NewService` as sub-interfaces used with `RegisterService` can have multiple instances
|
||||||
*/
|
*/
|
||||||
template<typename Type>
|
template<typename Type>
|
||||||
inline std::shared_ptr<Type> GetService(Service serviceType) {
|
std::shared_ptr<Type> GetService(ServiceName name) {
|
||||||
return std::static_pointer_cast<Type>(serviceMap.at(serviceType));
|
return std::static_pointer_cast<Type>(serviceMap.at(name));
|
||||||
|
}
|
||||||
|
|
||||||
|
template<typename Type>
|
||||||
|
constexpr std::shared_ptr<Type> GetService(std::string_view name) {
|
||||||
|
return GetService<Type>(util::MakeMagic<ServiceName>(name));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "ISettingsServer.h"
|
#include "ISettingsServer.h"
|
||||||
|
|
||||||
namespace skyline::service::settings {
|
namespace skyline::service::settings {
|
||||||
ISettingsServer::ISettingsServer(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::settings_ISettingsServer, "settings:ISettingsServer", {
|
ISettingsServer::ISettingsServer(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x1, SFUNC(ISettingsServer::GetAvailableLanguageCodes)},
|
{0x1, SFUNC(ISettingsServer::GetAvailableLanguageCodes)},
|
||||||
{0x2, SFUNC(ISettingsServer::MakeLanguageCode)},
|
{0x2, SFUNC(ISettingsServer::MakeLanguageCode)},
|
||||||
{0x5, SFUNC(ISettingsServer::GetAvailableLanguageCodes2)}
|
{0x5, SFUNC(ISettingsServer::GetAvailableLanguageCodes2)}
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "ISystemSettingsServer.h"
|
#include "ISystemSettingsServer.h"
|
||||||
|
|
||||||
namespace skyline::service::settings {
|
namespace skyline::service::settings {
|
||||||
ISystemSettingsServer::ISystemSettingsServer(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::settings_ISystemSettingsServer, "settings:ISystemSettingsServer", {
|
ISystemSettingsServer::ISystemSettingsServer(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x3, SFUNC(ISystemSettingsServer::GetFirmwareVersion)}}) {}
|
{0x3, SFUNC(ISystemSettingsServer::GetFirmwareVersion)}}) {}
|
||||||
|
|
||||||
void ISystemSettingsServer::GetFirmwareVersion(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
void ISystemSettingsServer::GetFirmwareVersion(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
#include "IUserInterface.h"
|
#include "IUserInterface.h"
|
||||||
|
|
||||||
namespace skyline::service::sm {
|
namespace skyline::service::sm {
|
||||||
IUserInterface::IUserInterface(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::sm_IUserInterface, "sm:IUserInterface", {
|
IUserInterface::IUserInterface(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IUserInterface::Initialize)},
|
{0x0, SFUNC(IUserInterface::Initialize)},
|
||||||
{0x1, SFUNC(IUserInterface::GetService)}
|
{0x1, SFUNC(IUserInterface::GetService)}
|
||||||
}) {}
|
}) {}
|
||||||
@ -12,18 +12,18 @@ namespace skyline::service::sm {
|
|||||||
void IUserInterface::Initialize(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {}
|
void IUserInterface::Initialize(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {}
|
||||||
|
|
||||||
void IUserInterface::GetService(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
void IUserInterface::GetService(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
||||||
std::string serviceName(request.PopString());
|
auto name = request.Pop<ServiceName>();
|
||||||
serviceName.resize(std::min(8UL, serviceName.size()));
|
|
||||||
|
|
||||||
if (serviceName.empty()) {
|
if (name) {
|
||||||
response.errorCode = constant::status::ServiceInvName;
|
|
||||||
} else {
|
|
||||||
try {
|
try {
|
||||||
manager.NewService(serviceName, session, response);
|
manager.NewService(name, session, response);
|
||||||
} catch (std::out_of_range &) {
|
} catch (std::out_of_range &) {
|
||||||
response.errorCode = constant::status::ServiceNotReg;
|
response.errorCode = constant::status::ServiceNotReg;
|
||||||
state.logger->Warn("Service has not been implemented: \"{}\"", serviceName);
|
std::string_view stringName(reinterpret_cast<char *>(&name), sizeof(u64));
|
||||||
}
|
state.logger->Warn("Service has not been implemented: \"{}\"", stringName);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
response.errorCode = constant::status::ServiceInvName;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
#include "IClient.h"
|
#include "IClient.h"
|
||||||
|
|
||||||
namespace skyline::service::socket {
|
namespace skyline::service::socket {
|
||||||
IClient::IClient(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::socket_IClient, "socket:IClient", {
|
IClient::IClient(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IClient::RegisterClient)},
|
{0x0, SFUNC(IClient::RegisterClient)},
|
||||||
{0x1, SFUNC(IClient::StartMonitoring)},
|
{0x1, SFUNC(IClient::StartMonitoring)},
|
||||||
}) {}
|
}) {}
|
||||||
|
@ -4,6 +4,6 @@
|
|||||||
#include "ISslContext.h"
|
#include "ISslContext.h"
|
||||||
|
|
||||||
namespace skyline::service::ssl {
|
namespace skyline::service::ssl {
|
||||||
ISslContext::ISslContext(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::ssl_ISslContext, "ssl:ISslContext", {
|
ISslContext::ISslContext(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
}) {}
|
}) {}
|
||||||
}
|
}
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "ISslService.h"
|
#include "ISslService.h"
|
||||||
|
|
||||||
namespace skyline::service::ssl {
|
namespace skyline::service::ssl {
|
||||||
ISslService::ISslService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::ssl_ISslService, "ssl:ISslService", {
|
ISslService::ISslService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(ISslService::CreateContext)},
|
{0x0, SFUNC(ISslService::CreateContext)},
|
||||||
{0x5, SFUNC(ISslService::SetInterfaceVersion)}
|
{0x5, SFUNC(ISslService::SetInterfaceVersion)}
|
||||||
}) {}
|
}) {}
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
#include "IStaticService.h"
|
#include "IStaticService.h"
|
||||||
|
|
||||||
namespace skyline::service::timesrv {
|
namespace skyline::service::timesrv {
|
||||||
IStaticService::IStaticService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::timesrv_IStaticService, "timesrv:IStaticService", {
|
IStaticService::IStaticService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(IStaticService::GetStandardUserSystemClock)},
|
{0x0, SFUNC(IStaticService::GetStandardUserSystemClock)},
|
||||||
{0x1, SFUNC(IStaticService::GetStandardNetworkSystemClock)},
|
{0x1, SFUNC(IStaticService::GetStandardNetworkSystemClock)},
|
||||||
{0x2, SFUNC(IStaticService::GetStandardSteadyClock)},
|
{0x2, SFUNC(IStaticService::GetStandardSteadyClock)},
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
#include "ISteadyClock.h"
|
#include "ISteadyClock.h"
|
||||||
|
|
||||||
namespace skyline::service::timesrv {
|
namespace skyline::service::timesrv {
|
||||||
ISteadyClock::ISteadyClock(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::timesrv_ISteadyClock, "timesrv:ISteadyClock", {
|
ISteadyClock::ISteadyClock(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x0, SFUNC(ISteadyClock::GetCurrentTimePoint)}
|
{0x0, SFUNC(ISteadyClock::GetCurrentTimePoint)}
|
||||||
}) {}
|
}) {}
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include "ISystemClock.h"
|
#include "ISystemClock.h"
|
||||||
|
|
||||||
namespace skyline::service::timesrv {
|
namespace skyline::service::timesrv {
|
||||||
ISystemClock::ISystemClock(const SystemClockType clockType, const DeviceState &state, ServiceManager &manager) : type(clockType), BaseService(state, manager, Service::timesrv_ISystemClock, "timesrv:ISystemClock", {
|
ISystemClock::ISystemClock(const SystemClockType clockType, const DeviceState &state, ServiceManager &manager) : type(clockType), BaseService(state, manager, {
|
||||||
{0x0, SFUNC(ISystemClock::GetCurrentTime)},
|
{0x0, SFUNC(ISystemClock::GetCurrentTime)},
|
||||||
{0x2, SFUNC(ISystemClock::GetSystemClockContext)}
|
{0x2, SFUNC(ISystemClock::GetSystemClockContext)}
|
||||||
}) {}
|
}) {}
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
#include "ITimeZoneService.h"
|
#include "ITimeZoneService.h"
|
||||||
|
|
||||||
namespace skyline::service::timesrv {
|
namespace skyline::service::timesrv {
|
||||||
ITimeZoneService::ITimeZoneService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::timesrv_ITimeZoneService, "timesrv:ITimeZoneService", {
|
ITimeZoneService::ITimeZoneService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x65, SFUNC(ITimeZoneService::ToCalendarTimeWithMyRule)}
|
{0x65, SFUNC(ITimeZoneService::ToCalendarTimeWithMyRule)}
|
||||||
}) {}
|
}) {}
|
||||||
|
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
#include "IManagerDisplayService.h"
|
#include "IManagerDisplayService.h"
|
||||||
|
|
||||||
namespace skyline::service::visrv {
|
namespace skyline::service::visrv {
|
||||||
IApplicationDisplayService::IApplicationDisplayService(const DeviceState &state, ServiceManager &manager) : IDisplayService(state, manager, Service::visrv_IApplicationDisplayService, "visrv:IApplicationDisplayService", {
|
IApplicationDisplayService::IApplicationDisplayService(const DeviceState &state, ServiceManager &manager) : IDisplayService(state, manager, {
|
||||||
{0x64, SFUNC(IApplicationDisplayService::GetRelayService)},
|
{0x64, SFUNC(IApplicationDisplayService::GetRelayService)},
|
||||||
{0x65, SFUNC(IApplicationDisplayService::GetSystemDisplayService)},
|
{0x65, SFUNC(IApplicationDisplayService::GetSystemDisplayService)},
|
||||||
{0x66, SFUNC(IApplicationDisplayService::GetManagerDisplayService)},
|
{0x66, SFUNC(IApplicationDisplayService::GetManagerDisplayService)},
|
||||||
@ -25,11 +25,11 @@ namespace skyline::service::visrv {
|
|||||||
}) {}
|
}) {}
|
||||||
|
|
||||||
void IApplicationDisplayService::GetRelayService(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
void IApplicationDisplayService::GetRelayService(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
||||||
manager.RegisterService(SRVREG(hosbinder::IHOSBinderDriver), session, response, false);
|
manager.RegisterService(SRVREG(hosbinder::IHOSBinderDriver), session, response, false, util::MakeMagic<ServiceName>("dispdrv"));
|
||||||
}
|
}
|
||||||
|
|
||||||
void IApplicationDisplayService::GetIndirectDisplayTransactionService(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
void IApplicationDisplayService::GetIndirectDisplayTransactionService(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
||||||
manager.RegisterService(SRVREG(hosbinder::IHOSBinderDriver), session, response, false);
|
manager.RegisterService(SRVREG(hosbinder::IHOSBinderDriver), session, response, false, util::MakeMagic<ServiceName>("dispdrv"));
|
||||||
}
|
}
|
||||||
|
|
||||||
void IApplicationDisplayService::GetSystemDisplayService(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
void IApplicationDisplayService::GetSystemDisplayService(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
||||||
@ -43,14 +43,14 @@ namespace skyline::service::visrv {
|
|||||||
void IApplicationDisplayService::OpenDisplay(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
void IApplicationDisplayService::OpenDisplay(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
||||||
std::string displayName(request.PopString());
|
std::string displayName(request.PopString());
|
||||||
state.logger->Debug("Setting display as: {}", displayName);
|
state.logger->Debug("Setting display as: {}", displayName);
|
||||||
state.os->serviceManager.GetService<hosbinder::IHOSBinderDriver>(Service::hosbinder_IHOSBinderDriver)->SetDisplay(displayName);
|
state.os->serviceManager.GetService<hosbinder::IHOSBinderDriver>("dispdrv")->SetDisplay(displayName);
|
||||||
|
|
||||||
response.Push<u64>(0); // There's only one display
|
response.Push<u64>(0); // There's only one display
|
||||||
}
|
}
|
||||||
|
|
||||||
void IApplicationDisplayService::CloseDisplay(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
void IApplicationDisplayService::CloseDisplay(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
||||||
state.logger->Debug("Closing the display");
|
state.logger->Debug("Closing the display");
|
||||||
state.os->serviceManager.GetService<hosbinder::IHOSBinderDriver>(Service::hosbinder_IHOSBinderDriver)->CloseDisplay();
|
state.os->serviceManager.GetService<hosbinder::IHOSBinderDriver>("dispdrv")->CloseDisplay();
|
||||||
}
|
}
|
||||||
|
|
||||||
void IApplicationDisplayService::OpenLayer(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
void IApplicationDisplayService::OpenLayer(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
||||||
@ -80,7 +80,7 @@ namespace skyline::service::visrv {
|
|||||||
u64 layerId = request.Pop<u64>();
|
u64 layerId = request.Pop<u64>();
|
||||||
state.logger->Debug("Closing Layer: {}", layerId);
|
state.logger->Debug("Closing Layer: {}", layerId);
|
||||||
|
|
||||||
auto hosBinder = state.os->serviceManager.GetService<hosbinder::IHOSBinderDriver>(Service::hosbinder_IHOSBinderDriver);
|
auto hosBinder = state.os->serviceManager.GetService<hosbinder::IHOSBinderDriver>("dispdrv");
|
||||||
if (hosBinder->layerStatus == hosbinder::LayerStatus::Uninitialized)
|
if (hosBinder->layerStatus == hosbinder::LayerStatus::Uninitialized)
|
||||||
state.logger->Warn("The application is destroying an uninitialized layer");
|
state.logger->Warn("The application is destroying an uninitialized layer");
|
||||||
hosBinder->layerStatus = hosbinder::LayerStatus::Uninitialized;
|
hosBinder->layerStatus = hosbinder::LayerStatus::Uninitialized;
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
#include "IDisplayService.h"
|
#include "IDisplayService.h"
|
||||||
|
|
||||||
namespace skyline::service::visrv {
|
namespace skyline::service::visrv {
|
||||||
IDisplayService::IDisplayService(const DeviceState &state, ServiceManager &manager, const Service serviceType, const std::string &serviceName, const std::unordered_map<u32, std::function<void(type::KSession &, ipc::IpcRequest &, ipc::IpcResponse &)>> &vTable) : BaseService(state, manager, serviceType, serviceName, vTable) {}
|
IDisplayService::IDisplayService(const DeviceState &state, ServiceManager &manager, const std::unordered_map<u32, std::function<void(type::KSession &, ipc::IpcRequest &, ipc::IpcResponse &)>> &vTable) : BaseService(state, manager, vTable) {}
|
||||||
|
|
||||||
void IDisplayService::CreateStrayLayer(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
void IDisplayService::CreateStrayLayer(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
||||||
request.Skip<u64>();
|
request.Skip<u64>();
|
||||||
@ -15,7 +15,7 @@ namespace skyline::service::visrv {
|
|||||||
|
|
||||||
state.logger->Debug("Creating Stray Layer on Display: {}", displayId);
|
state.logger->Debug("Creating Stray Layer on Display: {}", displayId);
|
||||||
|
|
||||||
auto hosBinder = state.os->serviceManager.GetService<hosbinder::IHOSBinderDriver>(Service::hosbinder_IHOSBinderDriver);
|
auto hosBinder = state.os->serviceManager.GetService<hosbinder::IHOSBinderDriver>("dispdrv");
|
||||||
if (hosBinder->layerStatus == hosbinder::LayerStatus::Stray)
|
if (hosBinder->layerStatus == hosbinder::LayerStatus::Stray)
|
||||||
throw exception("The application is creating more than one stray layer");
|
throw exception("The application is creating more than one stray layer");
|
||||||
hosBinder->layerStatus = hosbinder::LayerStatus::Stray;
|
hosBinder->layerStatus = hosbinder::LayerStatus::Stray;
|
||||||
@ -37,7 +37,7 @@ namespace skyline::service::visrv {
|
|||||||
auto layerId = request.Pop<u64>();
|
auto layerId = request.Pop<u64>();
|
||||||
state.logger->Debug("Destroying Stray Layer: {}", layerId);
|
state.logger->Debug("Destroying Stray Layer: {}", layerId);
|
||||||
|
|
||||||
auto hosBinder = state.os->serviceManager.GetService<hosbinder::IHOSBinderDriver>(Service::hosbinder_IHOSBinderDriver);
|
auto hosBinder = state.os->serviceManager.GetService<hosbinder::IHOSBinderDriver>("dispdrv");
|
||||||
if (hosBinder->layerStatus == hosbinder::LayerStatus::Uninitialized)
|
if (hosBinder->layerStatus == hosbinder::LayerStatus::Uninitialized)
|
||||||
state.logger->Warn("The application is destroying an uninitialized layer");
|
state.logger->Warn("The application is destroying an uninitialized layer");
|
||||||
hosBinder->layerStatus = hosbinder::LayerStatus::Uninitialized;
|
hosBinder->layerStatus = hosbinder::LayerStatus::Uninitialized;
|
||||||
|
@ -27,7 +27,7 @@ namespace skyline::service::visrv {
|
|||||||
static_assert(sizeof(LayerParcel) == 0x28);
|
static_assert(sizeof(LayerParcel) == 0x28);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
IDisplayService(const DeviceState &state, ServiceManager &manager, const Service serviceType, const std::string &serviceName, const std::unordered_map<u32, std::function<void(type::KSession & , ipc::IpcRequest & , ipc::IpcResponse & )>> &vTable);
|
IDisplayService(const DeviceState &state, ServiceManager &manager, const std::unordered_map<u32, std::function<void(type::KSession & , ipc::IpcRequest & , ipc::IpcResponse & )>> &vTable);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This creates a stray layer using a display's ID and returns a layer ID and the corresponding buffer ID
|
* @brief This creates a stray layer using a display's ID and returns a layer ID and the corresponding buffer ID
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
#include "IManagerDisplayService.h"
|
#include "IManagerDisplayService.h"
|
||||||
|
|
||||||
namespace skyline::service::visrv {
|
namespace skyline::service::visrv {
|
||||||
IManagerDisplayService::IManagerDisplayService(const DeviceState &state, ServiceManager &manager) : IDisplayService(state, manager, Service::visrv_IManagerDisplayService, "visrv:IManagerDisplayService", {
|
IManagerDisplayService::IManagerDisplayService(const DeviceState &state, ServiceManager &manager) : IDisplayService(state, manager, {
|
||||||
{0x7DA, SFUNC(IManagerDisplayService::CreateManagedLayer)},
|
{0x7DA, SFUNC(IManagerDisplayService::CreateManagedLayer)},
|
||||||
{0x7DB, SFUNC(IManagerDisplayService::DestroyManagedLayer)},
|
{0x7DB, SFUNC(IManagerDisplayService::DestroyManagedLayer)},
|
||||||
{0x7DC, SFUNC(IDisplayService::CreateStrayLayer)},
|
{0x7DC, SFUNC(IDisplayService::CreateStrayLayer)},
|
||||||
@ -19,7 +19,7 @@ namespace skyline::service::visrv {
|
|||||||
auto displayId = request.Pop<u64>();
|
auto displayId = request.Pop<u64>();
|
||||||
state.logger->Debug("Creating Managed Layer on Display: {}", displayId);
|
state.logger->Debug("Creating Managed Layer on Display: {}", displayId);
|
||||||
|
|
||||||
auto hosBinder = state.os->serviceManager.GetService<hosbinder::IHOSBinderDriver>(Service::hosbinder_IHOSBinderDriver);
|
auto hosBinder = state.os->serviceManager.GetService<hosbinder::IHOSBinderDriver>("dispdrv");
|
||||||
if (hosBinder->layerStatus != hosbinder::LayerStatus::Uninitialized)
|
if (hosBinder->layerStatus != hosbinder::LayerStatus::Uninitialized)
|
||||||
throw exception("The application is creating more than one layer");
|
throw exception("The application is creating more than one layer");
|
||||||
hosBinder->layerStatus = hosbinder::LayerStatus::Managed;
|
hosBinder->layerStatus = hosbinder::LayerStatus::Managed;
|
||||||
@ -31,7 +31,7 @@ namespace skyline::service::visrv {
|
|||||||
auto layerId = request.Pop<u64>();
|
auto layerId = request.Pop<u64>();
|
||||||
state.logger->Debug("Destroying Managed Layer: {}", layerId);
|
state.logger->Debug("Destroying Managed Layer: {}", layerId);
|
||||||
|
|
||||||
auto hosBinder = state.os->serviceManager.GetService<hosbinder::IHOSBinderDriver>(Service::hosbinder_IHOSBinderDriver);
|
auto hosBinder = state.os->serviceManager.GetService<hosbinder::IHOSBinderDriver>("dispdrv");
|
||||||
if (hosBinder->layerStatus == hosbinder::LayerStatus::Uninitialized)
|
if (hosBinder->layerStatus == hosbinder::LayerStatus::Uninitialized)
|
||||||
state.logger->Warn("The application is destroying an uninitialized layer");
|
state.logger->Warn("The application is destroying an uninitialized layer");
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
#include "IApplicationDisplayService.h"
|
#include "IApplicationDisplayService.h"
|
||||||
|
|
||||||
namespace skyline::service::visrv {
|
namespace skyline::service::visrv {
|
||||||
IManagerRootService::IManagerRootService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, Service::visrv_IManagerRootService, "visrv:IManagerRootService", {
|
IManagerRootService::IManagerRootService(const DeviceState &state, ServiceManager &manager) : BaseService(state, manager, {
|
||||||
{0x2, SFUNC(IManagerRootService::GetDisplayService)}
|
{0x2, SFUNC(IManagerRootService::GetDisplayService)}
|
||||||
}) {}
|
}) {}
|
||||||
|
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
#include "ISystemDisplayService.h"
|
#include "ISystemDisplayService.h"
|
||||||
|
|
||||||
namespace skyline::service::visrv {
|
namespace skyline::service::visrv {
|
||||||
ISystemDisplayService::ISystemDisplayService(const DeviceState &state, ServiceManager &manager) : IDisplayService(state, manager, Service::visrv_ISystemDisplayService, "visrv:ISystemDisplayService", {
|
ISystemDisplayService::ISystemDisplayService(const DeviceState &state, ServiceManager &manager) : IDisplayService(state, manager, {
|
||||||
{0x89D, SFUNC(ISystemDisplayService::SetLayerZ)},
|
{0x89D, SFUNC(ISystemDisplayService::SetLayerZ)},
|
||||||
{0x908, SFUNC(IDisplayService::CreateStrayLayer)}
|
{0x908, SFUNC(IDisplayService::CreateStrayLayer)}
|
||||||
}) {}
|
}) {}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user