From 675a5496289b5d771b6d5e9b00cc90bafc31632c Mon Sep 17 00:00:00 2001 From: "Admiral H. Curtiss" Date: Sun, 18 Nov 2018 18:19:35 +0100 Subject: [PATCH] GCMemcard: Use BigEndianValue for DEntry.m_first_block. --- Source/Core/Core/HW/GCMemcard/GCMemcard.cpp | 20 +++++++++++-------- Source/Core/Core/HW/GCMemcard/GCMemcard.h | 7 ++++--- .../Core/HW/GCMemcard/GCMemcardDirectory.cpp | 8 ++++---- 3 files changed, 20 insertions(+), 15 deletions(-) diff --git a/Source/Core/Core/HW/GCMemcard/GCMemcard.cpp b/Source/Core/Core/HW/GCMemcard/GCMemcard.cpp index 4fb5a90df3..f3b438d4d0 100644 --- a/Source/Core/Core/HW/GCMemcard/GCMemcard.cpp +++ b/Source/Core/Core/HW/GCMemcard/GCMemcard.cpp @@ -511,7 +511,7 @@ u16 GCMemcard::DEntry_FirstBlock(u8 index) const if (!m_valid || index >= DIRLEN) return 0xFFFF; - u16 block = BE16(CurrentDir->m_dir_entries[index].m_first_block); + u16 block = CurrentDir->m_dir_entries[index].m_first_block; if (block > (u16)maxBlock) return 0xFFFF; return block; @@ -542,7 +542,7 @@ std::string GCMemcard::GetSaveComment1(u8 index) const return ""; u32 Comment1 = BE32(CurrentDir->m_dir_entries[index].m_comments_address); - u32 DataBlock = BE16(CurrentDir->m_dir_entries[index].m_first_block) - MC_FST_BLOCKS; + u32 DataBlock = CurrentDir->m_dir_entries[index].m_first_block - MC_FST_BLOCKS; if ((DataBlock > maxBlock) || (Comment1 == 0xFFFFFFFF)) { return ""; @@ -557,7 +557,7 @@ std::string GCMemcard::GetSaveComment2(u8 index) const u32 Comment1 = BE32(CurrentDir->m_dir_entries[index].m_comments_address); u32 Comment2 = Comment1 + DENTRY_STRLEN; - u32 DataBlock = BE16(CurrentDir->m_dir_entries[index].m_first_block) - MC_FST_BLOCKS; + u32 DataBlock = CurrentDir->m_dir_entries[index].m_first_block - MC_FST_BLOCKS; if ((DataBlock > maxBlock) || (Comment1 == 0xFFFFFFFF)) { return ""; @@ -682,7 +682,7 @@ u32 GCMemcard::ImportFile(const DEntry& direntry, std::vector& saveBlo if (BE32(UpdatedDir.m_dir_entries[i].m_gamecode) == 0xFFFFFFFF) { UpdatedDir.m_dir_entries[i] = direntry; - *(u16*)&UpdatedDir.m_dir_entries[i].m_first_block = BE16(firstBlock); + UpdatedDir.m_dir_entries[i].m_first_block = firstBlock; UpdatedDir.m_dir_entries[i].m_copy_counter = UpdatedDir.m_dir_entries[i].m_copy_counter + 1; break; } @@ -748,7 +748,7 @@ u32 GCMemcard::RemoveFile(u8 index) // index in the directory array if (index >= DIRLEN) return DELETE_FAIL; - u16 startingblock = BE16(CurrentDir->m_dir_entries[index].m_first_block); + u16 startingblock = CurrentDir->m_dir_entries[index].m_first_block; u16 numberofblocks = BE16(CurrentDir->m_dir_entries[index].m_block_count); BlockAlloc UpdatedBat = *CurrentBat; @@ -1060,7 +1060,11 @@ void GCMemcard::Gcs_SavConvert(DEntry& tempDEntry, int saveType, int length) memcpy(&tempDEntry.m_animation_speed, tmp.data(), 2); ByteSwap(&tempDEntry.m_file_permissions, &tempDEntry.m_copy_counter); - ArrayByteSwap((tempDEntry.m_first_block)); + + memcpy(tmp.data(), &tempDEntry.m_first_block, 2); + ByteSwap(&tmp[0], &tmp[1]); + memcpy(&tempDEntry.m_first_block, tmp.data(), 2); + ArrayByteSwap((tempDEntry.m_block_count)); ArrayByteSwap((tempDEntry.m_unused_2)); ArrayByteSwap((tempDEntry.m_comments_address)); @@ -1088,7 +1092,7 @@ bool GCMemcard::ReadBannerRGBA8(u8 index, u32* buffer) const return false; u32 DataOffset = CurrentDir->m_dir_entries[index].m_image_offset; - u32 DataBlock = BE16(CurrentDir->m_dir_entries[index].m_first_block) - MC_FST_BLOCKS; + u32 DataBlock = CurrentDir->m_dir_entries[index].m_first_block - MC_FST_BLOCKS; if ((DataBlock > maxBlock) || (DataOffset == 0xFFFFFFFF)) { @@ -1135,7 +1139,7 @@ u32 GCMemcard::ReadAnimRGBA8(u8 index, u32* buffer, u8* delays) const int bnrFormat = (flags & 3); u32 DataOffset = CurrentDir->m_dir_entries[index].m_image_offset; - u32 DataBlock = BE16(CurrentDir->m_dir_entries[index].m_first_block) - MC_FST_BLOCKS; + u32 DataBlock = CurrentDir->m_dir_entries[index].m_first_block - MC_FST_BLOCKS; if ((DataBlock > maxBlock) || (DataOffset == 0xFFFFFFFF)) { diff --git a/Source/Core/Core/HW/GCMemcard/GCMemcard.h b/Source/Core/Core/HW/GCMemcard/GCMemcard.h index be6317613e..2ff9170d63 100644 --- a/Source/Core/Core/HW/GCMemcard/GCMemcard.h +++ b/Source/Core/Core/HW/GCMemcard/GCMemcard.h @@ -212,8 +212,9 @@ struct DEntry // 3 no copy File cannot be copied by the IPL // 2 public Can be read by any game // - u8 m_copy_counter; // 0x35 0x01 Copy counter (*2) - u8 m_first_block[2]; // 0x36 0x02 Block no of first block of file (0 == offset 0) + u8 m_copy_counter; // 0x35 0x01 Copy counter (*2) + Common::BigEndianValue + m_first_block; // 0x36 0x02 Block no of first block of file (0 == offset 0) u8 m_block_count[2]; // 0x38 0x02 File-length (number of blocks in file) u8 m_unused_2[2]; // 0x3a 0x02 Reserved/unused (always 0xffff, has no effect) u8 m_comments_address[4]; // 0x3c 0x04 Address of the two comments within the file data @@ -281,7 +282,7 @@ struct BlockAlloc m_last_allocated_block = BE16(current); m_free_blocks = BE16(BE16(m_free_blocks) - length); fixChecksums(); - return BE16(starting); + return starting; } }; static_assert(sizeof(BlockAlloc) == BLOCK_SIZE); diff --git a/Source/Core/Core/HW/GCMemcard/GCMemcardDirectory.cpp b/Source/Core/Core/HW/GCMemcard/GCMemcardDirectory.cpp index 5c289c0ce9..cfc979e5bd 100644 --- a/Source/Core/Core/HW/GCMemcard/GCMemcardDirectory.cpp +++ b/Source/Core/Core/HW/GCMemcard/GCMemcardDirectory.cpp @@ -108,7 +108,7 @@ int GCMemcardDirectory::LoadGCI(const std::string& file_name, bool current_game_ file_name.c_str()); return NO_INDEX; } - *(u16*)&gci.m_gci_header.m_first_block = first_block; + gci.m_gci_header.m_first_block = first_block; if (gci.HasCopyProtection() && gci.LoadSaveBlocks()) { GCMemcard::PSO_MakeSaveGameValid(m_hdr, gci.m_gci_header, gci.m_save_data); @@ -452,8 +452,8 @@ inline void GCMemcardDirectory::SyncSaves() m_saves[i].m_dirty = true; u32 gamecode = BE32(m_saves[i].m_gci_header.m_gamecode); u32 new_gamecode = BE32(current->m_dir_entries[i].m_gamecode); - u32 old_start = BE16(m_saves[i].m_gci_header.m_first_block); - u32 new_start = BE16(current->m_dir_entries[i].m_first_block); + u32 old_start = m_saves[i].m_gci_header.m_first_block; + u32 new_start = current->m_dir_entries[i].m_first_block; if ((gamecode != 0xFFFFFFFF) && (gamecode != new_gamecode)) { @@ -551,7 +551,7 @@ bool GCMemcardDirectory::SetUsedBlocks(int save_index) else current_bat = &m_bat1; - u16 block = BE16(m_saves[save_index].m_gci_header.m_first_block); + u16 block = m_saves[save_index].m_gci_header.m_first_block; while (block != 0xFFFF) { m_saves[save_index].m_used_blocks.push_back(block);