mirror of
https://github.com/Atmosphere-NX/Atmosphere
synced 2025-01-03 11:11:14 +00:00
fs: fix RomFs GetEntryType (fixes mariko daybreak)
This commit is contained in:
parent
24eef96b15
commit
7f1a7cfd2d
4 changed files with 20 additions and 22 deletions
|
@ -584,8 +584,8 @@ namespace ams::fssystem {
|
||||||
AMS_ASSERT(out_entry != nullptr);
|
AMS_ASSERT(out_entry != nullptr);
|
||||||
|
|
||||||
const Result dir_res = this->dir_table.Get(out_pos, out_entry, key);
|
const Result dir_res = this->dir_table.Get(out_pos, out_entry, key);
|
||||||
R_UNLESS(R_FAILED(dir_res), dir_res);
|
R_UNLESS(R_FAILED(dir_res), dir_res);
|
||||||
R_UNLESS(!fs::ResultDbmKeyNotFound::Includes(dir_res), dir_res);
|
R_UNLESS(fs::ResultDbmKeyNotFound::Includes(dir_res), dir_res);
|
||||||
|
|
||||||
Position pos = 0;
|
Position pos = 0;
|
||||||
RomFileEntry entry = {};
|
RomFileEntry entry = {};
|
||||||
|
@ -601,8 +601,8 @@ namespace ams::fssystem {
|
||||||
|
|
||||||
RomEntryKey key = {};
|
RomEntryKey key = {};
|
||||||
const Result dir_res = this->dir_table.GetByPosition(std::addressof(key), out_entry, nullptr, nullptr, pos);
|
const Result dir_res = this->dir_table.GetByPosition(std::addressof(key), out_entry, nullptr, nullptr, pos);
|
||||||
R_UNLESS(R_FAILED(dir_res), dir_res);
|
R_UNLESS(R_FAILED(dir_res), dir_res);
|
||||||
R_UNLESS(!fs::ResultDbmKeyNotFound::Includes(dir_res), dir_res);
|
R_UNLESS(fs::ResultDbmKeyNotFound::Includes(dir_res), dir_res);
|
||||||
|
|
||||||
RomFileEntry entry = {};
|
RomFileEntry entry = {};
|
||||||
const Result file_res = this->file_table.GetByPosition(std::addressof(key), std::addressof(entry), nullptr, nullptr, pos);
|
const Result file_res = this->file_table.GetByPosition(std::addressof(key), std::addressof(entry), nullptr, nullptr, pos);
|
||||||
|
@ -616,8 +616,8 @@ namespace ams::fssystem {
|
||||||
AMS_ASSERT(out_entry != nullptr);
|
AMS_ASSERT(out_entry != nullptr);
|
||||||
|
|
||||||
const Result file_res = this->file_table.Get(out_pos, out_entry, key);
|
const Result file_res = this->file_table.Get(out_pos, out_entry, key);
|
||||||
R_UNLESS(R_FAILED(file_res), file_res);
|
R_UNLESS(R_FAILED(file_res), file_res);
|
||||||
R_UNLESS(!fs::ResultDbmKeyNotFound::Includes(file_res), file_res);
|
R_UNLESS(fs::ResultDbmKeyNotFound::Includes(file_res), file_res);
|
||||||
|
|
||||||
Position pos = 0;
|
Position pos = 0;
|
||||||
RomDirectoryEntry entry = {};
|
RomDirectoryEntry entry = {};
|
||||||
|
@ -633,8 +633,8 @@ namespace ams::fssystem {
|
||||||
|
|
||||||
RomEntryKey key = {};
|
RomEntryKey key = {};
|
||||||
const Result file_res = this->file_table.GetByPosition(std::addressof(key), out_entry, nullptr, nullptr, pos);
|
const Result file_res = this->file_table.GetByPosition(std::addressof(key), out_entry, nullptr, nullptr, pos);
|
||||||
R_UNLESS(R_FAILED(file_res), file_res);
|
R_UNLESS(R_FAILED(file_res), file_res);
|
||||||
R_UNLESS(!fs::ResultDbmKeyNotFound::Includes(file_res), file_res);
|
R_UNLESS(fs::ResultDbmKeyNotFound::Includes(file_res), file_res);
|
||||||
|
|
||||||
RomDirectoryEntry entry = {};
|
RomDirectoryEntry entry = {};
|
||||||
const Result dir_res = this->dir_table.GetByPosition(std::addressof(key), std::addressof(entry), nullptr, nullptr, pos);
|
const Result dir_res = this->dir_table.GetByPosition(std::addressof(key), std::addressof(entry), nullptr, nullptr, pos);
|
||||||
|
|
|
@ -479,8 +479,8 @@ namespace ams::fs {
|
||||||
AMS_ASSERT(out_entry != nullptr);
|
AMS_ASSERT(out_entry != nullptr);
|
||||||
|
|
||||||
const Result dir_res = this->dir_table.Get(out_pos, out_entry, key);
|
const Result dir_res = this->dir_table.Get(out_pos, out_entry, key);
|
||||||
R_UNLESS(R_FAILED(dir_res), dir_res);
|
R_UNLESS(R_FAILED(dir_res), dir_res);
|
||||||
R_UNLESS(!fs::ResultDbmKeyNotFound::Includes(dir_res), dir_res);
|
R_UNLESS(fs::ResultDbmKeyNotFound::Includes(dir_res), dir_res);
|
||||||
|
|
||||||
Position pos = 0;
|
Position pos = 0;
|
||||||
RomFileEntry entry = {};
|
RomFileEntry entry = {};
|
||||||
|
@ -496,8 +496,8 @@ namespace ams::fs {
|
||||||
|
|
||||||
RomEntryKey key = {};
|
RomEntryKey key = {};
|
||||||
const Result dir_res = this->dir_table.GetByPosition(std::addressof(key), out_entry, pos);
|
const Result dir_res = this->dir_table.GetByPosition(std::addressof(key), out_entry, pos);
|
||||||
R_UNLESS(R_FAILED(dir_res), dir_res);
|
R_UNLESS(R_FAILED(dir_res), dir_res);
|
||||||
R_UNLESS(!fs::ResultDbmKeyNotFound::Includes(dir_res), dir_res);
|
R_UNLESS(fs::ResultDbmKeyNotFound::Includes(dir_res), dir_res);
|
||||||
|
|
||||||
RomFileEntry entry = {};
|
RomFileEntry entry = {};
|
||||||
const Result file_res = this->file_table.GetByPosition(std::addressof(key), std::addressof(entry), pos);
|
const Result file_res = this->file_table.GetByPosition(std::addressof(key), std::addressof(entry), pos);
|
||||||
|
@ -511,8 +511,8 @@ namespace ams::fs {
|
||||||
AMS_ASSERT(out_entry != nullptr);
|
AMS_ASSERT(out_entry != nullptr);
|
||||||
|
|
||||||
const Result file_res = this->file_table.Get(out_pos, out_entry, key);
|
const Result file_res = this->file_table.Get(out_pos, out_entry, key);
|
||||||
R_UNLESS(R_FAILED(file_res), file_res);
|
R_UNLESS(R_FAILED(file_res), file_res);
|
||||||
R_UNLESS(!fs::ResultDbmKeyNotFound::Includes(file_res), file_res);
|
R_UNLESS(fs::ResultDbmKeyNotFound::Includes(file_res), file_res);
|
||||||
|
|
||||||
Position pos = 0;
|
Position pos = 0;
|
||||||
RomDirectoryEntry entry = {};
|
RomDirectoryEntry entry = {};
|
||||||
|
@ -528,8 +528,8 @@ namespace ams::fs {
|
||||||
|
|
||||||
RomEntryKey key = {};
|
RomEntryKey key = {};
|
||||||
const Result file_res = this->file_table.GetByPosition(std::addressof(key), out_entry, pos);
|
const Result file_res = this->file_table.GetByPosition(std::addressof(key), out_entry, pos);
|
||||||
R_UNLESS(R_FAILED(file_res), file_res);
|
R_UNLESS(R_FAILED(file_res), file_res);
|
||||||
R_UNLESS(!fs::ResultDbmKeyNotFound::Includes(file_res), file_res);
|
R_UNLESS(fs::ResultDbmKeyNotFound::Includes(file_res), file_res);
|
||||||
|
|
||||||
RomDirectoryEntry entry = {};
|
RomDirectoryEntry entry = {};
|
||||||
const Result dir_res = this->dir_table.GetByPosition(std::addressof(key), std::addressof(entry), pos);
|
const Result dir_res = this->dir_table.GetByPosition(std::addressof(key), std::addressof(entry), pos);
|
||||||
|
|
|
@ -463,6 +463,8 @@ namespace ams::updater {
|
||||||
return BootImageUpdateType::Erista;
|
return BootImageUpdateType::Erista;
|
||||||
case spl::HardwareType::Hoag:
|
case spl::HardwareType::Hoag:
|
||||||
case spl::HardwareType::Iowa:
|
case spl::HardwareType::Iowa:
|
||||||
|
case spl::HardwareType::Calcio:
|
||||||
|
case spl::HardwareType::_Five_:
|
||||||
return BootImageUpdateType::Mariko;
|
return BootImageUpdateType::Mariko;
|
||||||
AMS_UNREACHABLE_DEFAULT_CASE();
|
AMS_UNREACHABLE_DEFAULT_CASE();
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,12 +23,8 @@ namespace ams::mitm::sysupdater {
|
||||||
alignas(os::MemoryPageSize) u8 g_boot_image_update_buffer[64_KB];
|
alignas(os::MemoryPageSize) u8 g_boot_image_update_buffer[64_KB];
|
||||||
|
|
||||||
updater::BootImageUpdateType GetBootImageUpdateType() {
|
updater::BootImageUpdateType GetBootImageUpdateType() {
|
||||||
int boot_image_update_type;
|
/* NOTE: Here Nintendo uses the value of system setting systeminitializer!boot_image_update_type...but we prefer not to take the risk. */
|
||||||
auto size = settings::fwdbg::GetSettingsItemValue(std::addressof(boot_image_update_type), sizeof(boot_image_update_type), "systeminitializer", "boot_image_update_type");
|
return updater::GetBootImageUpdateType(spl::GetHardwareType());
|
||||||
if (size != sizeof(boot_image_update_type)) {
|
|
||||||
return updater::BootImageUpdateType::Erista;
|
|
||||||
}
|
|
||||||
return updater::GetBootImageUpdateType(boot_image_update_type);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result MarkPreCommitForBootImages() {
|
Result MarkPreCommitForBootImages() {
|
||||||
|
|
Loading…
Reference in a new issue