summaryrefslogtreecommitdiff
path: root/src/core/loader
diff options
context:
space:
mode:
authorGravatar TheKoopaKingdom2017-03-08 16:23:28 -0500
committerGravatar TheKoopaKingdom2017-06-02 18:25:32 -0400
commite523c76cc8652dca4862bed2209cbf56ffbc06c2 (patch)
tree313d51420996b7618133915ddb90385636a2f4bf /src/core/loader
parentMerge pull request #2722 from wwylele/cam-ipc-helper (diff)
downloadyuzu-e523c76cc8652dca4862bed2209cbf56ffbc06c2.tar.gz
yuzu-e523c76cc8652dca4862bed2209cbf56ffbc06c2.tar.xz
yuzu-e523c76cc8652dca4862bed2209cbf56ffbc06c2.zip
Fixed encrypted ROM error messages.
Diffstat (limited to 'src/core/loader')
-rw-r--r--src/core/loader/loader.h8
-rw-r--r--src/core/loader/ncch.cpp15
-rw-r--r--src/core/loader/ncch.h5
3 files changed, 19 insertions, 9 deletions
diff --git a/src/core/loader/loader.h b/src/core/loader/loader.h
index 1d80766ae..21f73503e 100644
--- a/src/core/loader/loader.h
+++ b/src/core/loader/loader.h
@@ -100,11 +100,13 @@ public:
100 * Loads the system mode that this application needs. 100 * Loads the system mode that this application needs.
101 * This function defaults to 2 (96MB allocated to the application) if it can't read the 101 * This function defaults to 2 (96MB allocated to the application) if it can't read the
102 * information. 102 * information.
103 * @returns Optional with the kernel system mode 103 * @param boost::optional<u32> Reference to Boost optional to store system mode.
104 * @ return Result of operation.
104 */ 105 */
105 virtual boost::optional<u32> LoadKernelSystemMode() { 106 virtual ResultStatus LoadKernelSystemMode(boost::optional<u32>& system_mode) {
106 // 96MB allocated to the application. 107 // 96MB allocated to the application.
107 return 2; 108 system_mode = 2;
109 return ResultStatus::Success;
108 } 110 }
109 111
110 /** 112 /**
diff --git a/src/core/loader/ncch.cpp b/src/core/loader/ncch.cpp
index beeb13ffa..1a20762e4 100644
--- a/src/core/loader/ncch.cpp
+++ b/src/core/loader/ncch.cpp
@@ -121,12 +121,19 @@ FileType AppLoader_NCCH::IdentifyType(FileUtil::IOFile& file) {
121 return FileType::Error; 121 return FileType::Error;
122} 122}
123 123
124boost::optional<u32> AppLoader_NCCH::LoadKernelSystemMode() { 124ResultStatus AppLoader_NCCH::LoadKernelSystemMode(boost::optional<u32>& system_mode) {
125 if (!is_loaded) { 125 if (!is_loaded) {
126 if (LoadExeFS() != ResultStatus::Success) 126 ResultStatus res = LoadExeFS();
127 return boost::none; 127 if (res != ResultStatus::Success) {
128 // Set the system mode as invalid.
129 system_mode = boost::none;
130 // Return the error code.
131 return res;
132 }
128 } 133 }
129 return exheader_header.arm11_system_local_caps.system_mode.Value(); 134 // Set the system mode as the one from the exheader.
135 system_mode = exheader_header.arm11_system_local_caps.system_mode.Value();
136 return ResultStatus::Success;
130} 137}
131 138
132ResultStatus AppLoader_NCCH::LoadExec() { 139ResultStatus AppLoader_NCCH::LoadExec() {
diff --git a/src/core/loader/ncch.h b/src/core/loader/ncch.h
index 4ef95b5c6..269fe4f49 100644
--- a/src/core/loader/ncch.h
+++ b/src/core/loader/ncch.h
@@ -179,9 +179,10 @@ public:
179 179
180 /** 180 /**
181 * Loads the Exheader and returns the system mode for this application. 181 * Loads the Exheader and returns the system mode for this application.
182 * @return Optional with the kernel system mode 182 * @param boost::optional<u32> Reference to Boost optional to store system mode.
183 * @return Result of operation.
183 */ 184 */
184 boost::optional<u32> LoadKernelSystemMode() override; 185 ResultStatus LoadKernelSystemMode(boost::optional<u32>& system_mode) override;
185 186
186 ResultStatus ReadCode(std::vector<u8>& buffer) override; 187 ResultStatus ReadCode(std::vector<u8>& buffer) override;
187 188