core:
- more work on a backup memory stuff (fix Fokemons :) broken by me on r4807)
This commit is contained in:
parent
68525db6d9
commit
4ce78d5e49
|
@ -2460,7 +2460,6 @@ u32 DmaController::read32()
|
||||||
|
|
||||||
static INLINE void write_auxspicnt(const int proc, const int size, const int adr, const int val)
|
static INLINE void write_auxspicnt(const int proc, const int size, const int adr, const int val)
|
||||||
{
|
{
|
||||||
//u16 oldCnt = MMU.AUX_SPI_CNT;
|
|
||||||
bool csOld = (MMU.AUX_SPI_CNT & (1 << 6))?true:false;
|
bool csOld = (MMU.AUX_SPI_CNT & (1 << 6))?true:false;
|
||||||
|
|
||||||
switch(size)
|
switch(size)
|
||||||
|
@ -2477,6 +2476,9 @@ static INLINE void write_auxspicnt(const int proc, const int size, const int adr
|
||||||
|
|
||||||
//printf("MMU%c: cnt %04X, old %04X\n", proc?'7':'9', MMU.AUX_SPI_CNT, oldCnt);
|
//printf("MMU%c: cnt %04X, old %04X\n", proc?'7':'9', MMU.AUX_SPI_CNT, oldCnt);
|
||||||
|
|
||||||
|
if (MMU.AUX_SPI_CNT == 0)
|
||||||
|
MMU_new.backupDevice.reset_command(false);
|
||||||
|
|
||||||
if (!cs && csOld)
|
if (!cs && csOld)
|
||||||
{
|
{
|
||||||
//printf("MMU%c: CS changed from HIGH to LOW *****\n", proc?'7':'9');
|
//printf("MMU%c: CS changed from HIGH to LOW *****\n", proc?'7':'9');
|
||||||
|
|
|
@ -54,7 +54,7 @@
|
||||||
//the game reads its initial sound volumes from uninitialized data, and if it is 0, the game will be silent
|
//the game reads its initial sound volumes from uninitialized data, and if it is 0, the game will be silent
|
||||||
//if it is 0xFF then the game starts with its sound and music at max, as presumably it is supposed to.
|
//if it is 0xFF then the game starts with its sound and music at max, as presumably it is supposed to.
|
||||||
//so in r3303 I finally changed it (no$ appears definitely to initialize to 0xFF)
|
//so in r3303 I finally changed it (no$ appears definitely to initialize to 0xFF)
|
||||||
static const u8 kUninitializedSaveDataValue = 0xFF;
|
static const u8 kUninitializedSaveDataValue = 0xFF;
|
||||||
|
|
||||||
static const char* kDesmumeSaveCookie = "|-DESMUME SAVE-|";
|
static const char* kDesmumeSaveCookie = "|-DESMUME SAVE-|";
|
||||||
|
|
||||||
|
@ -244,24 +244,19 @@ void BackupDevice::detect()
|
||||||
|
|
||||||
printf("Autodetecting with autodetect_size=%d\n",autodetect_size);
|
printf("Autodetecting with autodetect_size=%d\n",autodetect_size);
|
||||||
|
|
||||||
const u8 sm64_sig[] = {0x01,0x80,0x00,0x00};
|
//detect based on rules
|
||||||
if(autodetect_size == 4 && !memcmp(&data_autodetect[0],sm64_sig,4))
|
switch(autodetect_size)
|
||||||
{
|
{
|
||||||
addr_size = 2;
|
|
||||||
}
|
|
||||||
else //detect based on rules
|
|
||||||
switch(autodetect_size)
|
|
||||||
{
|
|
||||||
case 0:
|
case 0:
|
||||||
case 1:
|
case 1:
|
||||||
addr_size = 1; //choose 1 just to keep the busted savefile from growing too big
|
addr_size = 1; //choose 1 just to keep the busted savefile from growing too big
|
||||||
|
|
||||||
if(!memcmp(gameInfo.header.gameCode,"AL3", 3)) break; //spongebob atlantis squarepantis.
|
if(!memcmp(gameInfo.header.gameCode,"AL3", 3)) break; //spongebob atlantis squarepantis.
|
||||||
//if(!memcmp(gameInfo.header.gameCode,"AH5",3)) break; //over the hedge
|
|
||||||
if(!memcmp(gameInfo.header.gameCode,"AVH", 3)) break; //over the hedge - Hammy Goes Nuts!
|
if(!memcmp(gameInfo.header.gameCode,"AVH", 3)) break; //over the hedge - Hammy Goes Nuts!
|
||||||
if(!memcmp(gameInfo.header.gameCode,"AQ3", 3)) break; //spider-man 3
|
if(!memcmp(gameInfo.header.gameCode,"AQ3", 3)) break; //spider-man 3
|
||||||
|
|
||||||
msgbox->error("Catastrophic error while autodetecting save type.\nIt will need to be specified manually\n");
|
printf("Catastrophic error while autodetecting save type.\nIt will need to be specified manually\n");
|
||||||
|
//msgbox->error("Catastrophic error while autodetecting save type.\nIt will need to be specified manually\n");
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
//the modern typical case for small eeproms
|
//the modern typical case for small eeproms
|
||||||
|
@ -279,6 +274,7 @@ void BackupDevice::detect()
|
||||||
case 4:
|
case 4:
|
||||||
//a modern typical case
|
//a modern typical case
|
||||||
addr_size = 3;
|
addr_size = 3;
|
||||||
|
if(!memcmp(gameInfo.header.gameCode,"ASM", 3)) addr_size = 2; //super mario 64 ds
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
//the archaic case: write the address and then some modulo-4 number of bytes
|
//the archaic case: write the address and then some modulo-4 number of bytes
|
||||||
|
@ -287,7 +283,7 @@ void BackupDevice::detect()
|
||||||
//SM64 (KOR) makes it here with autodetect_size=11 and nothing interesting in the buffer
|
//SM64 (KOR) makes it here with autodetect_size=11 and nothing interesting in the buffer
|
||||||
addr_size = autodetect_size & 3;
|
addr_size = autodetect_size & 3;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
state = RUNNING;
|
state = RUNNING;
|
||||||
data_autodetect.resize(0);
|
data_autodetect.resize(0);
|
||||||
|
|
|
@ -76,7 +76,7 @@ public:
|
||||||
bool load_state(EMUFILE* is);
|
bool load_state(EMUFILE* is);
|
||||||
|
|
||||||
//commands from mmu
|
//commands from mmu
|
||||||
void reset_command() { reset_command_state = true; };
|
void reset_command(bool state = true) { reset_command_state = state; };
|
||||||
u8 data_command(u8,int);
|
u8 data_command(u8,int);
|
||||||
std::vector<u8> data;
|
std::vector<u8> data;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue