FolderMemoryCard: Add some debugging functionality to examine the current memory card structure on load and flush.

This commit is contained in:
Admiral H. Curtiss 2015-11-17 00:27:20 +01:00
parent 7a69812b17
commit 186d58af01
2 changed files with 30 additions and 0 deletions

View File

@ -142,6 +142,10 @@ void FolderMemoryCard::LoadMemoryCardData( const u32 sizeInClusters, const bool
CreateRootDir(); CreateRootDir();
MemoryCardFileEntry* const rootDirEntry = &m_fileEntryDict[m_superBlock.data.rootdir_cluster].entries[0]; MemoryCardFileEntry* const rootDirEntry = &m_fileEntryDict[m_superBlock.data.rootdir_cluster].entries[0];
AddFolder( rootDirEntry, m_folderName.GetPath(), nullptr, enableFiltering, filter ); AddFolder( rootDirEntry, m_folderName.GetPath(), nullptr, enableFiltering, filter );
#ifdef DEBUG_WRITE_FOLDER_CARD_IN_MEMORY_TO_FILE_ON_CHANGE
WriteToFile( m_folderName.GetFullPath().RemoveLast() + L"-debug_" + wxDateTime::Now().Format( L"%Y-%m-%d-%H-%M-%S" ) + L"_load.ps2" );
#endif
} }
} }
@ -842,6 +846,10 @@ void FolderMemoryCard::NextFrame() {
void FolderMemoryCard::Flush() { void FolderMemoryCard::Flush() {
if ( m_cache.empty() ) { return; } if ( m_cache.empty() ) { return; }
#ifdef DEBUG_WRITE_FOLDER_CARD_IN_MEMORY_TO_FILE_ON_CHANGE
WriteToFile( m_folderName.GetFullPath().RemoveLast() + L"-debug_" + wxDateTime::Now().Format( L"%Y-%m-%d-%H-%M-%S" ) + L"_pre-flush.ps2" );
#endif
Console.WriteLn( L"(FolderMcd) Writing data for slot %u to file system...", m_slot ); Console.WriteLn( L"(FolderMcd) Writing data for slot %u to file system...", m_slot );
const u64 timeFlushStart = wxGetLocalTimeMillis().GetValue(); const u64 timeFlushStart = wxGetLocalTimeMillis().GetValue();
@ -900,6 +908,10 @@ void FolderMemoryCard::Flush() {
const u64 timeFlushEnd = wxGetLocalTimeMillis().GetValue(); const u64 timeFlushEnd = wxGetLocalTimeMillis().GetValue();
Console.WriteLn( L"(FolderMcd) Done! Took %u ms.", timeFlushEnd - timeFlushStart ); Console.WriteLn( L"(FolderMcd) Done! Took %u ms.", timeFlushEnd - timeFlushStart );
#ifdef DEBUG_WRITE_FOLDER_CARD_IN_MEMORY_TO_FILE_ON_CHANGE
WriteToFile( m_folderName.GetFullPath().RemoveLast() + L"-debug_" + wxDateTime::Now().Format( L"%Y-%m-%d-%H-%M-%S" ) + L"_post-flush.ps2" );
#endif
} }
bool FolderMemoryCard::FlushPage( const u32 page ) { bool FolderMemoryCard::FlushPage( const u32 page ) {
@ -1344,6 +1356,20 @@ void FolderMemoryCard::CalculateECC( u8* ecc, const u8* data ) {
return; return;
} }
void FolderMemoryCard::WriteToFile( const wxString& filename ) {
wxFFile targetFile( filename, L"wb" );
u8 buffer[FolderMemoryCard::PageSizeRaw];
u32 adr = 0;
while ( adr < GetSizeInClusters() * FolderMemoryCard::ClusterSizeRaw ) {
Read( buffer, adr, FolderMemoryCard::PageSizeRaw );
targetFile.Write( buffer, FolderMemoryCard::PageSizeRaw );
adr += FolderMemoryCard::PageSizeRaw;
}
targetFile.Close();
}
FileAccessHelper::FileAccessHelper() { FileAccessHelper::FileAccessHelper() {
m_files.clear(); m_files.clear();

View File

@ -24,6 +24,8 @@
#include "PluginCallbacks.h" #include "PluginCallbacks.h"
#include "AppConfig.h" #include "AppConfig.h"
//#define DEBUG_WRITE_FOLDER_CARD_IN_MEMORY_TO_FILE_ON_CHANGE
// -------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------
// Superblock Header Struct // Superblock Header Struct
// -------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------
@ -348,6 +350,8 @@ public:
static void CalculateECC( u8* ecc, const u8* data ); static void CalculateECC( u8* ecc, const u8* data );
void WriteToFile( const wxString& filename );
protected: protected:
// initializes memory card data, as if it was fresh from the factory // initializes memory card data, as if it was fresh from the factory
void InitializeInternalData(); void InitializeInternalData();