fix the most egregious savestate backwards compatibility violation. also remove code which would have prevented non-windows from compiling
This commit is contained in:
parent
89d9ebbbd2
commit
6b0d234643
|
@ -49,6 +49,9 @@ savestates_t savestates[NB_STATES];
|
||||||
#define SAVESTATE_VERSION 11
|
#define SAVESTATE_VERSION 11
|
||||||
static const char* magic = "DeSmuME SState\0";
|
static const char* magic = "DeSmuME SState\0";
|
||||||
|
|
||||||
|
//a savestate chunk loader can set this if it wants to permit a silent failure (for compatibility)
|
||||||
|
static bool SAV_silent_fail_flag;
|
||||||
|
|
||||||
#ifndef MAX_PATH
|
#ifndef MAX_PATH
|
||||||
#define MAX_PATH 256
|
#define MAX_PATH 256
|
||||||
#endif
|
#endif
|
||||||
|
@ -145,7 +148,9 @@ SFORMAT SF_MEM[]={
|
||||||
|
|
||||||
{ "VMEM", 1, sizeof(ARM9Mem.ARM9_VMEM), ARM9Mem.ARM9_VMEM},
|
{ "VMEM", 1, sizeof(ARM9Mem.ARM9_VMEM), ARM9Mem.ARM9_VMEM},
|
||||||
{ "OAMS", 1, sizeof(ARM9Mem.ARM9_OAM), ARM9Mem.ARM9_OAM},
|
{ "OAMS", 1, sizeof(ARM9Mem.ARM9_OAM), ARM9Mem.ARM9_OAM},
|
||||||
{ "LCDM", 1, sizeof(ARM9Mem.ARM9_LCD), ARM9Mem.ARM9_LCD},
|
|
||||||
|
//this size is specially chosen to avoid saving the blank space at the end
|
||||||
|
{ "LCDM", 1, 0xA4000, ARM9Mem.ARM9_LCD},
|
||||||
{ 0 }
|
{ 0 }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -248,7 +253,7 @@ SFORMAT SF_MOVIE[]={
|
||||||
static void mmu_savestate(std::ostream* os)
|
static void mmu_savestate(std::ostream* os)
|
||||||
{
|
{
|
||||||
//version
|
//version
|
||||||
write32le(0,os);
|
write32le(1,os);
|
||||||
|
|
||||||
write32le(MMU.bupmem.type,os);
|
write32le(MMU.bupmem.type,os);
|
||||||
write32le(MMU.bupmem.size,os);
|
write32le(MMU.bupmem.size,os);
|
||||||
|
@ -260,14 +265,26 @@ static bool mmu_loadstate(std::istream* is, int size)
|
||||||
//read version
|
//read version
|
||||||
int version;
|
int version;
|
||||||
if(read32le(&version,is) != 1) return false;
|
if(read32le(&version,is) != 1) return false;
|
||||||
if(version != 0) return false;
|
|
||||||
|
|
||||||
int bupmem_type;
|
|
||||||
u32 bupmem_size;
|
u32 bupmem_size;
|
||||||
|
|
||||||
|
if(version == 0)
|
||||||
|
{
|
||||||
|
//version 0 was buggy and didnt save the type.
|
||||||
|
//it would silently fail if there was a size mismatch
|
||||||
|
SAV_silent_fail_flag = true;
|
||||||
|
if(read32le(&bupmem_size,is) != 1) return false;
|
||||||
|
if(bupmem_size != MMU.bupmem.size) return false; //mismatch between current initialized and saved size
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//version 1 reinitializes the save system with the type that was saved
|
||||||
|
int bupmem_type;
|
||||||
if(read32le(&bupmem_type,is) != 1) return false;
|
if(read32le(&bupmem_type,is) != 1) return false;
|
||||||
if(read32le(&bupmem_size,is) != 1) return false;
|
if(read32le(&bupmem_size,is) != 1) return false;
|
||||||
|
|
||||||
mc_realloc(&MMU.bupmem,bupmem_type,bupmem_size);
|
mc_realloc(&MMU.bupmem,bupmem_type,bupmem_size);
|
||||||
|
}
|
||||||
|
|
||||||
is->read((char*)MMU.bupmem.data,bupmem_size);
|
is->read((char*)MMU.bupmem.data,bupmem_size);
|
||||||
if(is->fail()) return false;
|
if(is->fail()) return false;
|
||||||
|
@ -668,16 +685,6 @@ static bool savestate_save(std::ostream* outstream, int compressionLevel)
|
||||||
writechunks(os);
|
writechunks(os);
|
||||||
ms.flush();
|
ms.flush();
|
||||||
|
|
||||||
for(int i=0x2000;i<0x1000000;i++)
|
|
||||||
if(ARM9Mem.ARM9_REG[i] != 0) {
|
|
||||||
MessageBox(0,"Debug check fail: ARM9Mem.ARM9_REG",0,0);
|
|
||||||
}
|
|
||||||
|
|
||||||
for(int i=0;i<0x20000;i++)
|
|
||||||
if(ARM9Mem.blank_memory[i] != 0) {
|
|
||||||
MessageBox(0,"Debug check fail: ARM9Mem.blank_memory",0,0);
|
|
||||||
}
|
|
||||||
|
|
||||||
//save the length of the file
|
//save the length of the file
|
||||||
u32 len = ms.size();
|
u32 len = ms.size();
|
||||||
|
|
||||||
|
@ -737,8 +744,6 @@ bool savestate_save (const char *file_name)
|
||||||
} else return false;
|
} else return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
//u8 GPU_screen[4*256*192];
|
|
||||||
|
|
||||||
static void writechunks(std::ostream* os) {
|
static void writechunks(std::ostream* os) {
|
||||||
savestate_WriteChunk(os,1,SF_ARM9);
|
savestate_WriteChunk(os,1,SF_ARM9);
|
||||||
savestate_WriteChunk(os,2,SF_ARM7);
|
savestate_WriteChunk(os,2,SF_ARM7);
|
||||||
|
@ -812,6 +817,7 @@ static void loadstate()
|
||||||
|
|
||||||
static bool savestate_load(std::istream* is)
|
static bool savestate_load(std::istream* is)
|
||||||
{
|
{
|
||||||
|
SAV_silent_fail_flag = false;
|
||||||
char header[16];
|
char header[16];
|
||||||
is->read(header,16);
|
is->read(header,16);
|
||||||
if(is->fail() || memcmp(header,magic,16))
|
if(is->fail() || memcmp(header,magic,16))
|
||||||
|
@ -867,10 +873,11 @@ static bool savestate_load(std::istream* is)
|
||||||
memorystream mstemp(&buf);
|
memorystream mstemp(&buf);
|
||||||
bool x = ReadStateChunks(&mstemp,(s32)len);
|
bool x = ReadStateChunks(&mstemp,(s32)len);
|
||||||
|
|
||||||
if(!x)
|
if(!x && !SAV_silent_fail_flag)
|
||||||
{
|
{
|
||||||
printf("Error loading savestate. It failed halfway through;\nSince there is no savestate backup system, your current game session is wrecked");
|
printf("Error loading savestate. It failed halfway through;\nSince there is no savestate backup system, your current game session is wrecked");
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
|
//HACK! we really need a better way to handle this kind of feedback
|
||||||
MessageBox(0,"Error loading savestate. It failed halfway through;\nSince there is no savestate backup system, your current game session is wrecked",0,0);
|
MessageBox(0,"Error loading savestate. It failed halfway through;\nSince there is no savestate backup system, your current game session is wrecked",0,0);
|
||||||
#endif
|
#endif
|
||||||
return false;
|
return false;
|
||||||
|
|
Loading…
Reference in New Issue