diff options
| author | 2018-08-16 16:57:00 -0400 | |
|---|---|---|
| committer | 2018-08-23 11:52:44 -0400 | |
| commit | a9dc5a3c1058d22873a201c08bd6d095405789ae (patch) | |
| tree | daa6c23dcc4f3b3367eaf254689e427865b9e84e /src/core/loader/xci.cpp | |
| parent | Merge pull request #1157 from lioncash/vec (diff) | |
| download | yuzu-a9dc5a3c1058d22873a201c08bd6d095405789ae.tar.gz yuzu-a9dc5a3c1058d22873a201c08bd6d095405789ae.tar.xz yuzu-a9dc5a3c1058d22873a201c08bd6d095405789ae.zip | |
xci: Fix error masking issue
Prevents NCA-related errors from being masked into MissingProgramNCA or MissingKeyFile
Diffstat (limited to 'src/core/loader/xci.cpp')
| -rw-r--r-- | src/core/loader/xci.cpp | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/src/core/loader/xci.cpp b/src/core/loader/xci.cpp index 4c4979545..9dc4d1f35 100644 --- a/src/core/loader/xci.cpp +++ b/src/core/loader/xci.cpp | |||
| @@ -61,11 +61,12 @@ ResultStatus AppLoader_XCI::Load(Kernel::SharedPtr<Kernel::Process>& process) { | |||
| 61 | if (xci->GetStatus() != ResultStatus::Success) | 61 | if (xci->GetStatus() != ResultStatus::Success) |
| 62 | return xci->GetStatus(); | 62 | return xci->GetStatus(); |
| 63 | 63 | ||
| 64 | if (xci->GetNCAFileByType(FileSys::NCAContentType::Program) == nullptr) { | 64 | if (xci->GetProgramNCAStatus() != ResultStatus::Success) |
| 65 | if (!Core::Crypto::KeyManager::KeyFileExists(false)) | 65 | return xci->GetProgramNCAStatus(); |
| 66 | return ResultStatus::ErrorMissingProductionKeyFile; | 66 | |
| 67 | return ResultStatus::ErrorXCIMissingProgramNCA; | 67 | const auto nca = xci->GetNCAFileByType(FileSys::NCAContentType::Program); |
| 68 | } | 68 | if (nca == nullptr && !Core::Crypto::KeyManager::KeyFileExists(false)) |
| 69 | return ResultStatus::ErrorMissingProductionKeyFile; | ||
| 69 | 70 | ||
| 70 | auto result = nca_loader->Load(process); | 71 | auto result = nca_loader->Load(process); |
| 71 | if (result != ResultStatus::Success) | 72 | if (result != ResultStatus::Success) |