diff options
| author | 2017-05-23 19:46:30 -0400 | |
|---|---|---|
| committer | 2017-06-02 18:40:27 -0400 | |
| commit | cea19fd659496bcdf09a12b163ce490c1fa71ff7 (patch) | |
| tree | 30854e1975cfff0b6b0b1c37461d984956330d67 /src/core/file_sys | |
| parent | Created a whitelist of system archives to prevent false positives creating di... (diff) | |
| download | yuzu-cea19fd659496bcdf09a12b163ce490c1fa71ff7.tar.gz yuzu-cea19fd659496bcdf09a12b163ce490c1fa71ff7.tar.xz yuzu-cea19fd659496bcdf09a12b163ce490c1fa71ff7.zip | |
Moved whitelist checks from FS_User to the Archive_NCCH handler.
Diffstat (limited to 'src/core/file_sys')
| -rw-r--r-- | src/core/file_sys/archive_ncch.cpp | 36 |
1 files changed, 35 insertions, 1 deletions
diff --git a/src/core/file_sys/archive_ncch.cpp b/src/core/file_sys/archive_ncch.cpp index bf4e0916b..84950f871 100644 --- a/src/core/file_sys/archive_ncch.cpp +++ b/src/core/file_sys/archive_ncch.cpp | |||
| @@ -9,6 +9,7 @@ | |||
| 9 | #include "common/file_util.h" | 9 | #include "common/file_util.h" |
| 10 | #include "common/logging/log.h" | 10 | #include "common/logging/log.h" |
| 11 | #include "common/string_util.h" | 11 | #include "common/string_util.h" |
| 12 | #include "core/core.h" | ||
| 12 | #include "core/file_sys/archive_ncch.h" | 13 | #include "core/file_sys/archive_ncch.h" |
| 13 | #include "core/file_sys/ivfc_archive.h" | 14 | #include "core/file_sys/ivfc_archive.h" |
| 14 | #include "core/hle/service/fs/archive.h" | 15 | #include "core/hle/service/fs/archive.h" |
| @@ -33,10 +34,43 @@ ArchiveFactory_NCCH::ArchiveFactory_NCCH(const std::string& nand_directory) | |||
| 33 | ResultVal<std::unique_ptr<ArchiveBackend>> ArchiveFactory_NCCH::Open(const Path& path) { | 34 | ResultVal<std::unique_ptr<ArchiveBackend>> ArchiveFactory_NCCH::Open(const Path& path) { |
| 34 | auto vec = path.AsBinary(); | 35 | auto vec = path.AsBinary(); |
| 35 | const u32* data = reinterpret_cast<u32*>(vec.data()); | 36 | const u32* data = reinterpret_cast<u32*>(vec.data()); |
| 36 | std::string file_path = GetNCCHPath(mount_point, data[1], data[0]); | 37 | u32 high = data[1]; |
| 38 | u32 low = data[0]; | ||
| 39 | std::string file_path = GetNCCHPath(mount_point, high, low); | ||
| 37 | auto file = std::make_shared<FileUtil::IOFile>(file_path, "rb"); | 40 | auto file = std::make_shared<FileUtil::IOFile>(file_path, "rb"); |
| 38 | 41 | ||
| 39 | if (!file->IsOpen()) { | 42 | if (!file->IsOpen()) { |
| 43 | // High Title ID of the archive: The category (https://3dbrew.org/wiki/Title_list). | ||
| 44 | const u32 shared_data_archive = 0x0004009B; | ||
| 45 | const u32 system_data_archive = 0x000400DB; | ||
| 46 | |||
| 47 | // Low Title IDs. | ||
| 48 | const u32 mii_data = 0x00010202; | ||
| 49 | const u32 region_manifest = 0x00010402; | ||
| 50 | const u32 ng_word_list = 0x00010302; | ||
| 51 | |||
| 52 | LOG_DEBUG(Service_FS, "Full Path: %s. Category: 0x%X. Path: 0x%X.", path.DebugStr().c_str(), | ||
| 53 | high, low); | ||
| 54 | |||
| 55 | if (high == shared_data_archive) { | ||
| 56 | if (low == mii_data) { | ||
| 57 | LOG_ERROR(Service_FS, "Failed to get a handle for shared data archive: Mii data. "); | ||
| 58 | Core::System::GetInstance().SetStatus(Core::System::ResultStatus::ErrorSystemFiles, | ||
| 59 | "Mii data"); | ||
| 60 | } else if (low == region_manifest) { | ||
| 61 | LOG_ERROR(Service_FS, | ||
| 62 | "Failed to get a handle for shared data archive: region manifes"); | ||
| 63 | Core::System::GetInstance().SetStatus(Core::System::ResultStatus::ErrorSystemFiles, | ||
| 64 | "Region manifest"); | ||
| 65 | } | ||
| 66 | } else if (high == system_data_archive) { | ||
| 67 | if (low == ng_word_list) { | ||
| 68 | LOG_ERROR(Service_FS, | ||
| 69 | "Failed to get a handle for system data archive: NG bad word list."); | ||
| 70 | Core::System::GetInstance().SetStatus(Core::System::ResultStatus::ErrorSystemFiles, | ||
| 71 | "NG bad word list"); | ||
| 72 | } | ||
| 73 | } | ||
| 40 | return ResultCode(ErrorDescription::FS_NotFound, ErrorModule::FS, ErrorSummary::NotFound, | 74 | return ResultCode(ErrorDescription::FS_NotFound, ErrorModule::FS, ErrorSummary::NotFound, |
| 41 | ErrorLevel::Status); | 75 | ErrorLevel::Status); |
| 42 | } | 76 | } |