diff options
| author | 2018-10-06 23:58:24 -0400 | |
|---|---|---|
| committer | 2018-10-06 23:58:24 -0400 | |
| commit | 6e4d2e672d1083f29186ea0ddcb33cd634e360e3 (patch) | |
| tree | cbd20aab8705f8efac340c509ca71b08865a1417 /src/core/loader/nsp.cpp | |
| parent | Merge pull request #1446 from bunnei/fast_fermi_copy (diff) | |
| parent | romfs_factory: Extract packed update setter to new function (diff) | |
| download | yuzu-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.cpp | 32 |
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 | ||
| 99 | ResultStatus AppLoader_NSP::ReadRomFS(FileSys::VirtualFile& dir) { | 105 | ResultStatus AppLoader_NSP::ReadRomFS(FileSys::VirtualFile& file) { |
| 100 | return secondary_loader->ReadRomFS(dir); | 106 | return secondary_loader->ReadRomFS(file); |
| 107 | } | ||
| 108 | |||
| 109 | u64 AppLoader_NSP::ReadRomFSIVFCOffset() const { | ||
| 110 | return secondary_loader->ReadRomFSIVFCOffset(); | ||
| 111 | } | ||
| 112 | |||
| 113 | ResultStatus 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 | ||
| 103 | ResultStatus AppLoader_NSP::ReadProgramId(u64& out_program_id) { | 131 | ResultStatus AppLoader_NSP::ReadProgramId(u64& out_program_id) { |