diff options
author | bunnei <bunneidev@gmail.com> | 2021-05-16 16:33:33 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-05-16 16:33:33 -0700 |
commit | 440eb840ea18352488bd89e08e88d7ee34aab717 (patch) | |
tree | 60f78ad8af51d95b914fc4a288a7c888c71c1af7 /src/core | |
parent | bfe8816f7c2bb4338efff9763a6f7abb1b66977a (diff) | |
parent | a170aa16b6d609b5e92b41a64711a2899e457135 (diff) |
Merge pull request #6319 from Morph1984/no-install-base
main: Prevent installing base titles into NAND
Diffstat (limited to 'src/core')
-rw-r--r-- | src/core/file_sys/registered_cache.cpp | 7 | ||||
-rw-r--r-- | src/core/file_sys/registered_cache.h | 1 |
2 files changed, 8 insertions, 0 deletions
diff --git a/src/core/file_sys/registered_cache.cpp b/src/core/file_sys/registered_cache.cpp index 1fb66874e..b0cb65952 100644 --- a/src/core/file_sys/registered_cache.cpp +++ b/src/core/file_sys/registered_cache.cpp @@ -12,6 +12,7 @@ #include "common/logging/log.h" #include "core/crypto/key_manager.h" #include "core/file_sys/card_image.h" +#include "core/file_sys/common_funcs.h" #include "core/file_sys/content_archive.h" #include "core/file_sys/nca_metadata.h" #include "core/file_sys/registered_cache.h" @@ -592,6 +593,12 @@ InstallResult RegisteredCache::InstallEntry(const NSP& nsp, bool overwrite_if_ex const CNMT cnmt(cnmt_file); const auto title_id = cnmt.GetTitleID(); + const auto version = cnmt.GetTitleVersion(); + + if (title_id == GetBaseTitleID(title_id) && version == 0) { + return InstallResult::ErrorBaseInstall; + } + const auto result = RemoveExistingEntry(title_id); // Install Metadata File diff --git a/src/core/file_sys/registered_cache.h b/src/core/file_sys/registered_cache.h index b31630014..d042aef90 100644 --- a/src/core/file_sys/registered_cache.h +++ b/src/core/file_sys/registered_cache.h @@ -38,6 +38,7 @@ enum class InstallResult { ErrorAlreadyExists, ErrorCopyFailed, ErrorMetaFailed, + ErrorBaseInstall, }; struct ContentProviderEntry { |