diff --git a/src/core/hle/service/ns/ns.cpp b/src/core/hle/service/ns/ns.cpp index 9e19c38bf..9616cc8f6 100644 --- a/src/core/hle/service/ns/ns.cpp +++ b/src/core/hle/service/ns/ns.cpp @@ -2,12 +2,35 @@ // Licensed under GPLv2 or any later version // Refer to the license.txt file included. +#include +#include "core/hle/service/am/am.h" #include "core/hle/service/ns/ns.h" #include "core/hle/service/ns/ns_s.h" +#include "core/loader/loader.h" namespace Service { namespace NS { +Kernel::SharedPtr LaunchTitle(FS::MediaType media_type, u64 title_id) { + std::string path = AM::GetTitleContentPath(media_type, title_id); + auto loader = Loader::GetLoader(path); + + if (!loader) { + LOG_WARNING(Service_NS, "Could not find .app for title 0x%016" PRIx64, title_id); + return nullptr; + } + + Kernel::SharedPtr process; + Loader::ResultStatus result = loader->Load(process); + + if (result != Loader::ResultStatus::Success) { + LOG_WARNING(Service_NS, "Error loading .app for title 0x%016" PRIx64, title_id); + return nullptr; + } + + return process; +} + void InstallInterfaces(SM::ServiceManager& service_manager) { std::make_shared()->InstallAsService(service_manager); } diff --git a/src/core/hle/service/ns/ns.h b/src/core/hle/service/ns/ns.h index c3d67d98c..6fb171c1a 100644 --- a/src/core/hle/service/ns/ns.h +++ b/src/core/hle/service/ns/ns.h @@ -4,11 +4,15 @@ #pragma once +#include "core/hle/kernel/process.h" #include "core/hle/service/service.h" namespace Service { namespace NS { +/// Loads and launches the title identified by title_id in the specified media type. +Kernel::SharedPtr LaunchTitle(FS::MediaType media_type, u64 title_id); + /// Registers all NS services with the specified service manager. void InstallInterfaces(SM::ServiceManager& service_manager);