diff options
author | bunnei <bunneidev@gmail.com> | 2015-10-20 10:17:31 -0400 |
---|---|---|
committer | bunnei <bunneidev@gmail.com> | 2015-10-20 10:17:31 -0400 |
commit | c717d1551da213c9ad2a80dcf198ebe5a1345627 (patch) | |
tree | f89e6c7f0b19a370a69710c0e3327fb337f643cc /src/core/loader/ncch.cpp | |
parent | 04325e5980a649bea58aad349fc04eaf403aba3a (diff) | |
parent | 721475420dd2863c2cb9142f1fc3f89e2a9d46d5 (diff) |
Merge pull request #1199 from Gareth422/encryption-check
Loader: Implement NCCH encryption check
Diffstat (limited to 'src/core/loader/ncch.cpp')
-rw-r--r-- | src/core/loader/ncch.cpp | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/src/core/loader/ncch.cpp b/src/core/loader/ncch.cpp index 094d74100..68b3f546e 100644 --- a/src/core/loader/ncch.cpp +++ b/src/core/loader/ncch.cpp @@ -128,9 +128,8 @@ ResultStatus AppLoader_NCCH::LoadExec() { if (ResultStatus::Success == ReadCode(code)) { std::string process_name = Common::StringFromFixedZeroTerminatedBuffer( (const char*)exheader_header.codeset_info.name, 8); - u64 program_id = *reinterpret_cast<u64_le const*>(&ncch_header.program_id[0]); - SharedPtr<CodeSet> codeset = CodeSet::Create(process_name, program_id); + SharedPtr<CodeSet> codeset = CodeSet::Create(process_name, ncch_header.program_id); codeset->code.offset = 0; codeset->code.addr = exheader_header.codeset_info.text.address; @@ -266,6 +265,11 @@ ResultStatus AppLoader_NCCH::Load() { LOG_DEBUG(Loader, "Thread priority: 0x%X" , priority); LOG_DEBUG(Loader, "Resource limit category: %d" , resource_limit_category); + if (exheader_header.arm11_system_local_caps.program_id != ncch_header.program_id) { + LOG_ERROR(Loader, "ExHeader Program ID mismatch: the ROM is probably encrypted."); + return ResultStatus::ErrorEncrypted; + } + // Read ExeFS... exefs_offset = ncch_header.exefs_offset * kBlockSize; |