DirectoryBlob: Move content emplacement out of the constructor

This commit is contained in:
JosJuice 2017-06-10 10:37:06 +02:00
parent 1258d18f21
commit 5a00bda490
1 changed files with 13 additions and 9 deletions

View File

@ -171,27 +171,20 @@ DirectoryBlobReader::DirectoryBlobReader(const std::string& root_directory)
{ {
SetDiscHeaderAndDiscType(); SetDiscHeaderAndDiscType();
AddFileToContents(&m_virtual_disc, m_root_directory + "sys/bi2.bin", BI2_ADDRESS, BI2_SIZE);
// Setting the DOL relies on m_dol_address, which is set by SetApploader // Setting the DOL relies on m_dol_address, which is set by SetApploader
if (SetApploader(m_root_directory + "sys/apploader.img")) if (SetApploader(m_root_directory + "sys/apploader.img"))
SetDOL(); SetDOL();
BuildFST(); BuildFST();
m_virtual_disc.emplace(DISKHEADER_ADDRESS, DISKHEADER_SIZE, m_disk_header.data());
AddFileToContents(&m_virtual_disc, m_root_directory + "sys/bi2.bin", BI2_ADDRESS, BI2_SIZE);
m_virtual_disc.emplace(APPLOADER_ADDRESS, m_apploader.size(), m_apploader.data());
m_virtual_disc.emplace(m_fst_address, m_fst_data.size(), m_fst_data.data());
if (m_is_wii) if (m_is_wii)
{ {
m_nonpartition_contents.emplace(DISKHEADER_ADDRESS, NONPARTITION_DISKHEADER_SIZE,
m_disk_header_nonpartition.data());
m_nonpartition_contents.emplace(PARTITION_TABLE_ADDRESS, PARTITION_TABLE.size() * sizeof(u32), m_nonpartition_contents.emplace(PARTITION_TABLE_ADDRESS, PARTITION_TABLE.size() * sizeof(u32),
reinterpret_cast<const u8*>(PARTITION_TABLE.data())); reinterpret_cast<const u8*>(PARTITION_TABLE.data()));
SetWiiRegionData(); SetWiiRegionData();
m_nonpartition_contents.emplace(WII_REGION_DATA_ADDRESS, WII_REGION_DATA_SIZE,
m_wii_region_data.data());
constexpr u32 TICKET_OFFSET = 0x0; constexpr u32 TICKET_OFFSET = 0x0;
constexpr u32 TICKET_SIZE = 0x2a4; constexpr u32 TICKET_SIZE = 0x2a4;
@ -284,6 +277,8 @@ void DirectoryBlobReader::SetDiscHeaderAndDiscType()
if (ReadFileToVector(boot_bin_path, &m_disk_header) < 0x20) if (ReadFileToVector(boot_bin_path, &m_disk_header) < 0x20)
ERROR_LOG(DISCIO, "%s doesn't exist or is too small", boot_bin_path.c_str()); ERROR_LOG(DISCIO, "%s doesn't exist or is too small", boot_bin_path.c_str());
m_virtual_disc.emplace(DISKHEADER_ADDRESS, DISKHEADER_SIZE, m_disk_header.data());
m_is_wii = Common::swap32(&m_disk_header[0x18]) == 0x5d1c9ea3; m_is_wii = Common::swap32(&m_disk_header[0x18]) == 0x5d1c9ea3;
const bool is_gc = Common::swap32(&m_disk_header[0x1c]) == 0xc2339f3d; const bool is_gc = Common::swap32(&m_disk_header[0x1c]) == 0xc2339f3d;
if (m_is_wii == is_gc) if (m_is_wii == is_gc)
@ -307,6 +302,9 @@ void DirectoryBlobReader::SetDiscHeaderAndDiscType()
m_disk_header_nonpartition[0x60] = 0; m_disk_header_nonpartition[0x60] = 0;
if (header_bin_bytes_read < 0x61) if (header_bin_bytes_read < 0x61)
m_disk_header_nonpartition[0x61] = 0; m_disk_header_nonpartition[0x61] = 0;
m_nonpartition_contents.emplace(DISKHEADER_ADDRESS, NONPARTITION_DISKHEADER_SIZE,
m_disk_header_nonpartition.data());
} }
} }
@ -325,6 +323,9 @@ void DirectoryBlobReader::SetWiiRegionData()
ERROR_LOG(DISCIO, "Couldn't read region from %s", region_bin_path.c_str()); ERROR_LOG(DISCIO, "Couldn't read region from %s", region_bin_path.c_str());
else if (bytes_read < 0x20) else if (bytes_read < 0x20)
ERROR_LOG(DISCIO, "Couldn't read age ratings from %s", region_bin_path.c_str()); ERROR_LOG(DISCIO, "Couldn't read age ratings from %s", region_bin_path.c_str());
m_nonpartition_contents.emplace(WII_REGION_DATA_ADDRESS, WII_REGION_DATA_SIZE,
m_wii_region_data.data());
} }
bool DirectoryBlobReader::SetApploader(const std::string& apploader) bool DirectoryBlobReader::SetApploader(const std::string& apploader)
@ -364,6 +365,7 @@ bool DirectoryBlobReader::SetApploader(const std::string& apploader)
} }
} }
m_virtual_disc.emplace(APPLOADER_ADDRESS, m_apploader.size(), m_apploader.data());
return success; return success;
} }
@ -416,6 +418,8 @@ void DirectoryBlobReader::BuildFST()
Write32((u32)(m_fst_address >> m_address_shift), 0x0424, &m_disk_header); Write32((u32)(m_fst_address >> m_address_shift), 0x0424, &m_disk_header);
Write32((u32)(m_fst_data.size() >> m_address_shift), 0x0428, &m_disk_header); Write32((u32)(m_fst_data.size() >> m_address_shift), 0x0428, &m_disk_header);
Write32((u32)(m_fst_data.size() >> m_address_shift), 0x042c, &m_disk_header); Write32((u32)(m_fst_data.size() >> m_address_shift), 0x042c, &m_disk_header);
m_virtual_disc.emplace(m_fst_address, m_fst_data.size(), m_fst_data.data());
} }
void DirectoryBlobReader::PadToAddress(u64 start_address, u64* address, u64* length, void DirectoryBlobReader::PadToAddress(u64 start_address, u64* address, u64* length,