summaryrefslogtreecommitdiff
path: root/src/core/loader/nsp.cpp
diff options
context:
space:
mode:
authorGravatar bunnei2018-10-06 23:58:24 -0400
committerGravatar GitHub2018-10-06 23:58:24 -0400
commit6e4d2e672d1083f29186ea0ddcb33cd634e360e3 (patch)
treecbd20aab8705f8efac340c509ca71b08865a1417 /src/core/loader/nsp.cpp
parentMerge pull request #1446 from bunnei/fast_fermi_copy (diff)
parentromfs_factory: Extract packed update setter to new function (diff)
downloadyuzu-6e4d2e672d1083f29186ea0ddcb33cd634e360e3.tar.gz
yuzu-6e4d2e672d1083f29186ea0ddcb33cd634e360e3.tar.xz
yuzu-6e4d2e672d1083f29186ea0ddcb33cd634e360e3.zip
Merge pull request #1396 from DarkLordZach/packed-updates
loader: Add support for packed updates
Diffstat (limited to 'src/core/loader/nsp.cpp')
-rw-r--r--src/core/loader/nsp.cpp32
1 files changed, 30 insertions, 2 deletions
diff --git a/src/core/loader/nsp.cpp b/src/core/loader/nsp.cpp
index b7ba77ef4..5534ce01c 100644
--- a/src/core/loader/nsp.cpp
+++ b/src/core/loader/nsp.cpp
@@ -10,8 +10,10 @@
10#include "core/file_sys/control_metadata.h" 10#include "core/file_sys/control_metadata.h"
11#include "core/file_sys/nca_metadata.h" 11#include "core/file_sys/nca_metadata.h"
12#include "core/file_sys/patch_manager.h" 12#include "core/file_sys/patch_manager.h"
13#include "core/file_sys/registered_cache.h"
13#include "core/file_sys/submission_package.h" 14#include "core/file_sys/submission_package.h"
14#include "core/hle/kernel/process.h" 15#include "core/hle/kernel/process.h"
16#include "core/hle/service/filesystem/filesystem.h"
15#include "core/loader/deconstructed_rom_directory.h" 17#include "core/loader/deconstructed_rom_directory.h"
16#include "core/loader/nca.h" 18#include "core/loader/nca.h"
17#include "core/loader/nsp.h" 19#include "core/loader/nsp.h"
@@ -91,13 +93,39 @@ ResultStatus AppLoader_NSP::Load(Kernel::Process& process) {
91 if (result != ResultStatus::Success) 93 if (result != ResultStatus::Success)
92 return result; 94 return result;
93 95
96 FileSys::VirtualFile update_raw;
97 if (ReadUpdateRaw(update_raw) == ResultStatus::Success && update_raw != nullptr)
98 Service::FileSystem::SetPackedUpdate(std::move(update_raw));
99
94 is_loaded = true; 100 is_loaded = true;
95 101
96 return ResultStatus::Success; 102 return ResultStatus::Success;
97} 103}
98 104
99ResultStatus AppLoader_NSP::ReadRomFS(FileSys::VirtualFile& dir) { 105ResultStatus AppLoader_NSP::ReadRomFS(FileSys::VirtualFile& file) {
100 return secondary_loader->ReadRomFS(dir); 106 return secondary_loader->ReadRomFS(file);
107}
108
109u64 AppLoader_NSP::ReadRomFSIVFCOffset() const {
110 return secondary_loader->ReadRomFSIVFCOffset();
111}
112
113ResultStatus AppLoader_NSP::ReadUpdateRaw(FileSys::VirtualFile& file) {
114 if (nsp->IsExtractedType())
115 return ResultStatus::ErrorNoPackedUpdate;
116
117 const auto read =
118 nsp->GetNCAFile(FileSys::GetUpdateTitleID(title_id), FileSys::ContentRecordType::Program);
119
120 if (read == nullptr)
121 return ResultStatus::ErrorNoPackedUpdate;
122 const auto nca_test = std::make_shared<FileSys::NCA>(read);
123
124 if (nca_test->GetStatus() != ResultStatus::ErrorMissingBKTRBaseRomFS)
125 return nca_test->GetStatus();
126
127 file = read;
128 return ResultStatus::Success;
101} 129}
102 130
103ResultStatus AppLoader_NSP::ReadProgramId(u64& out_program_id) { 131ResultStatus AppLoader_NSP::ReadProgramId(u64& out_program_id) {