forked from eden-emu/eden
		
	service: Eliminate usages of the global system instance
Completely removes all usages of the global system instance within the services code by passing in the using system instance to the services.
This commit is contained in:
		
							parent
							
								
									322349e8cc
								
							
						
					
					
						commit
						1a954b2a59
					
				
					 222 changed files with 1221 additions and 907 deletions
				
			
		|  | @ -47,8 +47,8 @@ static constexpr u32 SanitizeJPEGSize(std::size_t size) { | |||
| 
 | ||||
| class IManagerForSystemService final : public ServiceFramework<IManagerForSystemService> { | ||||
| public: | ||||
|     explicit IManagerForSystemService(Common::UUID user_id) | ||||
|         : ServiceFramework("IManagerForSystemService") { | ||||
|     explicit IManagerForSystemService(Core::System& system_, Common::UUID) | ||||
|         : ServiceFramework{system_, "IManagerForSystemService"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "CheckAvailability"}, | ||||
|  | @ -83,8 +83,8 @@ public: | |||
| // 3.0.0+
 | ||||
| class IFloatingRegistrationRequest final : public ServiceFramework<IFloatingRegistrationRequest> { | ||||
| public: | ||||
|     explicit IFloatingRegistrationRequest(Common::UUID user_id) | ||||
|         : ServiceFramework("IFloatingRegistrationRequest") { | ||||
|     explicit IFloatingRegistrationRequest(Core::System& system_, Common::UUID) | ||||
|         : ServiceFramework{system_, "IFloatingRegistrationRequest"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "GetSessionId"}, | ||||
|  | @ -108,7 +108,8 @@ public: | |||
| 
 | ||||
| class IAdministrator final : public ServiceFramework<IAdministrator> { | ||||
| public: | ||||
|     explicit IAdministrator(Common::UUID user_id) : ServiceFramework("IAdministrator") { | ||||
|     explicit IAdministrator(Core::System& system_, Common::UUID) | ||||
|         : ServiceFramework{system_, "IAdministrator"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "CheckAvailability"}, | ||||
|  | @ -165,8 +166,8 @@ public: | |||
| 
 | ||||
| class IAuthorizationRequest final : public ServiceFramework<IAuthorizationRequest> { | ||||
| public: | ||||
|     explicit IAuthorizationRequest(Common::UUID user_id) | ||||
|         : ServiceFramework("IAuthorizationRequest") { | ||||
|     explicit IAuthorizationRequest(Core::System& system_, Common::UUID) | ||||
|         : ServiceFramework{system_, "IAuthorizationRequest"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "GetSessionId"}, | ||||
|  | @ -184,7 +185,8 @@ public: | |||
| 
 | ||||
| class IOAuthProcedure final : public ServiceFramework<IOAuthProcedure> { | ||||
| public: | ||||
|     explicit IOAuthProcedure(Common::UUID user_id) : ServiceFramework("IOAuthProcedure") { | ||||
|     explicit IOAuthProcedure(Core::System& system_, Common::UUID) | ||||
|         : ServiceFramework{system_, "IOAuthProcedure"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "PrepareAsync"}, | ||||
|  | @ -202,8 +204,8 @@ public: | |||
| // 3.0.0+
 | ||||
| class IOAuthProcedureForExternalNsa final : public ServiceFramework<IOAuthProcedureForExternalNsa> { | ||||
| public: | ||||
|     explicit IOAuthProcedureForExternalNsa(Common::UUID user_id) | ||||
|         : ServiceFramework("IOAuthProcedureForExternalNsa") { | ||||
|     explicit IOAuthProcedureForExternalNsa(Core::System& system_, Common::UUID) | ||||
|         : ServiceFramework{system_, "IOAuthProcedureForExternalNsa"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "PrepareAsync"}, | ||||
|  | @ -225,8 +227,8 @@ public: | |||
| class IOAuthProcedureForNintendoAccountLinkage final | ||||
|     : public ServiceFramework<IOAuthProcedureForNintendoAccountLinkage> { | ||||
| public: | ||||
|     explicit IOAuthProcedureForNintendoAccountLinkage(Common::UUID user_id) | ||||
|         : ServiceFramework("IOAuthProcedureForNintendoAccountLinkage") { | ||||
|     explicit IOAuthProcedureForNintendoAccountLinkage(Core::System& system_, Common::UUID) | ||||
|         : ServiceFramework{system_, "IOAuthProcedureForNintendoAccountLinkage"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "PrepareAsync"}, | ||||
|  | @ -246,7 +248,8 @@ public: | |||
| 
 | ||||
| class INotifier final : public ServiceFramework<INotifier> { | ||||
| public: | ||||
|     explicit INotifier(Common::UUID user_id) : ServiceFramework("INotifier") { | ||||
|     explicit INotifier(Core::System& system_, Common::UUID) | ||||
|         : ServiceFramework{system_, "INotifier"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "GetSystemEvent"}, | ||||
|  | @ -259,9 +262,9 @@ public: | |||
| 
 | ||||
| class IProfileCommon : public ServiceFramework<IProfileCommon> { | ||||
| public: | ||||
|     explicit IProfileCommon(const char* name, bool editor_commands, Common::UUID user_id, | ||||
|                             ProfileManager& profile_manager) | ||||
|         : ServiceFramework(name), profile_manager(profile_manager), user_id(user_id) { | ||||
|     explicit IProfileCommon(Core::System& system_, const char* name, bool editor_commands, | ||||
|                             Common::UUID user_id_, ProfileManager& profile_manager_) | ||||
|         : ServiceFramework{system_, name}, profile_manager{profile_manager_}, user_id{user_id_} { | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &IProfileCommon::Get, "Get"}, | ||||
|             {1, &IProfileCommon::GetBase, "GetBase"}, | ||||
|  | @ -427,19 +430,21 @@ protected: | |||
| 
 | ||||
| class IProfile final : public IProfileCommon { | ||||
| public: | ||||
|     IProfile(Common::UUID user_id, ProfileManager& profile_manager) | ||||
|         : IProfileCommon("IProfile", false, user_id, profile_manager) {} | ||||
|     explicit IProfile(Core::System& system_, Common::UUID user_id_, | ||||
|                       ProfileManager& profile_manager_) | ||||
|         : IProfileCommon{system_, "IProfile", false, user_id_, profile_manager_} {} | ||||
| }; | ||||
| 
 | ||||
| class IProfileEditor final : public IProfileCommon { | ||||
| public: | ||||
|     IProfileEditor(Common::UUID user_id, ProfileManager& profile_manager) | ||||
|         : IProfileCommon("IProfileEditor", true, user_id, profile_manager) {} | ||||
|     explicit IProfileEditor(Core::System& system_, Common::UUID user_id_, | ||||
|                             ProfileManager& profile_manager_) | ||||
|         : IProfileCommon{system_, "IProfileEditor", true, user_id_, profile_manager_} {} | ||||
| }; | ||||
| 
 | ||||
| class IAsyncContext final : public ServiceFramework<IAsyncContext> { | ||||
| public: | ||||
|     explicit IAsyncContext(Common::UUID user_id) : ServiceFramework("IAsyncContext") { | ||||
|     explicit IAsyncContext(Core::System& system_) : ServiceFramework{system_, "IAsyncContext"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "GetSystemEvent"}, | ||||
|  | @ -455,7 +460,8 @@ public: | |||
| 
 | ||||
| class ISessionObject final : public ServiceFramework<ISessionObject> { | ||||
| public: | ||||
|     explicit ISessionObject(Common::UUID user_id) : ServiceFramework("ISessionObject") { | ||||
|     explicit ISessionObject(Core::System& system_, Common::UUID) | ||||
|         : ServiceFramework{system_, "ISessionObject"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {999, nullptr, "Dummy"}, | ||||
|  | @ -468,7 +474,8 @@ public: | |||
| 
 | ||||
| class IGuestLoginRequest final : public ServiceFramework<IGuestLoginRequest> { | ||||
| public: | ||||
|     explicit IGuestLoginRequest(Common::UUID) : ServiceFramework("IGuestLoginRequest") { | ||||
|     explicit IGuestLoginRequest(Core::System& system_, Common::UUID) | ||||
|         : ServiceFramework{system_, "IGuestLoginRequest"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "GetSessionId"}, | ||||
|  | @ -487,8 +494,8 @@ public: | |||
| 
 | ||||
| class IManagerForApplication final : public ServiceFramework<IManagerForApplication> { | ||||
| public: | ||||
|     explicit IManagerForApplication(Common::UUID user_id) | ||||
|         : ServiceFramework("IManagerForApplication"), user_id(user_id) { | ||||
|     explicit IManagerForApplication(Core::System& system_, Common::UUID user_id_) | ||||
|         : ServiceFramework{system_, "IManagerForApplication"}, user_id{user_id_} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &IManagerForApplication::CheckAvailability, "CheckAvailability"}, | ||||
|  | @ -534,8 +541,8 @@ private: | |||
| class IAsyncNetworkServiceLicenseKindContext final | ||||
|     : public ServiceFramework<IAsyncNetworkServiceLicenseKindContext> { | ||||
| public: | ||||
|     explicit IAsyncNetworkServiceLicenseKindContext(Common::UUID user_id) | ||||
|         : ServiceFramework("IAsyncNetworkServiceLicenseKindContext") { | ||||
|     explicit IAsyncNetworkServiceLicenseKindContext(Core::System& system_, Common::UUID) | ||||
|         : ServiceFramework{system_, "IAsyncNetworkServiceLicenseKindContext"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "GetSystemEvent"}, | ||||
|  | @ -554,8 +561,8 @@ public: | |||
| class IOAuthProcedureForUserRegistration final | ||||
|     : public ServiceFramework<IOAuthProcedureForUserRegistration> { | ||||
| public: | ||||
|     explicit IOAuthProcedureForUserRegistration(Common::UUID user_id) | ||||
|         : ServiceFramework("IOAuthProcedureForUserRegistration") { | ||||
|     explicit IOAuthProcedureForUserRegistration(Core::System& system_, Common::UUID) | ||||
|         : ServiceFramework{system_, "IOAuthProcedureForUserRegistration"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "PrepareAsync"}, | ||||
|  | @ -578,7 +585,7 @@ public: | |||
| 
 | ||||
| class DAUTH_O final : public ServiceFramework<DAUTH_O> { | ||||
| public: | ||||
|     explicit DAUTH_O(Common::UUID) : ServiceFramework("dauth:o") { | ||||
|     explicit DAUTH_O(Core::System& system_, Common::UUID) : ServiceFramework{system_, "dauth:o"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "EnsureAuthenticationTokenCacheAsync"}, // [5.0.0-5.1.0] GeneratePostData
 | ||||
|  | @ -597,7 +604,8 @@ public: | |||
| // 6.0.0+
 | ||||
| class IAsyncResult final : public ServiceFramework<IAsyncResult> { | ||||
| public: | ||||
|     explicit IAsyncResult(Common::UUID user_id) : ServiceFramework("IAsyncResult") { | ||||
|     explicit IAsyncResult(Core::System& system_, Common::UUID) | ||||
|         : ServiceFramework{system_, "IAsyncResult"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "GetResult"}, | ||||
|  | @ -656,7 +664,7 @@ void Module::Interface::GetProfile(Kernel::HLERequestContext& ctx) { | |||
| 
 | ||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushIpcInterface<IProfile>(user_id, *profile_manager); | ||||
|     rb.PushIpcInterface<IProfile>(system, user_id, *profile_manager); | ||||
| } | ||||
| 
 | ||||
| void Module::Interface::IsUserRegistrationRequestPermitted(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -731,7 +739,7 @@ void Module::Interface::GetBaasAccountManagerForApplication(Kernel::HLERequestCo | |||
|     LOG_DEBUG(Service_ACC, "called"); | ||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushIpcInterface<IManagerForApplication>(profile_manager->GetLastOpenedUser()); | ||||
|     rb.PushIpcInterface<IManagerForApplication>(system, profile_manager->GetLastOpenedUser()); | ||||
| } | ||||
| 
 | ||||
| void Module::Interface::IsUserAccountSwitchLocked(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -769,7 +777,7 @@ void Module::Interface::GetProfileEditor(Kernel::HLERequestContext& ctx) { | |||
| 
 | ||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushIpcInterface<IProfileEditor>(user_id, *profile_manager); | ||||
|     rb.PushIpcInterface<IProfileEditor>(system, user_id, *profile_manager); | ||||
| } | ||||
| 
 | ||||
| void Module::Interface::ListQualifiedUsers(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -791,7 +799,7 @@ void Module::Interface::LoadOpenContext(Kernel::HLERequestContext& ctx) { | |||
|     // TODO: Find the differences between this and GetBaasAccountManagerForApplication
 | ||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushIpcInterface<IManagerForApplication>(profile_manager->GetLastOpenedUser()); | ||||
|     rb.PushIpcInterface<IManagerForApplication>(system, profile_manager->GetLastOpenedUser()); | ||||
| } | ||||
| 
 | ||||
| void Module::Interface::ListOpenContextStoredUsers(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -827,11 +835,11 @@ void Module::Interface::TrySelectUserWithoutInteraction(Kernel::HLERequestContex | |||
|     rb.PushRaw<u128>(profile_manager->GetUser(0)->uuid); | ||||
| } | ||||
| 
 | ||||
| Module::Interface::Interface(std::shared_ptr<Module> module, | ||||
|                              std::shared_ptr<ProfileManager> profile_manager, Core::System& system, | ||||
|                              const char* name) | ||||
|     : ServiceFramework(name), module(std::move(module)), | ||||
|       profile_manager(std::move(profile_manager)), system(system) {} | ||||
| Module::Interface::Interface(std::shared_ptr<Module> module_, | ||||
|                              std::shared_ptr<ProfileManager> profile_manager_, | ||||
|                              Core::System& system_, const char* name) | ||||
|     : ServiceFramework{system_, name}, module{std::move(module_)}, profile_manager{std::move( | ||||
|                                                                        profile_manager_)} {} | ||||
| 
 | ||||
| Module::Interface::~Interface() = default; | ||||
| 
 | ||||
|  |  | |||
|  | @ -15,8 +15,8 @@ class Module final { | |||
| public: | ||||
|     class Interface : public ServiceFramework<Interface> { | ||||
|     public: | ||||
|         explicit Interface(std::shared_ptr<Module> module, | ||||
|                            std::shared_ptr<ProfileManager> profile_manager, Core::System& system, | ||||
|         explicit Interface(std::shared_ptr<Module> module_, | ||||
|                            std::shared_ptr<ProfileManager> profile_manager_, Core::System& system_, | ||||
|                            const char* name); | ||||
|         ~Interface() override; | ||||
| 
 | ||||
|  | @ -60,7 +60,6 @@ public: | |||
|     protected: | ||||
|         std::shared_ptr<Module> module; | ||||
|         std::shared_ptr<ProfileManager> profile_manager; | ||||
|         Core::System& system; | ||||
|     }; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -64,7 +64,7 @@ struct LaunchParameterAccountPreselectedUser { | |||
| static_assert(sizeof(LaunchParameterAccountPreselectedUser) == 0x88); | ||||
| 
 | ||||
| IWindowController::IWindowController(Core::System& system_) | ||||
|     : ServiceFramework("IWindowController"), system{system_} { | ||||
|     : ServiceFramework{system_, "IWindowController"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "CreateWindow"}, | ||||
|  | @ -99,7 +99,8 @@ void IWindowController::AcquireForegroundRights(Kernel::HLERequestContext& ctx) | |||
|     rb.Push(RESULT_SUCCESS); | ||||
| } | ||||
| 
 | ||||
| IAudioController::IAudioController() : ServiceFramework("IAudioController") { | ||||
| IAudioController::IAudioController(Core::System& system_) | ||||
|     : ServiceFramework{system_, "IAudioController"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, &IAudioController::SetExpectedMasterVolume, "SetExpectedMasterVolume"}, | ||||
|  | @ -180,7 +181,8 @@ void IAudioController::SetTransparentAudioRate(Kernel::HLERequestContext& ctx) { | |||
|     rb.Push(RESULT_SUCCESS); | ||||
| } | ||||
| 
 | ||||
| IDisplayController::IDisplayController() : ServiceFramework("IDisplayController") { | ||||
| IDisplayController::IDisplayController(Core::System& system_) | ||||
|     : ServiceFramework{system_, "IDisplayController"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "GetLastForegroundCaptureImage"}, | ||||
|  | @ -219,7 +221,8 @@ IDisplayController::IDisplayController() : ServiceFramework("IDisplayController" | |||
| 
 | ||||
| IDisplayController::~IDisplayController() = default; | ||||
| 
 | ||||
| IDebugFunctions::IDebugFunctions() : ServiceFramework{"IDebugFunctions"} { | ||||
| IDebugFunctions::IDebugFunctions(Core::System& system_) | ||||
|     : ServiceFramework{system_, "IDebugFunctions"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "NotifyMessageToHomeMenuForDebug"}, | ||||
|  | @ -246,8 +249,8 @@ IDebugFunctions::IDebugFunctions() : ServiceFramework{"IDebugFunctions"} { | |||
| 
 | ||||
| IDebugFunctions::~IDebugFunctions() = default; | ||||
| 
 | ||||
| ISelfController::ISelfController(Core::System& system, NVFlinger::NVFlinger& nvflinger) | ||||
|     : ServiceFramework("ISelfController"), system(system), nvflinger(nvflinger) { | ||||
| ISelfController::ISelfController(Core::System& system_, NVFlinger::NVFlinger& nvflinger_) | ||||
|     : ServiceFramework{system_, "ISelfController"}, nvflinger{nvflinger_} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, &ISelfController::Exit, "Exit"}, | ||||
|  | @ -605,9 +608,9 @@ void AppletMessageQueue::RequestExit() { | |||
|     PushMessage(AppletMessage::ExitRequested); | ||||
| } | ||||
| 
 | ||||
| ICommonStateGetter::ICommonStateGetter(Core::System& system, | ||||
|                                        std::shared_ptr<AppletMessageQueue> msg_queue) | ||||
|     : ServiceFramework("ICommonStateGetter"), system(system), msg_queue(std::move(msg_queue)) { | ||||
| ICommonStateGetter::ICommonStateGetter(Core::System& system_, | ||||
|                                        std::shared_ptr<AppletMessageQueue> msg_queue_) | ||||
|     : ServiceFramework{system_, "ICommonStateGetter"}, msg_queue{std::move(msg_queue_)} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, &ICommonStateGetter::GetEventHandle, "GetEventHandle"}, | ||||
|  | @ -795,8 +798,9 @@ private: | |||
|     std::vector<u8> buffer; | ||||
| }; | ||||
| 
 | ||||
| IStorage::IStorage(std::vector<u8>&& buffer) | ||||
|     : ServiceFramework("IStorage"), impl{std::make_shared<StorageDataImpl>(std::move(buffer))} { | ||||
| IStorage::IStorage(Core::System& system_, std::vector<u8>&& buffer) | ||||
|     : ServiceFramework{system_, "IStorage"}, impl{std::make_shared<StorageDataImpl>( | ||||
|                                                  std::move(buffer))} { | ||||
|     Register(); | ||||
| } | ||||
| 
 | ||||
|  | @ -819,7 +823,7 @@ void IStorage::Open(Kernel::HLERequestContext& ctx) { | |||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
| 
 | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushIpcInterface<IStorageAccessor>(*this); | ||||
|     rb.PushIpcInterface<IStorageAccessor>(system, *this); | ||||
| } | ||||
| 
 | ||||
| void ICommonStateGetter::GetOperationMode(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -841,8 +845,8 @@ void ICommonStateGetter::GetPerformanceMode(Kernel::HLERequestContext& ctx) { | |||
| 
 | ||||
| class ILibraryAppletAccessor final : public ServiceFramework<ILibraryAppletAccessor> { | ||||
| public: | ||||
|     explicit ILibraryAppletAccessor(std::shared_ptr<Applets::Applet> applet) | ||||
|         : ServiceFramework("ILibraryAppletAccessor"), applet(std::move(applet)) { | ||||
|     explicit ILibraryAppletAccessor(Core::System& system_, std::shared_ptr<Applets::Applet> applet_) | ||||
|         : ServiceFramework{system_, "ILibraryAppletAccessor"}, applet{std::move(applet_)} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &ILibraryAppletAccessor::GetAppletStateChangedEvent, "GetAppletStateChangedEvent"}, | ||||
|  | @ -997,8 +1001,8 @@ private: | |||
|     std::shared_ptr<Applets::Applet> applet; | ||||
| }; | ||||
| 
 | ||||
| IStorageAccessor::IStorageAccessor(IStorage& storage) | ||||
|     : ServiceFramework("IStorageAccessor"), backing(storage) { | ||||
| IStorageAccessor::IStorageAccessor(Core::System& system_, IStorage& backing_) | ||||
|     : ServiceFramework{system_, "IStorageAccessor"}, backing{backing_} { | ||||
|     // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &IStorageAccessor::GetSize, "GetSize"}, | ||||
|  | @ -1069,7 +1073,7 @@ void IStorageAccessor::Read(Kernel::HLERequestContext& ctx) { | |||
| } | ||||
| 
 | ||||
| ILibraryAppletCreator::ILibraryAppletCreator(Core::System& system_) | ||||
|     : ServiceFramework("ILibraryAppletCreator"), system{system_} { | ||||
|     : ServiceFramework{system_, "ILibraryAppletCreator"} { | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, &ILibraryAppletCreator::CreateLibraryApplet, "CreateLibraryApplet"}, | ||||
|         {1, nullptr, "TerminateAllLibraryApplets"}, | ||||
|  | @ -1105,7 +1109,7 @@ void ILibraryAppletCreator::CreateLibraryApplet(Kernel::HLERequestContext& ctx) | |||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
| 
 | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushIpcInterface<AM::ILibraryAppletAccessor>(applet); | ||||
|     rb.PushIpcInterface<ILibraryAppletAccessor>(system, applet); | ||||
| } | ||||
| 
 | ||||
| void ILibraryAppletCreator::CreateStorage(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -1117,7 +1121,7 @@ void ILibraryAppletCreator::CreateStorage(Kernel::HLERequestContext& ctx) { | |||
| 
 | ||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushIpcInterface<AM::IStorage>(std::move(buffer)); | ||||
|     rb.PushIpcInterface<IStorage>(system, std::move(buffer)); | ||||
| } | ||||
| 
 | ||||
| void ILibraryAppletCreator::CreateTransferMemoryStorage(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -1144,11 +1148,11 @@ void ILibraryAppletCreator::CreateTransferMemoryStorage(Kernel::HLERequestContex | |||
| 
 | ||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushIpcInterface<IStorage>(std::move(memory)); | ||||
|     rb.PushIpcInterface<IStorage>(system, std::move(memory)); | ||||
| } | ||||
| 
 | ||||
| IApplicationFunctions::IApplicationFunctions(Core::System& system_) | ||||
|     : ServiceFramework("IApplicationFunctions"), system{system_} { | ||||
|     : ServiceFramework{system_, "IApplicationFunctions"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {1, &IApplicationFunctions::PopLaunchParameter, "PopLaunchParameter"}, | ||||
|  | @ -1300,7 +1304,7 @@ void IApplicationFunctions::PopLaunchParameter(Kernel::HLERequestContext& ctx) { | |||
|         if (data.has_value()) { | ||||
|             IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|             rb.Push(RESULT_SUCCESS); | ||||
|             rb.PushIpcInterface<IStorage>(std::move(*data)); | ||||
|             rb.PushIpcInterface<IStorage>(system, std::move(*data)); | ||||
|             launch_popped_application_specific = true; | ||||
|             return; | ||||
|         } | ||||
|  | @ -1323,7 +1327,7 @@ void IApplicationFunctions::PopLaunchParameter(Kernel::HLERequestContext& ctx) { | |||
|         std::vector<u8> buffer(sizeof(LaunchParameterAccountPreselectedUser)); | ||||
|         std::memcpy(buffer.data(), ¶ms, buffer.size()); | ||||
| 
 | ||||
|         rb.PushIpcInterface<IStorage>(std::move(buffer)); | ||||
|         rb.PushIpcInterface<IStorage>(system, std::move(buffer)); | ||||
|         launch_popped_account_preselect = true; | ||||
|         return; | ||||
|     } | ||||
|  | @ -1621,14 +1625,14 @@ void InstallInterfaces(SM::ServiceManager& service_manager, NVFlinger::NVFlinger | |||
| 
 | ||||
|     std::make_shared<AppletAE>(nvflinger, message_queue, system)->InstallAsService(service_manager); | ||||
|     std::make_shared<AppletOE>(nvflinger, message_queue, system)->InstallAsService(service_manager); | ||||
|     std::make_shared<IdleSys>()->InstallAsService(service_manager); | ||||
|     std::make_shared<OMM>()->InstallAsService(service_manager); | ||||
|     std::make_shared<SPSM>()->InstallAsService(service_manager); | ||||
|     std::make_shared<TCAP>()->InstallAsService(service_manager); | ||||
|     std::make_shared<IdleSys>(system)->InstallAsService(service_manager); | ||||
|     std::make_shared<OMM>(system)->InstallAsService(service_manager); | ||||
|     std::make_shared<SPSM>(system)->InstallAsService(service_manager); | ||||
|     std::make_shared<TCAP>(system)->InstallAsService(service_manager); | ||||
| } | ||||
| 
 | ||||
| IHomeMenuFunctions::IHomeMenuFunctions(Kernel::KernelCore& kernel) | ||||
|     : ServiceFramework("IHomeMenuFunctions"), kernel(kernel) { | ||||
| IHomeMenuFunctions::IHomeMenuFunctions(Core::System& system_) | ||||
|     : ServiceFramework{system_, "IHomeMenuFunctions"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {10, &IHomeMenuFunctions::RequestToGetForeground, "RequestToGetForeground"}, | ||||
|  | @ -1647,7 +1651,7 @@ IHomeMenuFunctions::IHomeMenuFunctions(Kernel::KernelCore& kernel) | |||
|     RegisterHandlers(functions); | ||||
| 
 | ||||
|     pop_from_general_channel_event = Kernel::WritableEvent::CreateEventPair( | ||||
|         kernel, "IHomeMenuFunctions:PopFromGeneralChannelEvent"); | ||||
|         system.Kernel(), "IHomeMenuFunctions:PopFromGeneralChannelEvent"); | ||||
| } | ||||
| 
 | ||||
| IHomeMenuFunctions::~IHomeMenuFunctions() = default; | ||||
|  | @ -1667,7 +1671,8 @@ void IHomeMenuFunctions::GetPopFromGeneralChannelEvent(Kernel::HLERequestContext | |||
|     rb.PushCopyObjects(pop_from_general_channel_event.readable); | ||||
| } | ||||
| 
 | ||||
| IGlobalStateController::IGlobalStateController() : ServiceFramework("IGlobalStateController") { | ||||
| IGlobalStateController::IGlobalStateController(Core::System& system_) | ||||
|     : ServiceFramework{system_, "IGlobalStateController"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "RequestToEnterSleep"}, | ||||
|  | @ -1690,7 +1695,8 @@ IGlobalStateController::IGlobalStateController() : ServiceFramework("IGlobalStat | |||
| 
 | ||||
| IGlobalStateController::~IGlobalStateController() = default; | ||||
| 
 | ||||
| IApplicationCreator::IApplicationCreator() : ServiceFramework("IApplicationCreator") { | ||||
| IApplicationCreator::IApplicationCreator(Core::System& system_) | ||||
|     : ServiceFramework{system_, "IApplicationCreator"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "CreateApplication"}, | ||||
|  | @ -1705,8 +1711,8 @@ IApplicationCreator::IApplicationCreator() : ServiceFramework("IApplicationCreat | |||
| 
 | ||||
| IApplicationCreator::~IApplicationCreator() = default; | ||||
| 
 | ||||
| IProcessWindingController::IProcessWindingController() | ||||
|     : ServiceFramework("IProcessWindingController") { | ||||
| IProcessWindingController::IProcessWindingController(Core::System& system_) | ||||
|     : ServiceFramework{system_, "IProcessWindingController"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "GetLaunchReason"}, | ||||
|  |  | |||
|  | @ -77,13 +77,11 @@ public: | |||
| private: | ||||
|     void GetAppletResourceUserId(Kernel::HLERequestContext& ctx); | ||||
|     void AcquireForegroundRights(Kernel::HLERequestContext& ctx); | ||||
| 
 | ||||
|     Core::System& system; | ||||
| }; | ||||
| 
 | ||||
| class IAudioController final : public ServiceFramework<IAudioController> { | ||||
| public: | ||||
|     IAudioController(); | ||||
|     explicit IAudioController(Core::System& system_); | ||||
|     ~IAudioController() override; | ||||
| 
 | ||||
| private: | ||||
|  | @ -109,13 +107,13 @@ private: | |||
| 
 | ||||
| class IDisplayController final : public ServiceFramework<IDisplayController> { | ||||
| public: | ||||
|     IDisplayController(); | ||||
|     explicit IDisplayController(Core::System& system_); | ||||
|     ~IDisplayController() override; | ||||
| }; | ||||
| 
 | ||||
| class IDebugFunctions final : public ServiceFramework<IDebugFunctions> { | ||||
| public: | ||||
|     IDebugFunctions(); | ||||
|     explicit IDebugFunctions(Core::System& system_); | ||||
|     ~IDebugFunctions() override; | ||||
| }; | ||||
| 
 | ||||
|  | @ -154,7 +152,6 @@ private: | |||
|         Disable = 2, | ||||
|     }; | ||||
| 
 | ||||
|     Core::System& system; | ||||
|     NVFlinger::NVFlinger& nvflinger; | ||||
|     Kernel::EventPair launchable_event; | ||||
|     Kernel::EventPair accumulated_suspended_tick_changed_event; | ||||
|  | @ -167,8 +164,8 @@ private: | |||
| 
 | ||||
| class ICommonStateGetter final : public ServiceFramework<ICommonStateGetter> { | ||||
| public: | ||||
|     explicit ICommonStateGetter(Core::System& system, | ||||
|                                 std::shared_ptr<AppletMessageQueue> msg_queue); | ||||
|     explicit ICommonStateGetter(Core::System& system_, | ||||
|                                 std::shared_ptr<AppletMessageQueue> msg_queue_); | ||||
|     ~ICommonStateGetter() override; | ||||
| 
 | ||||
| private: | ||||
|  | @ -196,7 +193,6 @@ private: | |||
|     void GetDefaultDisplayResolution(Kernel::HLERequestContext& ctx); | ||||
|     void SetCpuBoostMode(Kernel::HLERequestContext& ctx); | ||||
| 
 | ||||
|     Core::System& system; | ||||
|     std::shared_ptr<AppletMessageQueue> msg_queue; | ||||
|     bool vr_mode_state{}; | ||||
| }; | ||||
|  | @ -211,7 +207,7 @@ public: | |||
| 
 | ||||
| class IStorage final : public ServiceFramework<IStorage> { | ||||
| public: | ||||
|     explicit IStorage(std::vector<u8>&& buffer); | ||||
|     explicit IStorage(Core::System& system_, std::vector<u8>&& buffer); | ||||
|     ~IStorage() override; | ||||
| 
 | ||||
|     std::vector<u8>& GetData() { | ||||
|  | @ -235,7 +231,7 @@ private: | |||
| 
 | ||||
| class IStorageAccessor final : public ServiceFramework<IStorageAccessor> { | ||||
| public: | ||||
|     explicit IStorageAccessor(IStorage& backing); | ||||
|     explicit IStorageAccessor(Core::System& system_, IStorage& backing_); | ||||
|     ~IStorageAccessor() override; | ||||
| 
 | ||||
| private: | ||||
|  | @ -255,8 +251,6 @@ private: | |||
|     void CreateLibraryApplet(Kernel::HLERequestContext& ctx); | ||||
|     void CreateStorage(Kernel::HLERequestContext& ctx); | ||||
|     void CreateTransferMemoryStorage(Kernel::HLERequestContext& ctx); | ||||
| 
 | ||||
|     Core::System& system; | ||||
| }; | ||||
| 
 | ||||
| class IApplicationFunctions final : public ServiceFramework<IApplicationFunctions> { | ||||
|  | @ -299,12 +293,11 @@ private: | |||
|     s32 previous_program_index{-1}; | ||||
|     Kernel::EventPair gpu_error_detected_event; | ||||
|     Kernel::EventPair friend_invitation_storage_channel_event; | ||||
|     Core::System& system; | ||||
| }; | ||||
| 
 | ||||
| class IHomeMenuFunctions final : public ServiceFramework<IHomeMenuFunctions> { | ||||
| public: | ||||
|     explicit IHomeMenuFunctions(Kernel::KernelCore& kernel); | ||||
|     explicit IHomeMenuFunctions(Core::System& system_); | ||||
|     ~IHomeMenuFunctions() override; | ||||
| 
 | ||||
| private: | ||||
|  | @ -312,24 +305,23 @@ private: | |||
|     void GetPopFromGeneralChannelEvent(Kernel::HLERequestContext& ctx); | ||||
| 
 | ||||
|     Kernel::EventPair pop_from_general_channel_event; | ||||
|     Kernel::KernelCore& kernel; | ||||
| }; | ||||
| 
 | ||||
| class IGlobalStateController final : public ServiceFramework<IGlobalStateController> { | ||||
| public: | ||||
|     IGlobalStateController(); | ||||
|     explicit IGlobalStateController(Core::System& system_); | ||||
|     ~IGlobalStateController() override; | ||||
| }; | ||||
| 
 | ||||
| class IApplicationCreator final : public ServiceFramework<IApplicationCreator> { | ||||
| public: | ||||
|     IApplicationCreator(); | ||||
|     explicit IApplicationCreator(Core::System& system_); | ||||
|     ~IApplicationCreator() override; | ||||
| }; | ||||
| 
 | ||||
| class IProcessWindingController final : public ServiceFramework<IProcessWindingController> { | ||||
| public: | ||||
|     IProcessWindingController(); | ||||
|     explicit IProcessWindingController(Core::System& system_); | ||||
|     ~IProcessWindingController() override; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -13,11 +13,11 @@ namespace Service::AM { | |||
| 
 | ||||
| class ILibraryAppletProxy final : public ServiceFramework<ILibraryAppletProxy> { | ||||
| public: | ||||
|     explicit ILibraryAppletProxy(NVFlinger::NVFlinger& nvflinger, | ||||
|                                  std::shared_ptr<AppletMessageQueue> msg_queue, | ||||
|                                  Core::System& system) | ||||
|         : ServiceFramework("ILibraryAppletProxy"), nvflinger(nvflinger), | ||||
|           msg_queue(std::move(msg_queue)), system(system) { | ||||
|     explicit ILibraryAppletProxy(NVFlinger::NVFlinger& nvflinger_, | ||||
|                                  std::shared_ptr<AppletMessageQueue> msg_queue_, | ||||
|                                  Core::System& system_) | ||||
|         : ServiceFramework{system_, "ILibraryAppletProxy"}, nvflinger{nvflinger_}, | ||||
|           msg_queue{std::move(msg_queue_)} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &ILibraryAppletProxy::GetCommonStateGetter, "GetCommonStateGetter"}, | ||||
|  | @ -66,7 +66,7 @@ private: | |||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|         rb.PushIpcInterface<IAudioController>(); | ||||
|         rb.PushIpcInterface<IAudioController>(system); | ||||
|     } | ||||
| 
 | ||||
|     void GetDisplayController(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -74,7 +74,7 @@ private: | |||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|         rb.PushIpcInterface<IDisplayController>(); | ||||
|         rb.PushIpcInterface<IDisplayController>(system); | ||||
|     } | ||||
| 
 | ||||
|     void GetProcessWindingController(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -82,7 +82,7 @@ private: | |||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|         rb.PushIpcInterface<IProcessWindingController>(); | ||||
|         rb.PushIpcInterface<IProcessWindingController>(system); | ||||
|     } | ||||
| 
 | ||||
|     void GetDebugFunctions(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -90,7 +90,7 @@ private: | |||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|         rb.PushIpcInterface<IDebugFunctions>(); | ||||
|         rb.PushIpcInterface<IDebugFunctions>(system); | ||||
|     } | ||||
| 
 | ||||
|     void GetLibraryAppletCreator(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -111,15 +111,15 @@ private: | |||
| 
 | ||||
|     NVFlinger::NVFlinger& nvflinger; | ||||
|     std::shared_ptr<AppletMessageQueue> msg_queue; | ||||
|     Core::System& system; | ||||
| }; | ||||
| 
 | ||||
| class ISystemAppletProxy final : public ServiceFramework<ISystemAppletProxy> { | ||||
| public: | ||||
|     explicit ISystemAppletProxy(NVFlinger::NVFlinger& nvflinger, | ||||
|                                 std::shared_ptr<AppletMessageQueue> msg_queue, Core::System& system) | ||||
|         : ServiceFramework("ISystemAppletProxy"), nvflinger(nvflinger), | ||||
|           msg_queue(std::move(msg_queue)), system(system) { | ||||
|     explicit ISystemAppletProxy(NVFlinger::NVFlinger& nvflinger_, | ||||
|                                 std::shared_ptr<AppletMessageQueue> msg_queue_, | ||||
|                                 Core::System& system_) | ||||
|         : ServiceFramework{system_, "ISystemAppletProxy"}, nvflinger{nvflinger_}, | ||||
|           msg_queue{std::move(msg_queue_)} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &ISystemAppletProxy::GetCommonStateGetter, "GetCommonStateGetter"}, | ||||
|  | @ -170,7 +170,7 @@ private: | |||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|         rb.PushIpcInterface<IAudioController>(); | ||||
|         rb.PushIpcInterface<IAudioController>(system); | ||||
|     } | ||||
| 
 | ||||
|     void GetDisplayController(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -178,7 +178,7 @@ private: | |||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|         rb.PushIpcInterface<IDisplayController>(); | ||||
|         rb.PushIpcInterface<IDisplayController>(system); | ||||
|     } | ||||
| 
 | ||||
|     void GetDebugFunctions(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -186,7 +186,7 @@ private: | |||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|         rb.PushIpcInterface<IDebugFunctions>(); | ||||
|         rb.PushIpcInterface<IDebugFunctions>(system); | ||||
|     } | ||||
| 
 | ||||
|     void GetLibraryAppletCreator(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -202,7 +202,7 @@ private: | |||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|         rb.PushIpcInterface<IHomeMenuFunctions>(system.Kernel()); | ||||
|         rb.PushIpcInterface<IHomeMenuFunctions>(system); | ||||
|     } | ||||
| 
 | ||||
|     void GetGlobalStateController(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -210,7 +210,7 @@ private: | |||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|         rb.PushIpcInterface<IGlobalStateController>(); | ||||
|         rb.PushIpcInterface<IGlobalStateController>(system); | ||||
|     } | ||||
| 
 | ||||
|     void GetApplicationCreator(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -218,12 +218,11 @@ private: | |||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|         rb.PushIpcInterface<IApplicationCreator>(); | ||||
|         rb.PushIpcInterface<IApplicationCreator>(system); | ||||
|     } | ||||
| 
 | ||||
|     NVFlinger::NVFlinger& nvflinger; | ||||
|     std::shared_ptr<AppletMessageQueue> msg_queue; | ||||
|     Core::System& system; | ||||
| }; | ||||
| 
 | ||||
| void AppletAE::OpenSystemAppletProxy(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -250,10 +249,10 @@ void AppletAE::OpenLibraryAppletProxyOld(Kernel::HLERequestContext& ctx) { | |||
|     rb.PushIpcInterface<ILibraryAppletProxy>(nvflinger, msg_queue, system); | ||||
| } | ||||
| 
 | ||||
| AppletAE::AppletAE(NVFlinger::NVFlinger& nvflinger, std::shared_ptr<AppletMessageQueue> msg_queue, | ||||
|                    Core::System& system) | ||||
|     : ServiceFramework("appletAE"), nvflinger(nvflinger), msg_queue(std::move(msg_queue)), | ||||
|       system(system) { | ||||
| AppletAE::AppletAE(NVFlinger::NVFlinger& nvflinger_, std::shared_ptr<AppletMessageQueue> msg_queue_, | ||||
|                    Core::System& system_) | ||||
|     : ServiceFramework{system_, "appletAE"}, nvflinger{nvflinger_}, msg_queue{ | ||||
|                                                                         std::move(msg_queue_)} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {100, &AppletAE::OpenSystemAppletProxy, "OpenSystemAppletProxy"}, | ||||
|  |  | |||
|  | @ -23,8 +23,8 @@ class AppletMessageQueue; | |||
| 
 | ||||
| class AppletAE final : public ServiceFramework<AppletAE> { | ||||
| public: | ||||
|     explicit AppletAE(NVFlinger::NVFlinger& nvflinger, | ||||
|                       std::shared_ptr<AppletMessageQueue> msg_queue, Core::System& system); | ||||
|     explicit AppletAE(NVFlinger::NVFlinger& nvflinger_, | ||||
|                       std::shared_ptr<AppletMessageQueue> msg_queue_, Core::System& system_); | ||||
|     ~AppletAE() override; | ||||
| 
 | ||||
|     const std::shared_ptr<AppletMessageQueue>& GetMessageQueue() const; | ||||
|  | @ -36,7 +36,6 @@ private: | |||
| 
 | ||||
|     NVFlinger::NVFlinger& nvflinger; | ||||
|     std::shared_ptr<AppletMessageQueue> msg_queue; | ||||
|     Core::System& system; | ||||
| }; | ||||
| 
 | ||||
| } // namespace AM
 | ||||
|  |  | |||
|  | @ -12,10 +12,11 @@ namespace Service::AM { | |||
| 
 | ||||
| class IApplicationProxy final : public ServiceFramework<IApplicationProxy> { | ||||
| public: | ||||
|     explicit IApplicationProxy(NVFlinger::NVFlinger& nvflinger, | ||||
|                                std::shared_ptr<AppletMessageQueue> msg_queue, Core::System& system) | ||||
|         : ServiceFramework("IApplicationProxy"), nvflinger(nvflinger), | ||||
|           msg_queue(std::move(msg_queue)), system(system) { | ||||
|     explicit IApplicationProxy(NVFlinger::NVFlinger& nvflinger_, | ||||
|                                std::shared_ptr<AppletMessageQueue> msg_queue_, | ||||
|                                Core::System& system_) | ||||
|         : ServiceFramework{system_, "IApplicationProxy"}, nvflinger{nvflinger_}, | ||||
|           msg_queue{std::move(msg_queue_)} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &IApplicationProxy::GetCommonStateGetter, "GetCommonStateGetter"}, | ||||
|  | @ -39,7 +40,7 @@ private: | |||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|         rb.PushIpcInterface<IAudioController>(); | ||||
|         rb.PushIpcInterface<IAudioController>(system); | ||||
|     } | ||||
| 
 | ||||
|     void GetDisplayController(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -47,7 +48,7 @@ private: | |||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|         rb.PushIpcInterface<IDisplayController>(); | ||||
|         rb.PushIpcInterface<IDisplayController>(system); | ||||
|     } | ||||
| 
 | ||||
|     void GetDebugFunctions(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -55,7 +56,7 @@ private: | |||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|         rb.PushIpcInterface<IDebugFunctions>(); | ||||
|         rb.PushIpcInterface<IDebugFunctions>(system); | ||||
|     } | ||||
| 
 | ||||
|     void GetWindowController(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -100,7 +101,6 @@ private: | |||
| 
 | ||||
|     NVFlinger::NVFlinger& nvflinger; | ||||
|     std::shared_ptr<AppletMessageQueue> msg_queue; | ||||
|     Core::System& system; | ||||
| }; | ||||
| 
 | ||||
| void AppletOE::OpenApplicationProxy(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -111,10 +111,10 @@ void AppletOE::OpenApplicationProxy(Kernel::HLERequestContext& ctx) { | |||
|     rb.PushIpcInterface<IApplicationProxy>(nvflinger, msg_queue, system); | ||||
| } | ||||
| 
 | ||||
| AppletOE::AppletOE(NVFlinger::NVFlinger& nvflinger, std::shared_ptr<AppletMessageQueue> msg_queue, | ||||
|                    Core::System& system) | ||||
|     : ServiceFramework("appletOE"), nvflinger(nvflinger), msg_queue(std::move(msg_queue)), | ||||
|       system(system) { | ||||
| AppletOE::AppletOE(NVFlinger::NVFlinger& nvflinger_, std::shared_ptr<AppletMessageQueue> msg_queue_, | ||||
|                    Core::System& system_) | ||||
|     : ServiceFramework{system_, "appletOE"}, nvflinger{nvflinger_}, msg_queue{ | ||||
|                                                                         std::move(msg_queue_)} { | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, &AppletOE::OpenApplicationProxy, "OpenApplicationProxy"}, | ||||
|     }; | ||||
|  |  | |||
|  | @ -23,8 +23,8 @@ class AppletMessageQueue; | |||
| 
 | ||||
| class AppletOE final : public ServiceFramework<AppletOE> { | ||||
| public: | ||||
|     explicit AppletOE(NVFlinger::NVFlinger& nvflinger, | ||||
|                       std::shared_ptr<AppletMessageQueue> msg_queue, Core::System& system); | ||||
|     explicit AppletOE(NVFlinger::NVFlinger& nvflinger_, | ||||
|                       std::shared_ptr<AppletMessageQueue> msg_queue_, Core::System& system_); | ||||
|     ~AppletOE() override; | ||||
| 
 | ||||
|     const std::shared_ptr<AppletMessageQueue>& GetMessageQueue() const; | ||||
|  | @ -34,7 +34,6 @@ private: | |||
| 
 | ||||
|     NVFlinger::NVFlinger& nvflinger; | ||||
|     std::shared_ptr<AppletMessageQueue> msg_queue; | ||||
|     Core::System& system; | ||||
| }; | ||||
| 
 | ||||
| } // namespace AM
 | ||||
|  |  | |||
|  | @ -46,7 +46,7 @@ static Core::Frontend::ControllerParameters ConvertToFrontendParameters( | |||
| } | ||||
| 
 | ||||
| Controller::Controller(Core::System& system_, const Core::Frontend::ControllerApplet& frontend_) | ||||
|     : Applet{system_.Kernel()}, frontend(frontend_) {} | ||||
|     : Applet{system_.Kernel()}, frontend{frontend_}, system{system_} {} | ||||
| 
 | ||||
| Controller::~Controller() = default; | ||||
| 
 | ||||
|  | @ -245,7 +245,7 @@ void Controller::ConfigurationComplete() { | |||
|     complete = true; | ||||
|     out_data = std::vector<u8>(sizeof(ControllerSupportResultInfo)); | ||||
|     std::memcpy(out_data.data(), &result_info, out_data.size()); | ||||
|     broker.PushNormalDataFromApplet(std::make_shared<IStorage>(std::move(out_data))); | ||||
|     broker.PushNormalDataFromApplet(std::make_shared<IStorage>(system, std::move(out_data))); | ||||
|     broker.SignalStateChanged(); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -120,6 +120,7 @@ public: | |||
| 
 | ||||
| private: | ||||
|     const Core::Frontend::ControllerApplet& frontend; | ||||
|     Core::System& system; | ||||
| 
 | ||||
|     ControllerAppletVersion controller_applet_version; | ||||
|     ControllerSupportArgPrivate controller_private_arg; | ||||
|  |  | |||
|  | @ -87,7 +87,7 @@ ResultCode Decode64BitError(u64 error) { | |||
| } // Anonymous namespace
 | ||||
| 
 | ||||
| Error::Error(Core::System& system_, const Core::Frontend::ErrorApplet& frontend_) | ||||
|     : Applet{system_.Kernel()}, frontend(frontend_), system{system_} {} | ||||
|     : Applet{system_.Kernel()}, frontend{frontend_}, system{system_} {} | ||||
| 
 | ||||
| Error::~Error() = default; | ||||
| 
 | ||||
|  | @ -186,7 +186,7 @@ void Error::Execute() { | |||
| 
 | ||||
| void Error::DisplayCompleted() { | ||||
|     complete = true; | ||||
|     broker.PushNormalDataFromApplet(std::make_shared<IStorage>(std::vector<u8>{})); | ||||
|     broker.PushNormalDataFromApplet(std::make_shared<IStorage>(system, std::vector<u8>{})); | ||||
|     broker.SignalStateChanged(); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -38,7 +38,7 @@ static void LogCurrentStorage(AppletDataBroker& broker, std::string_view prefix) | |||
| } | ||||
| 
 | ||||
| Auth::Auth(Core::System& system_, Core::Frontend::ParentalControlsApplet& frontend_) | ||||
|     : Applet{system_.Kernel()}, frontend(frontend_) {} | ||||
|     : Applet{system_.Kernel()}, frontend{frontend_}, system{system_} {} | ||||
| 
 | ||||
| Auth::~Auth() = default; | ||||
| 
 | ||||
|  | @ -135,8 +135,8 @@ void Auth::Execute() { | |||
|     } | ||||
| } | ||||
| 
 | ||||
| void Auth::AuthFinished(bool successful) { | ||||
|     this->successful = successful; | ||||
| void Auth::AuthFinished(bool is_successful) { | ||||
|     this->successful = is_successful; | ||||
| 
 | ||||
|     struct Return { | ||||
|         ResultCode result_code; | ||||
|  | @ -148,12 +148,12 @@ void Auth::AuthFinished(bool successful) { | |||
|     std::vector<u8> out(sizeof(Return)); | ||||
|     std::memcpy(out.data(), &return_, sizeof(Return)); | ||||
| 
 | ||||
|     broker.PushNormalDataFromApplet(std::make_shared<IStorage>(std::move(out))); | ||||
|     broker.PushNormalDataFromApplet(std::make_shared<IStorage>(system, std::move(out))); | ||||
|     broker.SignalStateChanged(); | ||||
| } | ||||
| 
 | ||||
| PhotoViewer::PhotoViewer(Core::System& system_, const Core::Frontend::PhotoViewerApplet& frontend_) | ||||
|     : Applet{system_.Kernel()}, frontend(frontend_), system{system_} {} | ||||
|     : Applet{system_.Kernel()}, frontend{frontend_}, system{system_} {} | ||||
| 
 | ||||
| PhotoViewer::~PhotoViewer() = default; | ||||
| 
 | ||||
|  | @ -198,12 +198,12 @@ void PhotoViewer::Execute() { | |||
| } | ||||
| 
 | ||||
| void PhotoViewer::ViewFinished() { | ||||
|     broker.PushNormalDataFromApplet(std::make_shared<IStorage>(std::vector<u8>{})); | ||||
|     broker.PushNormalDataFromApplet(std::make_shared<IStorage>(system, std::vector<u8>{})); | ||||
|     broker.SignalStateChanged(); | ||||
| } | ||||
| 
 | ||||
| StubApplet::StubApplet(Core::System& system_, AppletId id_) | ||||
|     : Applet{system_.Kernel()}, id(id_), system{system_} {} | ||||
|     : Applet{system_.Kernel()}, id{id_}, system{system_} {} | ||||
| 
 | ||||
| StubApplet::~StubApplet() = default; | ||||
| 
 | ||||
|  | @ -234,8 +234,9 @@ void StubApplet::ExecuteInteractive() { | |||
|     LOG_WARNING(Service_AM, "called (STUBBED)"); | ||||
|     LogCurrentStorage(broker, "ExecuteInteractive"); | ||||
| 
 | ||||
|     broker.PushNormalDataFromApplet(std::make_shared<IStorage>(std::vector<u8>(0x1000))); | ||||
|     broker.PushInteractiveDataFromApplet(std::make_shared<IStorage>(std::vector<u8>(0x1000))); | ||||
|     broker.PushNormalDataFromApplet(std::make_shared<IStorage>(system, std::vector<u8>(0x1000))); | ||||
|     broker.PushInteractiveDataFromApplet( | ||||
|         std::make_shared<IStorage>(system, std::vector<u8>(0x1000))); | ||||
|     broker.SignalStateChanged(); | ||||
| } | ||||
| 
 | ||||
|  | @ -243,8 +244,9 @@ void StubApplet::Execute() { | |||
|     LOG_WARNING(Service_AM, "called (STUBBED)"); | ||||
|     LogCurrentStorage(broker, "Execute"); | ||||
| 
 | ||||
|     broker.PushNormalDataFromApplet(std::make_shared<IStorage>(std::vector<u8>(0x1000))); | ||||
|     broker.PushInteractiveDataFromApplet(std::make_shared<IStorage>(std::vector<u8>(0x1000))); | ||||
|     broker.PushNormalDataFromApplet(std::make_shared<IStorage>(system, std::vector<u8>(0x1000))); | ||||
|     broker.PushInteractiveDataFromApplet( | ||||
|         std::make_shared<IStorage>(system, std::vector<u8>(0x1000))); | ||||
|     broker.SignalStateChanged(); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -29,10 +29,11 @@ public: | |||
|     void ExecuteInteractive() override; | ||||
|     void Execute() override; | ||||
| 
 | ||||
|     void AuthFinished(bool successful = true); | ||||
|     void AuthFinished(bool is_successful = true); | ||||
| 
 | ||||
| private: | ||||
|     Core::Frontend::ParentalControlsApplet& frontend; | ||||
|     Core::System& system; | ||||
|     bool complete = false; | ||||
|     bool successful = false; | ||||
| 
 | ||||
|  |  | |||
|  | @ -17,7 +17,7 @@ constexpr ResultCode ERR_USER_CANCELLED_SELECTION{ErrorModule::Account, 1}; | |||
| 
 | ||||
| ProfileSelect::ProfileSelect(Core::System& system_, | ||||
|                              const Core::Frontend::ProfileSelectApplet& frontend_) | ||||
|     : Applet{system_.Kernel()}, frontend(frontend_) {} | ||||
|     : Applet{system_.Kernel()}, frontend{frontend_}, system{system_} {} | ||||
| 
 | ||||
| ProfileSelect::~ProfileSelect() = default; | ||||
| 
 | ||||
|  | @ -50,7 +50,7 @@ void ProfileSelect::ExecuteInteractive() { | |||
| 
 | ||||
| void ProfileSelect::Execute() { | ||||
|     if (complete) { | ||||
|         broker.PushNormalDataFromApplet(std::make_shared<IStorage>(std::move(final_data))); | ||||
|         broker.PushNormalDataFromApplet(std::make_shared<IStorage>(system, std::move(final_data))); | ||||
|         return; | ||||
|     } | ||||
| 
 | ||||
|  | @ -71,7 +71,7 @@ void ProfileSelect::SelectionComplete(std::optional<Common::UUID> uuid) { | |||
| 
 | ||||
|     final_data = std::vector<u8>(sizeof(UserSelectionOutput)); | ||||
|     std::memcpy(final_data.data(), &output, final_data.size()); | ||||
|     broker.PushNormalDataFromApplet(std::make_shared<IStorage>(std::move(final_data))); | ||||
|     broker.PushNormalDataFromApplet(std::make_shared<IStorage>(system, std::move(final_data))); | ||||
|     broker.SignalStateChanged(); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -53,6 +53,7 @@ private: | |||
|     bool complete = false; | ||||
|     ResultCode status = RESULT_SUCCESS; | ||||
|     std::vector<u8> final_data; | ||||
|     Core::System& system; | ||||
| }; | ||||
| 
 | ||||
| } // namespace Service::AM::Applets
 | ||||
|  |  | |||
|  | @ -53,7 +53,7 @@ static Core::Frontend::SoftwareKeyboardParameters ConvertToFrontendParameters( | |||
| 
 | ||||
| SoftwareKeyboard::SoftwareKeyboard(Core::System& system_, | ||||
|                                    const Core::Frontend::SoftwareKeyboardApplet& frontend_) | ||||
|     : Applet{system_.Kernel()}, frontend(frontend_) {} | ||||
|     : Applet{system_.Kernel()}, frontend{frontend_}, system{system_} {} | ||||
| 
 | ||||
| SoftwareKeyboard::~SoftwareKeyboard() = default; | ||||
| 
 | ||||
|  | @ -122,7 +122,7 @@ void SoftwareKeyboard::ExecuteInteractive() { | |||
| 
 | ||||
|         switch (request) { | ||||
|         case Request::Calc: { | ||||
|             broker.PushNormalDataFromApplet(std::make_shared<IStorage>(std::vector<u8>{1})); | ||||
|             broker.PushNormalDataFromApplet(std::make_shared<IStorage>(system, std::vector<u8>{1})); | ||||
|             broker.SignalStateChanged(); | ||||
|             break; | ||||
|         } | ||||
|  | @ -135,7 +135,7 @@ void SoftwareKeyboard::ExecuteInteractive() { | |||
| 
 | ||||
| void SoftwareKeyboard::Execute() { | ||||
|     if (complete) { | ||||
|         broker.PushNormalDataFromApplet(std::make_shared<IStorage>(std::move(final_data))); | ||||
|         broker.PushNormalDataFromApplet(std::make_shared<IStorage>(system, std::move(final_data))); | ||||
|         broker.SignalStateChanged(); | ||||
|         return; | ||||
|     } | ||||
|  | @ -179,15 +179,17 @@ void SoftwareKeyboard::WriteText(std::optional<std::u16string> text) { | |||
|         final_data = output_main; | ||||
| 
 | ||||
|         if (complete) { | ||||
|             broker.PushNormalDataFromApplet(std::make_shared<IStorage>(std::move(output_main))); | ||||
|             broker.PushNormalDataFromApplet( | ||||
|                 std::make_shared<IStorage>(system, std::move(output_main))); | ||||
|             broker.SignalStateChanged(); | ||||
|         } else { | ||||
|             broker.PushInteractiveDataFromApplet(std::make_shared<IStorage>(std::move(output_sub))); | ||||
|             broker.PushInteractiveDataFromApplet( | ||||
|                 std::make_shared<IStorage>(system, std::move(output_sub))); | ||||
|         } | ||||
|     } else { | ||||
|         output_main[0] = 1; | ||||
|         complete = true; | ||||
|         broker.PushNormalDataFromApplet(std::make_shared<IStorage>(std::move(output_main))); | ||||
|         broker.PushNormalDataFromApplet(std::make_shared<IStorage>(system, std::move(output_main))); | ||||
|         broker.SignalStateChanged(); | ||||
|     } | ||||
| } | ||||
|  |  | |||
|  | @ -80,6 +80,7 @@ private: | |||
|     bool complete = false; | ||||
|     bool is_inline = false; | ||||
|     std::vector<u8> final_data; | ||||
|     Core::System& system; | ||||
| }; | ||||
| 
 | ||||
| } // namespace Service::AM::Applets
 | ||||
|  |  | |||
|  | @ -290,7 +290,7 @@ void WebBrowser::Finalize() { | |||
|     std::vector<u8> data(sizeof(WebCommonReturnValue)); | ||||
|     std::memcpy(data.data(), &out, sizeof(WebCommonReturnValue)); | ||||
| 
 | ||||
|     broker.PushNormalDataFromApplet(std::make_shared<IStorage>(std::move(data))); | ||||
|     broker.PushNormalDataFromApplet(std::make_shared<IStorage>(system, std::move(data))); | ||||
|     broker.SignalStateChanged(); | ||||
| 
 | ||||
|     if (!temporary_dir.empty() && Common::FS::IsDirectory(temporary_dir)) { | ||||
|  |  | |||
|  | @ -6,7 +6,7 @@ | |||
| 
 | ||||
| namespace Service::AM { | ||||
| 
 | ||||
| IdleSys::IdleSys() : ServiceFramework{"idle:sys"} { | ||||
| IdleSys::IdleSys(Core::System& system_) : ServiceFramework{system_, "idle:sys"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "GetAutoPowerDownEvent"}, | ||||
|  |  | |||
|  | @ -6,11 +6,15 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::AM { | ||||
| 
 | ||||
| class IdleSys final : public ServiceFramework<IdleSys> { | ||||
| public: | ||||
|     explicit IdleSys(); | ||||
|     explicit IdleSys(Core::System& system_); | ||||
|     ~IdleSys() override; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -6,7 +6,7 @@ | |||
| 
 | ||||
| namespace Service::AM { | ||||
| 
 | ||||
| OMM::OMM() : ServiceFramework{"omm"} { | ||||
| OMM::OMM(Core::System& system_) : ServiceFramework{system_, "omm"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "GetOperationMode"}, | ||||
|  |  | |||
|  | @ -6,11 +6,15 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::AM { | ||||
| 
 | ||||
| class OMM final : public ServiceFramework<OMM> { | ||||
| public: | ||||
|     explicit OMM(); | ||||
|     explicit OMM(Core::System& system_); | ||||
|     ~OMM() override; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -6,7 +6,7 @@ | |||
| 
 | ||||
| namespace Service::AM { | ||||
| 
 | ||||
| SPSM::SPSM() : ServiceFramework{"spsm"} { | ||||
| SPSM::SPSM(Core::System& system_) : ServiceFramework{system_, "spsm"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "GetState"}, | ||||
|  |  | |||
|  | @ -6,11 +6,15 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::AM { | ||||
| 
 | ||||
| class SPSM final : public ServiceFramework<SPSM> { | ||||
| public: | ||||
|     explicit SPSM(); | ||||
|     explicit SPSM(Core::System& system_); | ||||
|     ~SPSM() override; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -6,7 +6,7 @@ | |||
| 
 | ||||
| namespace Service::AM { | ||||
| 
 | ||||
| TCAP::TCAP() : ServiceFramework{"tcap"} { | ||||
| TCAP::TCAP(Core::System& system_) : ServiceFramework{system_, "tcap"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "GetContinuousHighSkinTemperatureEvent"}, | ||||
|  |  | |||
|  | @ -6,11 +6,15 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::AM { | ||||
| 
 | ||||
| class TCAP final : public ServiceFramework<TCAP> { | ||||
| public: | ||||
|     explicit TCAP(); | ||||
|     explicit TCAP(Core::System& system_); | ||||
|     ~TCAP() override; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -48,8 +48,8 @@ static std::vector<u64> AccumulateAOCTitleIDs(Core::System& system) { | |||
|     return add_on_content; | ||||
| } | ||||
| 
 | ||||
| AOC_U::AOC_U(Core::System& system) | ||||
|     : ServiceFramework("aoc:u"), add_on_content(AccumulateAOCTitleIDs(system)), system(system) { | ||||
| AOC_U::AOC_U(Core::System& system_) | ||||
|     : ServiceFramework{system_, "aoc:u"}, add_on_content{AccumulateAOCTitleIDs(system)} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "CountAddOnContentByApplicationId"}, | ||||
|  |  | |||
|  | @ -6,6 +6,10 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Kernel { | ||||
| class WritableEvent; | ||||
| } | ||||
|  | @ -26,7 +30,6 @@ private: | |||
| 
 | ||||
|     std::vector<u64> add_on_content; | ||||
|     Kernel::EventPair aoc_change_event; | ||||
|     Core::System& system; | ||||
| }; | ||||
| 
 | ||||
| /// Registers all AOC services with the specified service manager.
 | ||||
|  |  | |||
|  | @ -14,13 +14,14 @@ Module::~Module() = default; | |||
| 
 | ||||
| void InstallInterfaces(Core::System& system) { | ||||
|     auto module_ = std::make_shared<Module>(); | ||||
|     std::make_shared<APM>(module_, system.GetAPMController(), "apm") | ||||
|     std::make_shared<APM>(system, module_, system.GetAPMController(), "apm") | ||||
|         ->InstallAsService(system.ServiceManager()); | ||||
|     std::make_shared<APM>(module_, system.GetAPMController(), "apm:p") | ||||
|     std::make_shared<APM>(system, module_, system.GetAPMController(), "apm:p") | ||||
|         ->InstallAsService(system.ServiceManager()); | ||||
|     std::make_shared<APM>(module_, system.GetAPMController(), "apm:am") | ||||
|     std::make_shared<APM>(system, module_, system.GetAPMController(), "apm:am") | ||||
|         ->InstallAsService(system.ServiceManager()); | ||||
|     std::make_shared<APM_Sys>(system, system.GetAPMController()) | ||||
|         ->InstallAsService(system.ServiceManager()); | ||||
|     std::make_shared<APM_Sys>(system.GetAPMController())->InstallAsService(system.ServiceManager()); | ||||
| } | ||||
| 
 | ||||
| } // namespace Service::APM
 | ||||
|  |  | |||
|  | @ -4,7 +4,9 @@ | |||
| 
 | ||||
| #pragma once | ||||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::APM { | ||||
| 
 | ||||
|  |  | |||
|  | @ -12,7 +12,8 @@ namespace Service::APM { | |||
| 
 | ||||
| class ISession final : public ServiceFramework<ISession> { | ||||
| public: | ||||
|     ISession(Controller& controller) : ServiceFramework("ISession"), controller(controller) { | ||||
|     explicit ISession(Core::System& system_, Controller& controller_) | ||||
|         : ServiceFramework{system_, "ISession"}, controller{controller_} { | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &ISession::SetPerformanceConfiguration, "SetPerformanceConfiguration"}, | ||||
|             {1, &ISession::GetPerformanceConfiguration, "GetPerformanceConfiguration"}, | ||||
|  | @ -50,8 +51,9 @@ private: | |||
|     Controller& controller; | ||||
| }; | ||||
| 
 | ||||
| APM::APM(std::shared_ptr<Module> apm, Controller& controller, const char* name) | ||||
|     : ServiceFramework(name), apm(std::move(apm)), controller(controller) { | ||||
| APM::APM(Core::System& system_, std::shared_ptr<Module> apm_, Controller& controller_, | ||||
|          const char* name) | ||||
|     : ServiceFramework{system_, name}, apm(std::move(apm_)), controller{controller_} { | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, &APM::OpenSession, "OpenSession"}, | ||||
|         {1, &APM::GetPerformanceMode, "GetPerformanceMode"}, | ||||
|  | @ -67,7 +69,7 @@ void APM::OpenSession(Kernel::HLERequestContext& ctx) { | |||
| 
 | ||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushIpcInterface<ISession>(controller); | ||||
|     rb.PushIpcInterface<ISession>(system, controller); | ||||
| } | ||||
| 
 | ||||
| void APM::GetPerformanceMode(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -77,7 +79,8 @@ void APM::GetPerformanceMode(Kernel::HLERequestContext& ctx) { | |||
|     rb.PushEnum(controller.GetCurrentPerformanceMode()); | ||||
| } | ||||
| 
 | ||||
| APM_Sys::APM_Sys(Controller& controller) : ServiceFramework{"apm:sys"}, controller(controller) { | ||||
| APM_Sys::APM_Sys(Core::System& system_, Controller& controller_) | ||||
|     : ServiceFramework{system_, "apm:sys"}, controller{controller_} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "RequestPerformanceMode"}, | ||||
|  | @ -101,7 +104,7 @@ void APM_Sys::GetPerformanceEvent(Kernel::HLERequestContext& ctx) { | |||
| 
 | ||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushIpcInterface<ISession>(controller); | ||||
|     rb.PushIpcInterface<ISession>(system, controller); | ||||
| } | ||||
| 
 | ||||
| void APM_Sys::SetCpuBoostMode(Kernel::HLERequestContext& ctx) { | ||||
|  |  | |||
|  | @ -13,7 +13,8 @@ class Module; | |||
| 
 | ||||
| class APM final : public ServiceFramework<APM> { | ||||
| public: | ||||
|     explicit APM(std::shared_ptr<Module> apm, Controller& controller, const char* name); | ||||
|     explicit APM(Core::System& system_, std::shared_ptr<Module> apm_, Controller& controller_, | ||||
|                  const char* name); | ||||
|     ~APM() override; | ||||
| 
 | ||||
| private: | ||||
|  | @ -26,7 +27,7 @@ private: | |||
| 
 | ||||
| class APM_Sys final : public ServiceFramework<APM_Sys> { | ||||
| public: | ||||
|     explicit APM_Sys(Controller& controller); | ||||
|     explicit APM_Sys(Core::System& system_, Controller& controller); | ||||
|     ~APM_Sys() override; | ||||
| 
 | ||||
|     void SetCpuBoostMode(Kernel::HLERequestContext& ctx); | ||||
|  |  | |||
|  | @ -8,7 +8,7 @@ | |||
| 
 | ||||
| namespace Service::Audio { | ||||
| 
 | ||||
| AudCtl::AudCtl() : ServiceFramework{"audctl"} { | ||||
| AudCtl::AudCtl(Core::System& system_) : ServiceFramework{system_, "audctl"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "GetTargetVolume"}, | ||||
|  |  | |||
|  | @ -6,11 +6,15 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::Audio { | ||||
| 
 | ||||
| class AudCtl final : public ServiceFramework<AudCtl> { | ||||
| public: | ||||
|     explicit AudCtl(); | ||||
|     explicit AudCtl(Core::System& system_); | ||||
|     ~AudCtl() override; | ||||
| 
 | ||||
| private: | ||||
|  |  | |||
|  | @ -6,7 +6,7 @@ | |||
| 
 | ||||
| namespace Service::Audio { | ||||
| 
 | ||||
| AudDbg::AudDbg(const char* name) : ServiceFramework{name} { | ||||
| AudDbg::AudDbg(Core::System& system_, const char* name) : ServiceFramework{system_, name} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "RequestSuspendForDebug"}, | ||||
|  |  | |||
|  | @ -6,11 +6,15 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::Audio { | ||||
| 
 | ||||
| class AudDbg final : public ServiceFramework<AudDbg> { | ||||
| public: | ||||
|     explicit AudDbg(const char* name); | ||||
|     explicit AudDbg(Core::System& system_, const char* name); | ||||
|     ~AudDbg() override; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -6,7 +6,7 @@ | |||
| 
 | ||||
| namespace Service::Audio { | ||||
| 
 | ||||
| AudInA::AudInA() : ServiceFramework{"audin:a"} { | ||||
| AudInA::AudInA(Core::System& system_) : ServiceFramework{system_, "audin:a"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "RequestSuspendAudioIns"}, | ||||
|  |  | |||
|  | @ -6,11 +6,15 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::Audio { | ||||
| 
 | ||||
| class AudInA final : public ServiceFramework<AudInA> { | ||||
| public: | ||||
|     explicit AudInA(); | ||||
|     explicit AudInA(Core::System& system_); | ||||
|     ~AudInA() override; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -11,7 +11,7 @@ namespace Service::Audio { | |||
| 
 | ||||
| class IAudioIn final : public ServiceFramework<IAudioIn> { | ||||
| public: | ||||
|     IAudioIn() : ServiceFramework("IAudioIn") { | ||||
|     explicit IAudioIn(Core::System& system_) : ServiceFramework{system_, "IAudioIn"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "GetAudioInState"}, | ||||
|  | @ -36,7 +36,7 @@ public: | |||
|     } | ||||
| }; | ||||
| 
 | ||||
| AudInU::AudInU() : ServiceFramework("audin:u") { | ||||
| AudInU::AudInU(Core::System& system_) : ServiceFramework{system_, "audin:u"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, &AudInU::ListAudioIns, "ListAudioIns"}, | ||||
|  | @ -96,7 +96,7 @@ void AudInU::OpenInOutImpl(Kernel::HLERequestContext& ctx) { | |||
|     IPC::ResponseBuilder rb{ctx, 6, 0, 1}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushRaw<AudInOutParams>(params); | ||||
|     rb.PushIpcInterface<IAudioIn>(); | ||||
|     rb.PushIpcInterface<IAudioIn>(system); | ||||
| } | ||||
| 
 | ||||
| void AudInU::OpenAudioIn(Kernel::HLERequestContext& ctx) { | ||||
|  |  | |||
|  | @ -6,6 +6,10 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Kernel { | ||||
| class HLERequestContext; | ||||
| } | ||||
|  | @ -14,7 +18,7 @@ namespace Service::Audio { | |||
| 
 | ||||
| class AudInU final : public ServiceFramework<AudInU> { | ||||
| public: | ||||
|     explicit AudInU(); | ||||
|     explicit AudInU(Core::System& system_); | ||||
|     ~AudInU() override; | ||||
| 
 | ||||
| private: | ||||
|  |  | |||
|  | @ -20,22 +20,22 @@ | |||
| namespace Service::Audio { | ||||
| 
 | ||||
| void InstallInterfaces(SM::ServiceManager& service_manager, Core::System& system) { | ||||
|     std::make_shared<AudCtl>()->InstallAsService(service_manager); | ||||
|     std::make_shared<AudOutA>()->InstallAsService(service_manager); | ||||
|     std::make_shared<AudCtl>(system)->InstallAsService(service_manager); | ||||
|     std::make_shared<AudOutA>(system)->InstallAsService(service_manager); | ||||
|     std::make_shared<AudOutU>(system)->InstallAsService(service_manager); | ||||
|     std::make_shared<AudInA>()->InstallAsService(service_manager); | ||||
|     std::make_shared<AudInU>()->InstallAsService(service_manager); | ||||
|     std::make_shared<AudRecA>()->InstallAsService(service_manager); | ||||
|     std::make_shared<AudRecU>()->InstallAsService(service_manager); | ||||
|     std::make_shared<AudRenA>()->InstallAsService(service_manager); | ||||
|     std::make_shared<AudInA>(system)->InstallAsService(service_manager); | ||||
|     std::make_shared<AudInU>(system)->InstallAsService(service_manager); | ||||
|     std::make_shared<AudRecA>(system)->InstallAsService(service_manager); | ||||
|     std::make_shared<AudRecU>(system)->InstallAsService(service_manager); | ||||
|     std::make_shared<AudRenA>(system)->InstallAsService(service_manager); | ||||
|     std::make_shared<AudRenU>(system)->InstallAsService(service_manager); | ||||
|     std::make_shared<CodecCtl>()->InstallAsService(service_manager); | ||||
|     std::make_shared<HwOpus>()->InstallAsService(service_manager); | ||||
|     std::make_shared<CodecCtl>(system)->InstallAsService(service_manager); | ||||
|     std::make_shared<HwOpus>(system)->InstallAsService(service_manager); | ||||
| 
 | ||||
|     std::make_shared<AudDbg>("audin:d")->InstallAsService(service_manager); | ||||
|     std::make_shared<AudDbg>("audout:d")->InstallAsService(service_manager); | ||||
|     std::make_shared<AudDbg>("audrec:d")->InstallAsService(service_manager); | ||||
|     std::make_shared<AudDbg>("audren:d")->InstallAsService(service_manager); | ||||
|     std::make_shared<AudDbg>(system, "audin:d")->InstallAsService(service_manager); | ||||
|     std::make_shared<AudDbg>(system, "audout:d")->InstallAsService(service_manager); | ||||
|     std::make_shared<AudDbg>(system, "audrec:d")->InstallAsService(service_manager); | ||||
|     std::make_shared<AudDbg>(system, "audren:d")->InstallAsService(service_manager); | ||||
| } | ||||
| 
 | ||||
| } // namespace Service::Audio
 | ||||
|  |  | |||
|  | @ -6,7 +6,7 @@ | |||
| 
 | ||||
| namespace Service::Audio { | ||||
| 
 | ||||
| AudOutA::AudOutA() : ServiceFramework{"audout:a"} { | ||||
| AudOutA::AudOutA(Core::System& system_) : ServiceFramework{system_, "audout:a"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "RequestSuspendAudioOuts"}, | ||||
|  |  | |||
|  | @ -6,11 +6,15 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::Audio { | ||||
| 
 | ||||
| class AudOutA final : public ServiceFramework<AudOutA> { | ||||
| public: | ||||
|     explicit AudOutA(); | ||||
|     explicit AudOutA(Core::System& system_); | ||||
|     ~AudOutA() override; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -40,11 +40,11 @@ enum class AudioState : u32 { | |||
| 
 | ||||
| class IAudioOut final : public ServiceFramework<IAudioOut> { | ||||
| public: | ||||
|     IAudioOut(Core::System& system, AudoutParams audio_params, AudioCore::AudioOut& audio_core, | ||||
|               std::string&& device_name, std::string&& unique_name) | ||||
|         : ServiceFramework("IAudioOut"), audio_core(audio_core), | ||||
|           device_name(std::move(device_name)), | ||||
|           audio_params(audio_params), main_memory{system.Memory()} { | ||||
|     IAudioOut(Core::System& system_, AudoutParams audio_params_, AudioCore::AudioOut& audio_core_, | ||||
|               std::string&& device_name_, std::string&& unique_name) | ||||
|         : ServiceFramework{system_, "IAudioOut"}, audio_core{audio_core_}, | ||||
|           device_name{std::move(device_name_)}, audio_params{audio_params_}, main_memory{ | ||||
|                                                                                  system.Memory()} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &IAudioOut::GetAudioOutState, "GetAudioOutState"}, | ||||
|  | @ -213,7 +213,7 @@ private: | |||
|     Core::Memory::Memory& main_memory; | ||||
| }; | ||||
| 
 | ||||
| AudOutU::AudOutU(Core::System& system_) : ServiceFramework("audout:u"), system{system_} { | ||||
| AudOutU::AudOutU(Core::System& system_) : ServiceFramework{system_, "audout:u"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, &AudOutU::ListAudioOutsImpl, "ListAudioOuts"}, | ||||
|  |  | |||
|  | @ -34,8 +34,6 @@ private: | |||
| 
 | ||||
|     std::vector<std::shared_ptr<IAudioOut>> audio_out_interfaces; | ||||
|     std::unique_ptr<AudioCore::AudioOut> audio_core; | ||||
| 
 | ||||
|     Core::System& system; | ||||
| }; | ||||
| 
 | ||||
| } // namespace Service::Audio
 | ||||
|  |  | |||
|  | @ -6,7 +6,7 @@ | |||
| 
 | ||||
| namespace Service::Audio { | ||||
| 
 | ||||
| AudRecA::AudRecA() : ServiceFramework{"audrec:a"} { | ||||
| AudRecA::AudRecA(Core::System& system_) : ServiceFramework{system_, "audrec:a"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "RequestSuspendFinalOutputRecorders"}, | ||||
|  |  | |||
|  | @ -6,11 +6,15 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::Audio { | ||||
| 
 | ||||
| class AudRecA final : public ServiceFramework<AudRecA> { | ||||
| public: | ||||
|     explicit AudRecA(); | ||||
|     explicit AudRecA(Core::System& system_); | ||||
|     ~AudRecA() override; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -8,7 +8,8 @@ namespace Service::Audio { | |||
| 
 | ||||
| class IFinalOutputRecorder final : public ServiceFramework<IFinalOutputRecorder> { | ||||
| public: | ||||
|     IFinalOutputRecorder() : ServiceFramework("IFinalOutputRecorder") { | ||||
|     explicit IFinalOutputRecorder(Core::System& system_) | ||||
|         : ServiceFramework{system_, "IFinalOutputRecorder"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "GetFinalOutputRecorderState"}, | ||||
|  | @ -29,7 +30,7 @@ public: | |||
|     } | ||||
| }; | ||||
| 
 | ||||
| AudRecU::AudRecU() : ServiceFramework("audrec:u") { | ||||
| AudRecU::AudRecU(Core::System& system_) : ServiceFramework{system_, "audrec:u"} { | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "OpenFinalOutputRecorder"}, | ||||
|     }; | ||||
|  |  | |||
|  | @ -6,15 +6,15 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Kernel { | ||||
| class HLERequestContext; | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::Audio { | ||||
| 
 | ||||
| class AudRecU final : public ServiceFramework<AudRecU> { | ||||
| public: | ||||
|     explicit AudRecU(); | ||||
|     explicit AudRecU(Core::System& system_); | ||||
|     ~AudRecU() override; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -6,7 +6,7 @@ | |||
| 
 | ||||
| namespace Service::Audio { | ||||
| 
 | ||||
| AudRenA::AudRenA() : ServiceFramework{"audren:a"} { | ||||
| AudRenA::AudRenA(Core::System& system_) : ServiceFramework{system_, "audren:a"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "RequestSuspendAudioRenderers"}, | ||||
|  |  | |||
|  | @ -6,11 +6,15 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::Audio { | ||||
| 
 | ||||
| class AudRenA final : public ServiceFramework<AudRenA> { | ||||
| public: | ||||
|     explicit AudRenA(); | ||||
|     explicit AudRenA(Core::System& system_); | ||||
|     ~AudRenA() override; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -28,7 +28,7 @@ class IAudioRenderer final : public ServiceFramework<IAudioRenderer> { | |||
| public: | ||||
|     explicit IAudioRenderer(Core::System& system, AudioCommon::AudioRendererParameter audren_params, | ||||
|                             const std::size_t instance_number) | ||||
|         : ServiceFramework("IAudioRenderer") { | ||||
|         : ServiceFramework{system, "IAudioRenderer"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &IAudioRenderer::GetSampleRate, "GetSampleRate"}, | ||||
|  | @ -167,8 +167,8 @@ private: | |||
| 
 | ||||
| class IAudioDevice final : public ServiceFramework<IAudioDevice> { | ||||
| public: | ||||
|     explicit IAudioDevice(Core::System& system, u32_le revision_num) | ||||
|         : ServiceFramework("IAudioDevice"), revision{revision_num} { | ||||
|     explicit IAudioDevice(Core::System& system_, u32_le revision_num) | ||||
|         : ServiceFramework{system_, "IAudioDevice"}, revision{revision_num} { | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &IAudioDevice::ListAudioDeviceName, "ListAudioDeviceName"}, | ||||
|             {1, &IAudioDevice::SetAudioDeviceOutputVolume, "SetAudioDeviceOutputVolume"}, | ||||
|  | @ -325,7 +325,7 @@ private: | |||
| 
 | ||||
| }; // namespace Audio
 | ||||
| 
 | ||||
| AudRenU::AudRenU(Core::System& system_) : ServiceFramework("audren:u"), system{system_} { | ||||
| AudRenU::AudRenU(Core::System& system_) : ServiceFramework{system_, "audren:u"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, &AudRenU::OpenAudioRenderer, "OpenAudioRenderer"}, | ||||
|  |  | |||
|  | @ -31,7 +31,6 @@ private: | |||
|     void OpenAudioRendererImpl(Kernel::HLERequestContext& ctx); | ||||
| 
 | ||||
|     std::size_t audren_instance_count = 0; | ||||
|     Core::System& system; | ||||
| }; | ||||
| 
 | ||||
| // Describes a particular audio feature that may be supported in a particular revision.
 | ||||
|  |  | |||
|  | @ -2,14 +2,11 @@ | |||
| // Licensed under GPLv2 or any later version
 | ||||
| // Refer to the license.txt file included.
 | ||||
| 
 | ||||
| #include "common/logging/log.h" | ||||
| #include "core/hle/ipc_helpers.h" | ||||
| #include "core/hle/kernel/hle_ipc.h" | ||||
| #include "core/hle/service/audio/codecctl.h" | ||||
| 
 | ||||
| namespace Service::Audio { | ||||
| 
 | ||||
| CodecCtl::CodecCtl() : ServiceFramework("codecctl") { | ||||
| CodecCtl::CodecCtl(Core::System& system_) : ServiceFramework{system_, "codecctl"} { | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "InitializeCodecController"}, | ||||
|         {1, nullptr, "FinalizeCodecController"}, | ||||
|  |  | |||
|  | @ -6,15 +6,15 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Kernel { | ||||
| class HLERequestContext; | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::Audio { | ||||
| 
 | ||||
| class CodecCtl final : public ServiceFramework<CodecCtl> { | ||||
| public: | ||||
|     explicit CodecCtl(); | ||||
|     explicit CodecCtl(Core::System& system_); | ||||
|     ~CodecCtl() override; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -160,8 +160,9 @@ private: | |||
| 
 | ||||
| class IHardwareOpusDecoderManager final : public ServiceFramework<IHardwareOpusDecoderManager> { | ||||
| public: | ||||
|     explicit IHardwareOpusDecoderManager(OpusDecoderState decoder_state) | ||||
|         : ServiceFramework("IHardwareOpusDecoderManager"), decoder_state{std::move(decoder_state)} { | ||||
|     explicit IHardwareOpusDecoderManager(Core::System& system_, OpusDecoderState decoder_state) | ||||
|         : ServiceFramework{system_, "IHardwareOpusDecoderManager"}, decoder_state{ | ||||
|                                                                         std::move(decoder_state)} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &IHardwareOpusDecoderManager::DecodeInterleavedOld, "DecodeInterleavedOld"}, | ||||
|  | @ -287,10 +288,10 @@ void HwOpus::OpenOpusDecoder(Kernel::HLERequestContext& ctx) { | |||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushIpcInterface<IHardwareOpusDecoderManager>( | ||||
|         OpusDecoderState{std::move(decoder), sample_rate, channel_count}); | ||||
|         system, OpusDecoderState{std::move(decoder), sample_rate, channel_count}); | ||||
| } | ||||
| 
 | ||||
| HwOpus::HwOpus() : ServiceFramework("hwopus") { | ||||
| HwOpus::HwOpus(Core::System& system_) : ServiceFramework{system_, "hwopus"} { | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, &HwOpus::OpenOpusDecoder, "OpenOpusDecoder"}, | ||||
|         {1, &HwOpus::GetWorkBufferSize, "GetWorkBufferSize"}, | ||||
|  |  | |||
|  | @ -6,11 +6,15 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::Audio { | ||||
| 
 | ||||
| class HwOpus final : public ServiceFramework<HwOpus> { | ||||
| public: | ||||
|     explicit HwOpus(); | ||||
|     explicit HwOpus(Core::System& system_); | ||||
|     ~HwOpus() override; | ||||
| 
 | ||||
| private: | ||||
|  |  | |||
|  | @ -88,9 +88,11 @@ struct DeliveryCacheDirectoryEntry { | |||
| 
 | ||||
| class IDeliveryCacheProgressService final : public ServiceFramework<IDeliveryCacheProgressService> { | ||||
| public: | ||||
|     IDeliveryCacheProgressService(std::shared_ptr<Kernel::ReadableEvent> event, | ||||
|                                   const DeliveryCacheProgressImpl& impl) | ||||
|         : ServiceFramework{"IDeliveryCacheProgressService"}, event(std::move(event)), impl(impl) { | ||||
|     explicit IDeliveryCacheProgressService(Core::System& system_, | ||||
|                                            std::shared_ptr<Kernel::ReadableEvent> event_, | ||||
|                                            const DeliveryCacheProgressImpl& impl_) | ||||
|         : ServiceFramework{system_, "IDeliveryCacheProgressService"}, event{std::move(event_)}, | ||||
|           impl{impl_} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &IDeliveryCacheProgressService::GetEvent, "GetEvent"}, | ||||
|  | @ -126,7 +128,7 @@ private: | |||
| class IBcatService final : public ServiceFramework<IBcatService> { | ||||
| public: | ||||
|     explicit IBcatService(Core::System& system_, Backend& backend_) | ||||
|         : ServiceFramework("IBcatService"), system{system_}, backend{backend_}, | ||||
|         : ServiceFramework{system_, "IBcatService"}, backend{backend_}, | ||||
|           progress{{ | ||||
|               ProgressServiceBackend{system_.Kernel(), "Normal"}, | ||||
|               ProgressServiceBackend{system_.Kernel(), "Directory"}, | ||||
|  | @ -171,7 +173,7 @@ private: | |||
| 
 | ||||
|     std::shared_ptr<IDeliveryCacheProgressService> CreateProgressService(SyncType type) { | ||||
|         auto& backend{progress.at(static_cast<std::size_t>(type))}; | ||||
|         return std::make_shared<IDeliveryCacheProgressService>(backend.GetEvent(), | ||||
|         return std::make_shared<IDeliveryCacheProgressService>(system, backend.GetEvent(), | ||||
|                                                                backend.GetImpl()); | ||||
|     } | ||||
| 
 | ||||
|  | @ -261,7 +263,6 @@ private: | |||
|         rb.Push(RESULT_SUCCESS); | ||||
|     } | ||||
| 
 | ||||
|     Core::System& system; | ||||
|     Backend& backend; | ||||
| 
 | ||||
|     std::array<ProgressServiceBackend, static_cast<std::size_t>(SyncType::Count)> progress; | ||||
|  | @ -277,8 +278,8 @@ void Module::Interface::CreateBcatService(Kernel::HLERequestContext& ctx) { | |||
| 
 | ||||
| class IDeliveryCacheFileService final : public ServiceFramework<IDeliveryCacheFileService> { | ||||
| public: | ||||
|     IDeliveryCacheFileService(FileSys::VirtualDir root_) | ||||
|         : ServiceFramework{"IDeliveryCacheFileService"}, root(std::move(root_)) { | ||||
|     explicit IDeliveryCacheFileService(Core::System& system_, FileSys::VirtualDir root_) | ||||
|         : ServiceFramework{system_, "IDeliveryCacheFileService"}, root(std::move(root_)) { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &IDeliveryCacheFileService::Open, "Open"}, | ||||
|  | @ -394,8 +395,8 @@ private: | |||
| class IDeliveryCacheDirectoryService final | ||||
|     : public ServiceFramework<IDeliveryCacheDirectoryService> { | ||||
| public: | ||||
|     IDeliveryCacheDirectoryService(FileSys::VirtualDir root_) | ||||
|         : ServiceFramework{"IDeliveryCacheDirectoryService"}, root(std::move(root_)) { | ||||
|     explicit IDeliveryCacheDirectoryService(Core::System& system_, FileSys::VirtualDir root_) | ||||
|         : ServiceFramework{system_, "IDeliveryCacheDirectoryService"}, root(std::move(root_)) { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &IDeliveryCacheDirectoryService::Open, "Open"}, | ||||
|  | @ -492,8 +493,8 @@ private: | |||
| 
 | ||||
| class IDeliveryCacheStorageService final : public ServiceFramework<IDeliveryCacheStorageService> { | ||||
| public: | ||||
|     IDeliveryCacheStorageService(FileSys::VirtualDir root_) | ||||
|         : ServiceFramework{"IDeliveryCacheStorageService"}, root(std::move(root_)) { | ||||
|     explicit IDeliveryCacheStorageService(Core::System& system_, FileSys::VirtualDir root_) | ||||
|         : ServiceFramework{system_, "IDeliveryCacheStorageService"}, root(std::move(root_)) { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &IDeliveryCacheStorageService::CreateFileService, "CreateFileService"}, | ||||
|  | @ -518,7 +519,7 @@ private: | |||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|         rb.PushIpcInterface<IDeliveryCacheFileService>(root); | ||||
|         rb.PushIpcInterface<IDeliveryCacheFileService>(system, root); | ||||
|     } | ||||
| 
 | ||||
|     void CreateDirectoryService(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -526,7 +527,7 @@ private: | |||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|         rb.PushIpcInterface<IDeliveryCacheDirectoryService>(root); | ||||
|         rb.PushIpcInterface<IDeliveryCacheDirectoryService>(system, root); | ||||
|     } | ||||
| 
 | ||||
|     void EnumerateDeliveryCacheDirectory(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -551,10 +552,10 @@ private: | |||
| void Module::Interface::CreateDeliveryCacheStorageService(Kernel::HLERequestContext& ctx) { | ||||
|     LOG_DEBUG(Service_BCAT, "called"); | ||||
| 
 | ||||
|     const auto title_id = system.CurrentProcess()->GetTitleID(); | ||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushIpcInterface<IDeliveryCacheStorageService>( | ||||
|         fsc.GetBCATDirectory(system.CurrentProcess()->GetTitleID())); | ||||
|     rb.PushIpcInterface<IDeliveryCacheStorageService>(system, fsc.GetBCATDirectory(title_id)); | ||||
| } | ||||
| 
 | ||||
| void Module::Interface::CreateDeliveryCacheStorageServiceWithApplicationId( | ||||
|  | @ -566,7 +567,7 @@ void Module::Interface::CreateDeliveryCacheStorageServiceWithApplicationId( | |||
| 
 | ||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushIpcInterface<IDeliveryCacheStorageService>(fsc.GetBCATDirectory(title_id)); | ||||
|     rb.PushIpcInterface<IDeliveryCacheStorageService>(system, fsc.GetBCATDirectory(title_id)); | ||||
| } | ||||
| 
 | ||||
| std::unique_ptr<Backend> CreateBackendFromSettings([[maybe_unused]] Core::System& system, | ||||
|  | @ -582,10 +583,9 @@ std::unique_ptr<Backend> CreateBackendFromSettings([[maybe_unused]] Core::System | |||
| 
 | ||||
| Module::Interface::Interface(Core::System& system_, std::shared_ptr<Module> module_, | ||||
|                              FileSystem::FileSystemController& fsc_, const char* name) | ||||
|     : ServiceFramework(name), fsc{fsc_}, module{std::move(module_)}, | ||||
|     : ServiceFramework{system_, name}, fsc{fsc_}, module{std::move(module_)}, | ||||
|       backend{CreateBackendFromSettings(system_, | ||||
|                                         [&fsc_](u64 tid) { return fsc_.GetBCATDirectory(tid); })}, | ||||
|       system{system_} {} | ||||
|                                         [&fsc_](u64 tid) { return fsc_.GetBCATDirectory(tid); })} {} | ||||
| 
 | ||||
| Module::Interface::~Interface() = default; | ||||
| 
 | ||||
|  |  | |||
|  | @ -37,9 +37,6 @@ public: | |||
| 
 | ||||
|         std::shared_ptr<Module> module; | ||||
|         std::unique_ptr<Backend> backend; | ||||
| 
 | ||||
|     private: | ||||
|         Core::System& system; | ||||
|     }; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -12,7 +12,7 @@ namespace Service::BPC { | |||
| 
 | ||||
| class BPC final : public ServiceFramework<BPC> { | ||||
| public: | ||||
|     explicit BPC() : ServiceFramework{"bpc"} { | ||||
|     explicit BPC(Core::System& system_) : ServiceFramework{system_, "bpc"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "ShutdownSystem"}, | ||||
|  | @ -40,7 +40,7 @@ public: | |||
| 
 | ||||
| class BPC_R final : public ServiceFramework<BPC_R> { | ||||
| public: | ||||
|     explicit BPC_R() : ServiceFramework{"bpc:r"} { | ||||
|     explicit BPC_R(Core::System& system_) : ServiceFramework{system_, "bpc:r"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "GetRtcTime"}, | ||||
|  | @ -55,9 +55,9 @@ public: | |||
|     } | ||||
| }; | ||||
| 
 | ||||
| void InstallInterfaces(SM::ServiceManager& sm) { | ||||
|     std::make_shared<BPC>()->InstallAsService(sm); | ||||
|     std::make_shared<BPC_R>()->InstallAsService(sm); | ||||
| void InstallInterfaces(SM::ServiceManager& sm, Core::System& system) { | ||||
|     std::make_shared<BPC>(system)->InstallAsService(sm); | ||||
|     std::make_shared<BPC_R>(system)->InstallAsService(sm); | ||||
| } | ||||
| 
 | ||||
| } // namespace Service::BPC
 | ||||
|  |  | |||
|  | @ -4,12 +4,16 @@ | |||
| 
 | ||||
| #pragma once | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::SM { | ||||
| class ServiceManager; | ||||
| } | ||||
| 
 | ||||
| namespace Service::BPC { | ||||
| 
 | ||||
| void InstallInterfaces(SM::ServiceManager& sm); | ||||
| void InstallInterfaces(SM::ServiceManager& sm, Core::System& system); | ||||
| 
 | ||||
| } // namespace Service::BPC
 | ||||
|  |  | |||
|  | @ -17,7 +17,7 @@ namespace Service::BtDrv { | |||
| 
 | ||||
| class Bt final : public ServiceFramework<Bt> { | ||||
| public: | ||||
|     explicit Bt(Core::System& system) : ServiceFramework{"bt"} { | ||||
|     explicit Bt(Core::System& system_) : ServiceFramework{system_, "bt"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "LeClientReadCharacteristic"}, | ||||
|  | @ -52,7 +52,7 @@ private: | |||
| 
 | ||||
| class BtDrv final : public ServiceFramework<BtDrv> { | ||||
| public: | ||||
|     explicit BtDrv() : ServiceFramework{"btdrv"} { | ||||
|     explicit BtDrv(Core::System& system_) : ServiceFramework{system_, "btdrv"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "InitializeBluetoothDriver"}, | ||||
|  | @ -166,7 +166,7 @@ public: | |||
| }; | ||||
| 
 | ||||
| void InstallInterfaces(SM::ServiceManager& sm, Core::System& system) { | ||||
|     std::make_shared<BtDrv>()->InstallAsService(sm); | ||||
|     std::make_shared<BtDrv>(system)->InstallAsService(sm); | ||||
|     std::make_shared<Bt>(system)->InstallAsService(sm); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -18,7 +18,7 @@ namespace Service::BTM { | |||
| 
 | ||||
| class IBtmUserCore final : public ServiceFramework<IBtmUserCore> { | ||||
| public: | ||||
|     explicit IBtmUserCore(Core::System& system) : ServiceFramework{"IBtmUserCore"} { | ||||
|     explicit IBtmUserCore(Core::System& system_) : ServiceFramework{system_, "IBtmUserCore"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &IBtmUserCore::AcquireBleScanEvent, "AcquireBleScanEvent"}, | ||||
|  | @ -107,7 +107,7 @@ private: | |||
| 
 | ||||
| class BTM_USR final : public ServiceFramework<BTM_USR> { | ||||
| public: | ||||
|     explicit BTM_USR(Core::System& system) : ServiceFramework{"btm:u"}, system(system) { | ||||
|     explicit BTM_USR(Core::System& system_) : ServiceFramework{system_, "btm:u"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &BTM_USR::GetCore, "GetCore"}, | ||||
|  | @ -124,13 +124,11 @@ private: | |||
|         rb.Push(RESULT_SUCCESS); | ||||
|         rb.PushIpcInterface<IBtmUserCore>(system); | ||||
|     } | ||||
| 
 | ||||
|     Core::System& system; | ||||
| }; | ||||
| 
 | ||||
| class BTM final : public ServiceFramework<BTM> { | ||||
| public: | ||||
|     explicit BTM() : ServiceFramework{"btm"} { | ||||
|     explicit BTM(Core::System& system_) : ServiceFramework{system_, "btm"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "GetState"}, | ||||
|  | @ -207,7 +205,7 @@ public: | |||
| 
 | ||||
| class BTM_DBG final : public ServiceFramework<BTM_DBG> { | ||||
| public: | ||||
|     explicit BTM_DBG() : ServiceFramework{"btm:dbg"} { | ||||
|     explicit BTM_DBG(Core::System& system_) : ServiceFramework{system_, "btm:dbg"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "AcquireDiscoveryEvent"}, | ||||
|  | @ -232,7 +230,7 @@ public: | |||
| 
 | ||||
| class IBtmSystemCore final : public ServiceFramework<IBtmSystemCore> { | ||||
| public: | ||||
|     explicit IBtmSystemCore() : ServiceFramework{"IBtmSystemCore"} { | ||||
|     explicit IBtmSystemCore(Core::System& system_) : ServiceFramework{system_, "IBtmSystemCore"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "StartGamepadPairing"}, | ||||
|  | @ -254,7 +252,7 @@ public: | |||
| 
 | ||||
| class BTM_SYS final : public ServiceFramework<BTM_SYS> { | ||||
| public: | ||||
|     explicit BTM_SYS() : ServiceFramework{"btm:sys"} { | ||||
|     explicit BTM_SYS(Core::System& system_) : ServiceFramework{system_, "btm:sys"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &BTM_SYS::GetCore, "GetCore"}, | ||||
|  | @ -270,14 +268,14 @@ private: | |||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|         rb.PushIpcInterface<IBtmSystemCore>(); | ||||
|         rb.PushIpcInterface<IBtmSystemCore>(system); | ||||
|     } | ||||
| }; | ||||
| 
 | ||||
| void InstallInterfaces(SM::ServiceManager& sm, Core::System& system) { | ||||
|     std::make_shared<BTM>()->InstallAsService(sm); | ||||
|     std::make_shared<BTM_DBG>()->InstallAsService(sm); | ||||
|     std::make_shared<BTM_SYS>()->InstallAsService(sm); | ||||
|     std::make_shared<BTM>(system)->InstallAsService(sm); | ||||
|     std::make_shared<BTM_DBG>(system)->InstallAsService(sm); | ||||
|     std::make_shared<BTM_SYS>(system)->InstallAsService(sm); | ||||
|     std::make_shared<BTM_USR>(system)->InstallAsService(sm); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -13,13 +13,13 @@ | |||
| 
 | ||||
| namespace Service::Capture { | ||||
| 
 | ||||
| void InstallInterfaces(SM::ServiceManager& sm) { | ||||
|     std::make_shared<CAPS_A>()->InstallAsService(sm); | ||||
|     std::make_shared<CAPS_C>()->InstallAsService(sm); | ||||
|     std::make_shared<CAPS_U>()->InstallAsService(sm); | ||||
|     std::make_shared<CAPS_SC>()->InstallAsService(sm); | ||||
|     std::make_shared<CAPS_SS>()->InstallAsService(sm); | ||||
|     std::make_shared<CAPS_SU>()->InstallAsService(sm); | ||||
| void InstallInterfaces(SM::ServiceManager& sm, Core::System& system) { | ||||
|     std::make_shared<CAPS_A>(system)->InstallAsService(sm); | ||||
|     std::make_shared<CAPS_C>(system)->InstallAsService(sm); | ||||
|     std::make_shared<CAPS_U>(system)->InstallAsService(sm); | ||||
|     std::make_shared<CAPS_SC>(system)->InstallAsService(sm); | ||||
|     std::make_shared<CAPS_SS>(system)->InstallAsService(sm); | ||||
|     std::make_shared<CAPS_SU>(system)->InstallAsService(sm); | ||||
| } | ||||
| 
 | ||||
| } // namespace Service::Capture
 | ||||
|  |  | |||
|  | @ -6,6 +6,10 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::SM { | ||||
| class ServiceManager; | ||||
| } | ||||
|  | @ -87,6 +91,6 @@ static_assert(sizeof(ApplicationAlbumFileEntry) == 0x30, | |||
|               "ApplicationAlbumFileEntry has incorrect size."); | ||||
| 
 | ||||
| /// Registers all Capture services with the specified service manager.
 | ||||
| void InstallInterfaces(SM::ServiceManager& sm); | ||||
| void InstallInterfaces(SM::ServiceManager& sm, Core::System& system); | ||||
| 
 | ||||
| } // namespace Service::Capture
 | ||||
|  |  | |||
|  | @ -8,7 +8,8 @@ namespace Service::Capture { | |||
| 
 | ||||
| class IAlbumAccessorSession final : public ServiceFramework<IAlbumAccessorSession> { | ||||
| public: | ||||
|     explicit IAlbumAccessorSession() : ServiceFramework{"IAlbumAccessorSession"} { | ||||
|     explicit IAlbumAccessorSession(Core::System& system_) | ||||
|         : ServiceFramework{system_, "IAlbumAccessorSession"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {2001, nullptr, "OpenAlbumMovieReadStream"}, | ||||
|  | @ -26,7 +27,7 @@ public: | |||
|     } | ||||
| }; | ||||
| 
 | ||||
| CAPS_A::CAPS_A() : ServiceFramework("caps:a") { | ||||
| CAPS_A::CAPS_A(Core::System& system_) : ServiceFramework{system_, "caps:a"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "GetAlbumFileCount"}, | ||||
|  |  | |||
|  | @ -6,6 +6,10 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Kernel { | ||||
| class HLERequestContext; | ||||
| } | ||||
|  | @ -14,7 +18,7 @@ namespace Service::Capture { | |||
| 
 | ||||
| class CAPS_A final : public ServiceFramework<CAPS_A> { | ||||
| public: | ||||
|     explicit CAPS_A(); | ||||
|     explicit CAPS_A(Core::System& system_); | ||||
|     ~CAPS_A() override; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -10,7 +10,8 @@ namespace Service::Capture { | |||
| 
 | ||||
| class IAlbumControlSession final : public ServiceFramework<IAlbumControlSession> { | ||||
| public: | ||||
|     explicit IAlbumControlSession() : ServiceFramework{"IAlbumControlSession"} { | ||||
|     explicit IAlbumControlSession(Core::System& system_) | ||||
|         : ServiceFramework{system_, "IAlbumControlSession"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {2001, nullptr, "OpenAlbumMovieReadStream"}, | ||||
|  | @ -44,7 +45,7 @@ public: | |||
|     } | ||||
| }; | ||||
| 
 | ||||
| CAPS_C::CAPS_C() : ServiceFramework("caps:c") { | ||||
| CAPS_C::CAPS_C(Core::System& system_) : ServiceFramework{system_, "caps:c"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {1, nullptr, "CaptureRawImage"}, | ||||
|  |  | |||
|  | @ -6,6 +6,10 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Kernel { | ||||
| class HLERequestContext; | ||||
| } | ||||
|  | @ -14,7 +18,7 @@ namespace Service::Capture { | |||
| 
 | ||||
| class CAPS_C final : public ServiceFramework<CAPS_C> { | ||||
| public: | ||||
|     explicit CAPS_C(); | ||||
|     explicit CAPS_C(Core::System& system_); | ||||
|     ~CAPS_C() override; | ||||
| 
 | ||||
| private: | ||||
|  |  | |||
|  | @ -6,7 +6,7 @@ | |||
| 
 | ||||
| namespace Service::Capture { | ||||
| 
 | ||||
| CAPS_SC::CAPS_SC() : ServiceFramework("caps:sc") { | ||||
| CAPS_SC::CAPS_SC(Core::System& system_) : ServiceFramework{system_, "caps:sc"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {1, nullptr, "CaptureRawImage"}, | ||||
|  |  | |||
|  | @ -6,15 +6,15 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Kernel { | ||||
| class HLERequestContext; | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::Capture { | ||||
| 
 | ||||
| class CAPS_SC final : public ServiceFramework<CAPS_SC> { | ||||
| public: | ||||
|     explicit CAPS_SC(); | ||||
|     explicit CAPS_SC(Core::System& system_); | ||||
|     ~CAPS_SC() override; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -6,7 +6,7 @@ | |||
| 
 | ||||
| namespace Service::Capture { | ||||
| 
 | ||||
| CAPS_SS::CAPS_SS() : ServiceFramework("caps:ss") { | ||||
| CAPS_SS::CAPS_SS(Core::System& system_) : ServiceFramework{system_, "caps:ss"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {201, nullptr, "SaveScreenShot"}, | ||||
|  |  | |||
|  | @ -6,15 +6,15 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Kernel { | ||||
| class HLERequestContext; | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::Capture { | ||||
| 
 | ||||
| class CAPS_SS final : public ServiceFramework<CAPS_SS> { | ||||
| public: | ||||
|     explicit CAPS_SS(); | ||||
|     explicit CAPS_SS(Core::System& system_); | ||||
|     ~CAPS_SS() override; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -8,7 +8,7 @@ | |||
| 
 | ||||
| namespace Service::Capture { | ||||
| 
 | ||||
| CAPS_SU::CAPS_SU() : ServiceFramework("caps:su") { | ||||
| CAPS_SU::CAPS_SU(Core::System& system_) : ServiceFramework{system_, "caps:su"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {32, &CAPS_SU::SetShimLibraryVersion, "SetShimLibraryVersion"}, | ||||
|  |  | |||
|  | @ -6,6 +6,10 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Kernel { | ||||
| class HLERequestContext; | ||||
| } | ||||
|  | @ -14,7 +18,7 @@ namespace Service::Capture { | |||
| 
 | ||||
| class CAPS_SU final : public ServiceFramework<CAPS_SU> { | ||||
| public: | ||||
|     explicit CAPS_SU(); | ||||
|     explicit CAPS_SU(Core::System& system_); | ||||
|     ~CAPS_SU() override; | ||||
| 
 | ||||
| private: | ||||
|  |  | |||
|  | @ -12,8 +12,8 @@ namespace Service::Capture { | |||
| class IAlbumAccessorApplicationSession final | ||||
|     : public ServiceFramework<IAlbumAccessorApplicationSession> { | ||||
| public: | ||||
|     explicit IAlbumAccessorApplicationSession() | ||||
|         : ServiceFramework{"IAlbumAccessorApplicationSession"} { | ||||
|     explicit IAlbumAccessorApplicationSession(Core::System& system_) | ||||
|         : ServiceFramework{system_, "IAlbumAccessorApplicationSession"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {2001, nullptr, "OpenAlbumMovieReadStream"}, | ||||
|  | @ -28,7 +28,7 @@ public: | |||
|     } | ||||
| }; | ||||
| 
 | ||||
| CAPS_U::CAPS_U() : ServiceFramework("caps:u") { | ||||
| CAPS_U::CAPS_U(Core::System& system_) : ServiceFramework{system_, "caps:u"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {32, &CAPS_U::SetShimLibraryVersion, "SetShimLibraryVersion"}, | ||||
|  |  | |||
|  | @ -6,6 +6,10 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Kernel { | ||||
| class HLERequestContext; | ||||
| } | ||||
|  | @ -14,7 +18,7 @@ namespace Service::Capture { | |||
| 
 | ||||
| class CAPS_U final : public ServiceFramework<CAPS_U> { | ||||
| public: | ||||
|     explicit CAPS_U(); | ||||
|     explicit CAPS_U(Core::System& system_); | ||||
|     ~CAPS_U() override; | ||||
| 
 | ||||
| private: | ||||
|  |  | |||
|  | @ -12,7 +12,7 @@ namespace Service::ERPT { | |||
| 
 | ||||
| class ErrorReportContext final : public ServiceFramework<ErrorReportContext> { | ||||
| public: | ||||
|     explicit ErrorReportContext() : ServiceFramework{"erpt:c"} { | ||||
|     explicit ErrorReportContext(Core::System& system_) : ServiceFramework{system_, "erpt:c"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "SubmitContext"}, | ||||
|  | @ -35,7 +35,7 @@ public: | |||
| 
 | ||||
| class ErrorReportSession final : public ServiceFramework<ErrorReportSession> { | ||||
| public: | ||||
|     explicit ErrorReportSession() : ServiceFramework{"erpt:r"} { | ||||
|     explicit ErrorReportSession(Core::System& system_) : ServiceFramework{system_, "erpt:r"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "OpenReport"}, | ||||
|  | @ -48,9 +48,9 @@ public: | |||
|     } | ||||
| }; | ||||
| 
 | ||||
| void InstallInterfaces(SM::ServiceManager& sm) { | ||||
|     std::make_shared<ErrorReportContext>()->InstallAsService(sm); | ||||
|     std::make_shared<ErrorReportSession>()->InstallAsService(sm); | ||||
| void InstallInterfaces(SM::ServiceManager& sm, Core::System& system) { | ||||
|     std::make_shared<ErrorReportContext>(system)->InstallAsService(sm); | ||||
|     std::make_shared<ErrorReportSession>(system)->InstallAsService(sm); | ||||
| } | ||||
| 
 | ||||
| } // namespace Service::ERPT
 | ||||
|  |  | |||
|  | @ -4,6 +4,10 @@ | |||
| 
 | ||||
| #pragma once | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::SM { | ||||
| class ServiceManager; | ||||
| } | ||||
|  | @ -11,6 +15,6 @@ class ServiceManager; | |||
| namespace Service::ERPT { | ||||
| 
 | ||||
| /// Registers all ERPT services with the specified service manager.
 | ||||
| void InstallInterfaces(SM::ServiceManager& sm); | ||||
| void InstallInterfaces(SM::ServiceManager& sm, Core::System& system); | ||||
| 
 | ||||
| } // namespace Service::ERPT
 | ||||
|  |  | |||
|  | @ -14,7 +14,7 @@ constexpr ResultCode ERROR_INVALID_RIGHTS_ID{ErrorModule::ETicket, 3}; | |||
| 
 | ||||
| class ETicket final : public ServiceFramework<ETicket> { | ||||
| public: | ||||
|     explicit ETicket() : ServiceFramework{"es"} { | ||||
|     explicit ETicket(Core::System& system_) : ServiceFramework{system_, "es"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {1, &ETicket::ImportTicket, "ImportTicket"}, | ||||
|  | @ -305,8 +305,8 @@ private: | |||
|     Core::Crypto::KeyManager& keys = Core::Crypto::KeyManager::Instance(); | ||||
| }; | ||||
| 
 | ||||
| void InstallInterfaces(SM::ServiceManager& service_manager) { | ||||
|     std::make_shared<ETicket>()->InstallAsService(service_manager); | ||||
| void InstallInterfaces(SM::ServiceManager& service_manager, Core::System& system) { | ||||
|     std::make_shared<ETicket>(system)->InstallAsService(service_manager); | ||||
| } | ||||
| 
 | ||||
| } // namespace Service::ES
 | ||||
|  |  | |||
|  | @ -4,6 +4,10 @@ | |||
| 
 | ||||
| #pragma once | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::SM { | ||||
| class ServiceManager; | ||||
| } | ||||
|  | @ -11,6 +15,6 @@ class ServiceManager; | |||
| namespace Service::ES { | ||||
| 
 | ||||
| /// Registers all ES services with the specified service manager.
 | ||||
| void InstallInterfaces(SM::ServiceManager& service_manager); | ||||
| void InstallInterfaces(SM::ServiceManager& service_manager, Core::System& system); | ||||
| 
 | ||||
| } // namespace Service::ES
 | ||||
|  |  | |||
|  | @ -12,7 +12,7 @@ namespace Service::EUPLD { | |||
| 
 | ||||
| class ErrorUploadContext final : public ServiceFramework<ErrorUploadContext> { | ||||
| public: | ||||
|     explicit ErrorUploadContext() : ServiceFramework{"eupld:c"} { | ||||
|     explicit ErrorUploadContext(Core::System& system_) : ServiceFramework{system_, "eupld:c"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "SetUrl"}, | ||||
|  | @ -29,7 +29,7 @@ public: | |||
| 
 | ||||
| class ErrorUploadRequest final : public ServiceFramework<ErrorUploadRequest> { | ||||
| public: | ||||
|     explicit ErrorUploadRequest() : ServiceFramework{"eupld:r"} { | ||||
|     explicit ErrorUploadRequest(Core::System& system_) : ServiceFramework{system_, "eupld:r"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "Initialize"}, | ||||
|  | @ -45,9 +45,9 @@ public: | |||
|     } | ||||
| }; | ||||
| 
 | ||||
| void InstallInterfaces(SM::ServiceManager& sm) { | ||||
|     std::make_shared<ErrorUploadContext>()->InstallAsService(sm); | ||||
|     std::make_shared<ErrorUploadRequest>()->InstallAsService(sm); | ||||
| void InstallInterfaces(SM::ServiceManager& sm, Core::System& system) { | ||||
|     std::make_shared<ErrorUploadContext>(system)->InstallAsService(sm); | ||||
|     std::make_shared<ErrorUploadRequest>(system)->InstallAsService(sm); | ||||
| } | ||||
| 
 | ||||
| } // namespace Service::EUPLD
 | ||||
|  |  | |||
|  | @ -4,6 +4,10 @@ | |||
| 
 | ||||
| #pragma once | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::SM { | ||||
| class ServiceManager; | ||||
| } | ||||
|  | @ -11,6 +15,6 @@ class ServiceManager; | |||
| namespace Service::EUPLD { | ||||
| 
 | ||||
| /// Registers all EUPLD services with the specified service manager.
 | ||||
| void InstallInterfaces(SM::ServiceManager& sm); | ||||
| void InstallInterfaces(SM::ServiceManager& sm, Core::System& system); | ||||
| 
 | ||||
| } // namespace Service::EUPLD
 | ||||
|  |  | |||
|  | @ -20,8 +20,9 @@ | |||
| 
 | ||||
| namespace Service::Fatal { | ||||
| 
 | ||||
| Module::Interface::Interface(std::shared_ptr<Module> module, Core::System& system, const char* name) | ||||
|     : ServiceFramework(name), module(std::move(module)), system(system) {} | ||||
| Module::Interface::Interface(std::shared_ptr<Module> module_, Core::System& system_, | ||||
|                              const char* name) | ||||
|     : ServiceFramework{system_, name}, module{std::move(module_)} {} | ||||
| 
 | ||||
| Module::Interface::~Interface() = default; | ||||
| 
 | ||||
|  |  | |||
|  | @ -16,7 +16,8 @@ class Module final { | |||
| public: | ||||
|     class Interface : public ServiceFramework<Interface> { | ||||
|     public: | ||||
|         explicit Interface(std::shared_ptr<Module> module, Core::System& system, const char* name); | ||||
|         explicit Interface(std::shared_ptr<Module> module_, Core::System& system_, | ||||
|                            const char* name); | ||||
|         ~Interface() override; | ||||
| 
 | ||||
|         void ThrowFatal(Kernel::HLERequestContext& ctx); | ||||
|  | @ -25,7 +26,6 @@ public: | |||
| 
 | ||||
|     protected: | ||||
|         std::shared_ptr<Module> module; | ||||
|         Core::System& system; | ||||
|     }; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -6,8 +6,8 @@ | |||
| 
 | ||||
| namespace Service::Fatal { | ||||
| 
 | ||||
| Fatal_P::Fatal_P(std::shared_ptr<Module> module, Core::System& system) | ||||
|     : Module::Interface(std::move(module), system, "fatal:p") {} | ||||
| Fatal_P::Fatal_P(std::shared_ptr<Module> module_, Core::System& system_) | ||||
|     : Interface(std::move(module_), system_, "fatal:p") {} | ||||
| 
 | ||||
| Fatal_P::~Fatal_P() = default; | ||||
| 
 | ||||
|  |  | |||
|  | @ -10,7 +10,7 @@ namespace Service::Fatal { | |||
| 
 | ||||
| class Fatal_P final : public Module::Interface { | ||||
| public: | ||||
|     explicit Fatal_P(std::shared_ptr<Module> module, Core::System& system); | ||||
|     explicit Fatal_P(std::shared_ptr<Module> module_, Core::System& system_); | ||||
|     ~Fatal_P() override; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -6,8 +6,8 @@ | |||
| 
 | ||||
| namespace Service::Fatal { | ||||
| 
 | ||||
| Fatal_U::Fatal_U(std::shared_ptr<Module> module, Core::System& system) | ||||
|     : Module::Interface(std::move(module), system, "fatal:u") { | ||||
| Fatal_U::Fatal_U(std::shared_ptr<Module> module_, Core::System& system_) | ||||
|     : Interface(std::move(module_), system_, "fatal:u") { | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, &Fatal_U::ThrowFatal, "ThrowFatal"}, | ||||
|         {1, &Fatal_U::ThrowFatalWithPolicy, "ThrowFatalWithPolicy"}, | ||||
|  |  | |||
|  | @ -10,7 +10,7 @@ namespace Service::Fatal { | |||
| 
 | ||||
| class Fatal_U final : public Module::Interface { | ||||
| public: | ||||
|     explicit Fatal_U(std::shared_ptr<Module> module, Core::System& system); | ||||
|     explicit Fatal_U(std::shared_ptr<Module> module_, Core::System& system_); | ||||
|     ~Fatal_U() override; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -14,7 +14,7 @@ namespace Service::FGM { | |||
| 
 | ||||
| class IRequest final : public ServiceFramework<IRequest> { | ||||
| public: | ||||
|     explicit IRequest() : ServiceFramework{"IRequest"} { | ||||
|     explicit IRequest(Core::System& system_) : ServiceFramework{system_, "IRequest"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "Initialize"}, | ||||
|  | @ -30,7 +30,7 @@ public: | |||
| 
 | ||||
| class FGM final : public ServiceFramework<FGM> { | ||||
| public: | ||||
|     explicit FGM(const char* name) : ServiceFramework{name} { | ||||
|     explicit FGM(Core::System& system_, const char* name) : ServiceFramework{system_, name} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &FGM::Initialize, "Initialize"}, | ||||
|  | @ -46,13 +46,13 @@ private: | |||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|         rb.PushIpcInterface<IRequest>(); | ||||
|         rb.PushIpcInterface<IRequest>(system); | ||||
|     } | ||||
| }; | ||||
| 
 | ||||
| class FGM_DBG final : public ServiceFramework<FGM_DBG> { | ||||
| public: | ||||
|     explicit FGM_DBG() : ServiceFramework{"fgm:dbg"} { | ||||
|     explicit FGM_DBG(Core::System& system_) : ServiceFramework{system_, "fgm:dbg"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "Initialize"}, | ||||
|  | @ -65,11 +65,11 @@ public: | |||
|     } | ||||
| }; | ||||
| 
 | ||||
| void InstallInterfaces(SM::ServiceManager& sm) { | ||||
|     std::make_shared<FGM>("fgm")->InstallAsService(sm); | ||||
|     std::make_shared<FGM>("fgm:0")->InstallAsService(sm); | ||||
|     std::make_shared<FGM>("fgm:9")->InstallAsService(sm); | ||||
|     std::make_shared<FGM_DBG>()->InstallAsService(sm); | ||||
| void InstallInterfaces(SM::ServiceManager& sm, Core::System& system) { | ||||
|     std::make_shared<FGM>(system, "fgm")->InstallAsService(sm); | ||||
|     std::make_shared<FGM>(system, "fgm:0")->InstallAsService(sm); | ||||
|     std::make_shared<FGM>(system, "fgm:9")->InstallAsService(sm); | ||||
|     std::make_shared<FGM_DBG>(system)->InstallAsService(sm); | ||||
| } | ||||
| 
 | ||||
| } // namespace Service::FGM
 | ||||
|  |  | |||
|  | @ -4,12 +4,16 @@ | |||
| 
 | ||||
| #pragma once | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::SM { | ||||
| class ServiceManager; | ||||
| } | ||||
| 
 | ||||
| namespace Service::FGM { | ||||
| 
 | ||||
| void InstallInterfaces(SM::ServiceManager& sm); | ||||
| void InstallInterfaces(SM::ServiceManager& sm, Core::System& system); | ||||
| 
 | ||||
| } // namespace Service::FGM
 | ||||
|  |  | |||
|  | @ -728,11 +728,9 @@ void FileSystemController::CreateFactories(FileSys::VfsFilesystem& vfs, bool ove | |||
| } | ||||
| 
 | ||||
| void InstallInterfaces(Core::System& system) { | ||||
|     std::make_shared<FSP_LDR>()->InstallAsService(system.ServiceManager()); | ||||
|     std::make_shared<FSP_PR>()->InstallAsService(system.ServiceManager()); | ||||
|     std::make_shared<FSP_SRV>(system.GetFileSystemController(), system.GetContentProvider(), | ||||
|                               system.GetReporter()) | ||||
|         ->InstallAsService(system.ServiceManager()); | ||||
|     std::make_shared<FSP_LDR>(system)->InstallAsService(system.ServiceManager()); | ||||
|     std::make_shared<FSP_PR>(system)->InstallAsService(system.ServiceManager()); | ||||
|     std::make_shared<FSP_SRV>(system)->InstallAsService(system.ServiceManager()); | ||||
| } | ||||
| 
 | ||||
| } // namespace Service::FileSystem
 | ||||
|  |  | |||
|  | @ -7,7 +7,7 @@ | |||
| 
 | ||||
| namespace Service::FileSystem { | ||||
| 
 | ||||
| FSP_LDR::FSP_LDR() : ServiceFramework{"fsp:ldr"} { | ||||
| FSP_LDR::FSP_LDR(Core::System& system_) : ServiceFramework{system_, "fsp:ldr"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "OpenCodeFileSystem"}, | ||||
|  |  | |||
|  | @ -6,11 +6,15 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::FileSystem { | ||||
| 
 | ||||
| class FSP_LDR final : public ServiceFramework<FSP_LDR> { | ||||
| public: | ||||
|     explicit FSP_LDR(); | ||||
|     explicit FSP_LDR(Core::System& system_); | ||||
|     ~FSP_LDR() override; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -7,7 +7,7 @@ | |||
| 
 | ||||
| namespace Service::FileSystem { | ||||
| 
 | ||||
| FSP_PR::FSP_PR() : ServiceFramework{"fsp:pr"} { | ||||
| FSP_PR::FSP_PR(Core::System& system_) : ServiceFramework{system_, "fsp:pr"} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "RegisterProgram"}, | ||||
|  |  | |||
|  | @ -6,11 +6,15 @@ | |||
| 
 | ||||
| #include "core/hle/service/service.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| } | ||||
| 
 | ||||
| namespace Service::FileSystem { | ||||
| 
 | ||||
| class FSP_PR final : public ServiceFramework<FSP_PR> { | ||||
| public: | ||||
|     explicit FSP_PR(); | ||||
|     explicit FSP_PR(Core::System& system_); | ||||
|     ~FSP_PR() override; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -14,6 +14,7 @@ | |||
| #include "common/hex_util.h" | ||||
| #include "common/logging/log.h" | ||||
| #include "common/string_util.h" | ||||
| #include "core/core.h" | ||||
| #include "core/file_sys/directory.h" | ||||
| #include "core/file_sys/errors.h" | ||||
| #include "core/file_sys/mode.h" | ||||
|  | @ -56,8 +57,8 @@ enum class FileSystemType : u8 { | |||
| 
 | ||||
| class IStorage final : public ServiceFramework<IStorage> { | ||||
| public: | ||||
|     explicit IStorage(FileSys::VirtualFile backend_) | ||||
|         : ServiceFramework("IStorage"), backend(std::move(backend_)) { | ||||
|     explicit IStorage(Core::System& system_, FileSys::VirtualFile backend_) | ||||
|         : ServiceFramework{system_, "IStorage"}, backend(std::move(backend_)) { | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &IStorage::Read, "Read"}, | ||||
|             {1, nullptr, "Write"}, | ||||
|  | @ -114,8 +115,8 @@ private: | |||
| 
 | ||||
| class IFile final : public ServiceFramework<IFile> { | ||||
| public: | ||||
|     explicit IFile(FileSys::VirtualFile backend_) | ||||
|         : ServiceFramework("IFile"), backend(std::move(backend_)) { | ||||
|     explicit IFile(Core::System& system_, FileSys::VirtualFile backend_) | ||||
|         : ServiceFramework{system_, "IFile"}, backend(std::move(backend_)) { | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &IFile::Read, "Read"},       {1, &IFile::Write, "Write"}, | ||||
|             {2, &IFile::Flush, "Flush"},     {3, &IFile::SetSize, "SetSize"}, | ||||
|  | @ -246,8 +247,8 @@ static void BuildEntryIndex(std::vector<FileSys::Entry>& entries, const std::vec | |||
| 
 | ||||
| class IDirectory final : public ServiceFramework<IDirectory> { | ||||
| public: | ||||
|     explicit IDirectory(FileSys::VirtualDir backend_) | ||||
|         : ServiceFramework("IDirectory"), backend(std::move(backend_)) { | ||||
|     explicit IDirectory(Core::System& system_, FileSys::VirtualDir backend_) | ||||
|         : ServiceFramework{system_, "IDirectory"}, backend(std::move(backend_)) { | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &IDirectory::Read, "Read"}, | ||||
|             {1, &IDirectory::GetEntryCount, "GetEntryCount"}, | ||||
|  | @ -302,8 +303,9 @@ private: | |||
| 
 | ||||
| class IFileSystem final : public ServiceFramework<IFileSystem> { | ||||
| public: | ||||
|     explicit IFileSystem(FileSys::VirtualDir backend, SizeGetter size) | ||||
|         : ServiceFramework("IFileSystem"), backend(std::move(backend)), size(std::move(size)) { | ||||
|     explicit IFileSystem(Core::System& system_, FileSys::VirtualDir backend_, SizeGetter size_) | ||||
|         : ServiceFramework{system_, "IFileSystem"}, backend{std::move(backend_)}, size{std::move( | ||||
|                                                                                       size_)} { | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &IFileSystem::CreateFile, "CreateFile"}, | ||||
|             {1, &IFileSystem::DeleteFile, "DeleteFile"}, | ||||
|  | @ -420,7 +422,7 @@ public: | |||
|             return; | ||||
|         } | ||||
| 
 | ||||
|         auto file = std::make_shared<IFile>(result.Unwrap()); | ||||
|         auto file = std::make_shared<IFile>(system, result.Unwrap()); | ||||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|  | @ -445,7 +447,7 @@ public: | |||
|             return; | ||||
|         } | ||||
| 
 | ||||
|         auto directory = std::make_shared<IDirectory>(result.Unwrap()); | ||||
|         auto directory = std::make_shared<IDirectory>(system, result.Unwrap()); | ||||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|  | @ -500,8 +502,9 @@ private: | |||
| 
 | ||||
| class ISaveDataInfoReader final : public ServiceFramework<ISaveDataInfoReader> { | ||||
| public: | ||||
|     explicit ISaveDataInfoReader(FileSys::SaveDataSpaceId space, FileSystemController& fsc) | ||||
|         : ServiceFramework("ISaveDataInfoReader"), fsc(fsc) { | ||||
|     explicit ISaveDataInfoReader(Core::System& system_, FileSys::SaveDataSpaceId space, | ||||
|                                  FileSystemController& fsc_) | ||||
|         : ServiceFramework{system_, "ISaveDataInfoReader"}, fsc{fsc_} { | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &ISaveDataInfoReader::ReadSaveDataInfo, "ReadSaveDataInfo"}, | ||||
|         }; | ||||
|  | @ -650,10 +653,9 @@ private: | |||
|     u64 next_entry_index = 0; | ||||
| }; | ||||
| 
 | ||||
| FSP_SRV::FSP_SRV(FileSystemController& fsc_, const FileSys::ContentProvider& content_provider_, | ||||
|                  const Core::Reporter& reporter_) | ||||
|     : ServiceFramework("fsp-srv"), fsc(fsc_), content_provider{content_provider_}, | ||||
|       reporter(reporter_) { | ||||
| FSP_SRV::FSP_SRV(Core::System& system_) | ||||
|     : ServiceFramework{system_, "fsp-srv"}, fsc{system.GetFileSystemController()}, | ||||
|       content_provider{system.GetContentProvider()}, reporter{system.GetReporter()} { | ||||
|     // clang-format off
 | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0, nullptr, "OpenFileSystem"}, | ||||
|  | @ -803,8 +805,9 @@ void FSP_SRV::OpenFileSystemWithPatch(Kernel::HLERequestContext& ctx) { | |||
| void FSP_SRV::OpenSdCardFileSystem(Kernel::HLERequestContext& ctx) { | ||||
|     LOG_DEBUG(Service_FS, "called"); | ||||
| 
 | ||||
|     auto filesystem = std::make_shared<IFileSystem>( | ||||
|         fsc.OpenSDMC().Unwrap(), SizeGetter::FromStorageId(fsc, FileSys::StorageId::SdCard)); | ||||
|     auto filesystem = | ||||
|         std::make_shared<IFileSystem>(system, fsc.OpenSDMC().Unwrap(), | ||||
|                                       SizeGetter::FromStorageId(fsc, FileSys::StorageId::SdCard)); | ||||
| 
 | ||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|  | @ -864,8 +867,8 @@ void FSP_SRV::OpenSaveDataFileSystem(Kernel::HLERequestContext& ctx) { | |||
|         UNREACHABLE(); | ||||
|     } | ||||
| 
 | ||||
|     auto filesystem = | ||||
|         std::make_shared<IFileSystem>(std::move(dir.Unwrap()), SizeGetter::FromStorageId(fsc, id)); | ||||
|     auto filesystem = std::make_shared<IFileSystem>(system, std::move(dir.Unwrap()), | ||||
|                                                     SizeGetter::FromStorageId(fsc, id)); | ||||
| 
 | ||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|  | @ -884,7 +887,8 @@ void FSP_SRV::OpenSaveDataInfoReaderBySaveDataSpaceId(Kernel::HLERequestContext& | |||
| 
 | ||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushIpcInterface<ISaveDataInfoReader>(std::make_shared<ISaveDataInfoReader>(space, fsc)); | ||||
|     rb.PushIpcInterface<ISaveDataInfoReader>( | ||||
|         std::make_shared<ISaveDataInfoReader>(system, space, fsc)); | ||||
| } | ||||
| 
 | ||||
| void FSP_SRV::WriteSaveDataFileSystemExtraDataBySaveDataAttribute(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -933,7 +937,7 @@ void FSP_SRV::OpenDataStorageByCurrentProcess(Kernel::HLERequestContext& ctx) { | |||
|         return; | ||||
|     } | ||||
| 
 | ||||
|     auto storage = std::make_shared<IStorage>(std::move(romfs.Unwrap())); | ||||
|     auto storage = std::make_shared<IStorage>(system, std::move(romfs.Unwrap())); | ||||
| 
 | ||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|  | @ -957,7 +961,7 @@ void FSP_SRV::OpenDataStorageByDataId(Kernel::HLERequestContext& ctx) { | |||
|         if (archive != nullptr) { | ||||
|             IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|             rb.Push(RESULT_SUCCESS); | ||||
|             rb.PushIpcInterface(std::make_shared<IStorage>(archive)); | ||||
|             rb.PushIpcInterface(std::make_shared<IStorage>(system, archive)); | ||||
|             return; | ||||
|         } | ||||
| 
 | ||||
|  | @ -973,7 +977,7 @@ void FSP_SRV::OpenDataStorageByDataId(Kernel::HLERequestContext& ctx) { | |||
|     const FileSys::PatchManager pm{title_id, fsc, content_provider}; | ||||
| 
 | ||||
|     auto storage = std::make_shared<IStorage>( | ||||
|         pm.PatchRomFS(std::move(data.Unwrap()), 0, FileSys::ContentRecordType::Data)); | ||||
|         system, pm.PatchRomFS(std::move(data.Unwrap()), 0, FileSys::ContentRecordType::Data)); | ||||
| 
 | ||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|  | @ -1035,7 +1039,8 @@ void FSP_SRV::GetAccessLogVersionInfo(Kernel::HLERequestContext& ctx) { | |||
| 
 | ||||
| class IMultiCommitManager final : public ServiceFramework<IMultiCommitManager> { | ||||
| public: | ||||
|     explicit IMultiCommitManager() : ServiceFramework("IMultiCommitManager") { | ||||
|     explicit IMultiCommitManager(Core::System& system_) | ||||
|         : ServiceFramework{system_, "IMultiCommitManager"} { | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {1, &IMultiCommitManager::Add, "Add"}, | ||||
|             {2, &IMultiCommitManager::Commit, "Commit"}, | ||||
|  | @ -1066,7 +1071,7 @@ void FSP_SRV::OpenMultiCommitManager(Kernel::HLERequestContext& ctx) { | |||
| 
 | ||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushIpcInterface<IMultiCommitManager>(std::make_shared<IMultiCommitManager>()); | ||||
|     rb.PushIpcInterface<IMultiCommitManager>(std::make_shared<IMultiCommitManager>(system)); | ||||
| } | ||||
| 
 | ||||
| } // namespace Service::FileSystem
 | ||||
|  |  | |||
|  | @ -33,8 +33,7 @@ enum class LogMode : u32 { | |||
| 
 | ||||
| class FSP_SRV final : public ServiceFramework<FSP_SRV> { | ||||
| public: | ||||
|     explicit FSP_SRV(FileSystemController& fsc_, const FileSys::ContentProvider& content_provider_, | ||||
|                      const Core::Reporter& reporter_); | ||||
|     explicit FSP_SRV(Core::System& system_); | ||||
|     ~FSP_SRV() override; | ||||
| 
 | ||||
| private: | ||||
|  |  | |||
|  | @ -17,7 +17,7 @@ namespace Service::Friend { | |||
| 
 | ||||
| class IFriendService final : public ServiceFramework<IFriendService> { | ||||
| public: | ||||
|     IFriendService() : ServiceFramework("IFriendService") { | ||||
|     explicit IFriendService(Core::System& system_) : ServiceFramework{system_, "IFriendService"} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, nullptr, "GetCompletionEvent"}, | ||||
|  | @ -171,8 +171,8 @@ private: | |||
| 
 | ||||
| class INotificationService final : public ServiceFramework<INotificationService> { | ||||
| public: | ||||
|     INotificationService(Common::UUID uuid, Core::System& system) | ||||
|         : ServiceFramework("INotificationService"), uuid(uuid) { | ||||
|     explicit INotificationService(Common::UUID uuid_, Core::System& system_) | ||||
|         : ServiceFramework{system_, "INotificationService"}, uuid{uuid_} { | ||||
|         // clang-format off
 | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &INotificationService::GetEvent, "GetEvent"}, | ||||
|  | @ -267,7 +267,7 @@ private: | |||
| void Module::Interface::CreateFriendService(Kernel::HLERequestContext& ctx) { | ||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushIpcInterface<IFriendService>(); | ||||
|     rb.PushIpcInterface<IFriendService>(system); | ||||
|     LOG_DEBUG(Service_ACC, "called"); | ||||
| } | ||||
| 
 | ||||
|  | @ -282,8 +282,9 @@ void Module::Interface::CreateNotificationService(Kernel::HLERequestContext& ctx | |||
|     rb.PushIpcInterface<INotificationService>(uuid, system); | ||||
| } | ||||
| 
 | ||||
| Module::Interface::Interface(std::shared_ptr<Module> module, Core::System& system, const char* name) | ||||
|     : ServiceFramework(name), module(std::move(module)), system(system) {} | ||||
| Module::Interface::Interface(std::shared_ptr<Module> module_, Core::System& system_, | ||||
|                              const char* name) | ||||
|     : ServiceFramework{system_, name}, module{std::move(module_)} {} | ||||
| 
 | ||||
| Module::Interface::~Interface() = default; | ||||
| 
 | ||||
|  |  | |||
|  | @ -16,7 +16,8 @@ class Module final { | |||
| public: | ||||
|     class Interface : public ServiceFramework<Interface> { | ||||
|     public: | ||||
|         explicit Interface(std::shared_ptr<Module> module, Core::System& system, const char* name); | ||||
|         explicit Interface(std::shared_ptr<Module> module_, Core::System& system_, | ||||
|                            const char* name); | ||||
|         ~Interface() override; | ||||
| 
 | ||||
|         void CreateFriendService(Kernel::HLERequestContext& ctx); | ||||
|  | @ -24,7 +25,6 @@ public: | |||
| 
 | ||||
|     protected: | ||||
|         std::shared_ptr<Module> module; | ||||
|         Core::System& system; | ||||
|     }; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
Some files were not shown because too many files have changed in this diff Show more
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lioncash
						Lioncash