Skip to content
Snippets Groups Projects
Commit 1c75945d authored by Zach Hilman's avatar Zach Hilman
Browse files

nsp: Use title ID from NPDM metadata for extracted type NSPs

Avoids 0 being used as title ID for all extracted NSPs.
parent 364932df
No related branches found
No related tags found
No related merge requests found
...@@ -85,12 +85,29 @@ Loader::ResultStatus NSP::GetProgramStatus(u64 title_id) const { ...@@ -85,12 +85,29 @@ Loader::ResultStatus NSP::GetProgramStatus(u64 title_id) const {
} }
u64 NSP::GetFirstTitleID() const { u64 NSP::GetFirstTitleID() const {
if (IsExtractedType()) {
return GetProgramTitleID();
}
if (program_status.empty()) if (program_status.empty())
return 0; return 0;
return program_status.begin()->first; return program_status.begin()->first;
} }
u64 NSP::GetProgramTitleID() const { u64 NSP::GetProgramTitleID() const {
if (IsExtractedType()) {
if (GetExeFS() == nullptr || !IsDirectoryExeFS(GetExeFS())) {
return 0;
}
ProgramMetadata meta;
if (meta.Load(GetExeFS()->GetFile("main.npdm")) == Loader::ResultStatus::Success) {
return meta.GetTitleID();
} else {
return 0;
}
}
const auto out = GetFirstTitleID(); const auto out = GetFirstTitleID();
if ((out & 0x800) == 0) if ((out & 0x800) == 0)
return out; return out;
...@@ -102,6 +119,10 @@ u64 NSP::GetProgramTitleID() const { ...@@ -102,6 +119,10 @@ u64 NSP::GetProgramTitleID() const {
} }
std::vector<u64> NSP::GetTitleIDs() const { std::vector<u64> NSP::GetTitleIDs() const {
if (IsExtractedType()) {
return {GetProgramTitleID()};
}
std::vector<u64> out; std::vector<u64> out;
out.reserve(ncas.size()); out.reserve(ncas.size());
for (const auto& kv : ncas) for (const auto& kv : ncas)
......
...@@ -77,7 +77,7 @@ AppLoader_NSP::LoadResult AppLoader_NSP::Load(Kernel::Process& process) { ...@@ -77,7 +77,7 @@ AppLoader_NSP::LoadResult AppLoader_NSP::Load(Kernel::Process& process) {
return {ResultStatus::ErrorAlreadyLoaded, {}}; return {ResultStatus::ErrorAlreadyLoaded, {}};
} }
if (title_id == 0) { if (!nsp->IsExtractedType() && title_id == 0) {
return {ResultStatus::ErrorNSPMissingProgramNCA, {}}; return {ResultStatus::ErrorNSPMissingProgramNCA, {}};
} }
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment