|
|
@ -117,12 +117,12 @@ FileType AppLoader_NCCH::IdentifyType(FileUtil::IOFile& file) {
|
|
|
|
return FileType::Error;
|
|
|
|
return FileType::Error;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ResultStatus AppLoader_NCCH::LoadKernelSystemMode(u32& memory_type) {
|
|
|
|
boost::optional<u32> AppLoader_NCCH::LoadKernelSystemMode() {
|
|
|
|
ResultStatus result = LoadExeFS();
|
|
|
|
if (!is_loaded) {
|
|
|
|
if (result != ResultStatus::Success)
|
|
|
|
if (LoadExeFS() != ResultStatus::Success)
|
|
|
|
return result;
|
|
|
|
return boost::none;
|
|
|
|
memory_type = exheader_header.arm11_system_local_caps.system_mode;
|
|
|
|
}
|
|
|
|
return ResultStatus::Success;
|
|
|
|
return exheader_header.arm11_system_local_caps.system_mode.Value();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ResultStatus AppLoader_NCCH::LoadExec() {
|
|
|
|
ResultStatus AppLoader_NCCH::LoadExec() {
|
|
|
@ -285,7 +285,8 @@ ResultStatus AppLoader_NCCH::LoadExeFS() {
|
|
|
|
LOG_DEBUG(Loader, "Core version: %d", core_version);
|
|
|
|
LOG_DEBUG(Loader, "Core version: %d", core_version);
|
|
|
|
LOG_DEBUG(Loader, "Thread priority: 0x%X", priority);
|
|
|
|
LOG_DEBUG(Loader, "Thread priority: 0x%X", priority);
|
|
|
|
LOG_DEBUG(Loader, "Resource limit category: %d", resource_limit_category);
|
|
|
|
LOG_DEBUG(Loader, "Resource limit category: %d", resource_limit_category);
|
|
|
|
LOG_DEBUG(Loader, "System Mode: %d", exheader_header.arm11_system_local_caps.system_mode);
|
|
|
|
LOG_DEBUG(Loader, "System Mode: %d",
|
|
|
|
|
|
|
|
exheader_header.arm11_system_local_caps.system_mode);
|
|
|
|
|
|
|
|
|
|
|
|
if (exheader_header.arm11_system_local_caps.program_id != ncch_header.program_id) {
|
|
|
|
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.");
|
|
|
|
LOG_ERROR(Loader, "ExHeader Program ID mismatch: the ROM is probably encrypted.");
|
|
|
|