2008-08-06 03:09:59 +02:00
|
|
|
/****************************************************************************
|
2008-09-12 07:28:40 +02:00
|
|
|
* Snes9x 1.51 Nintendo Wii/Gamecube Port
|
2008-09-05 00:42:33 +02:00
|
|
|
*
|
2008-08-06 03:09:59 +02:00
|
|
|
* crunchy2 April 2007-July 2007
|
2008-09-23 06:13:33 +02:00
|
|
|
* Michniewski 2008
|
2009-03-11 18:28:37 +01:00
|
|
|
* Tantric 2008-2009
|
2008-08-06 03:09:59 +02:00
|
|
|
*
|
|
|
|
* sram.cpp
|
|
|
|
*
|
|
|
|
* SRAM save/load/import/export handling
|
2008-09-12 07:28:40 +02:00
|
|
|
***************************************************************************/
|
|
|
|
|
2008-08-06 03:09:59 +02:00
|
|
|
#include <gccore.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <ogcsys.h>
|
|
|
|
|
|
|
|
#include "snes9x.h"
|
|
|
|
#include "memmap.h"
|
|
|
|
#include "srtc.h"
|
2008-08-10 05:14:39 +02:00
|
|
|
|
2008-09-09 19:36:48 +02:00
|
|
|
#include "snes9xGX.h"
|
2008-08-12 05:25:16 +02:00
|
|
|
#include "images/saveicon.h"
|
2009-03-11 18:28:37 +01:00
|
|
|
#include "menu.h"
|
2008-12-18 19:36:30 +01:00
|
|
|
#include "fileop.h"
|
2009-03-11 18:28:37 +01:00
|
|
|
#include "filebrowser.h"
|
2009-01-05 23:23:41 +01:00
|
|
|
#include "input.h"
|
2008-08-06 03:09:59 +02:00
|
|
|
|
|
|
|
/****************************************************************************
|
2008-09-02 22:15:59 +02:00
|
|
|
* Prepare SRAM Save Data
|
2008-08-06 03:09:59 +02:00
|
|
|
*
|
2008-09-12 07:28:40 +02:00
|
|
|
* This sets up the savebuffer for saving in a format compatible with
|
|
|
|
* snes9x on other platforms.
|
|
|
|
***************************************************************************/
|
2009-01-05 23:23:41 +01:00
|
|
|
static int
|
2008-09-02 22:15:59 +02:00
|
|
|
preparesavedata (int method)
|
2008-08-06 03:09:59 +02:00
|
|
|
{
|
2008-09-02 22:15:59 +02:00
|
|
|
int offset = 0;
|
|
|
|
int size;
|
2008-08-06 03:09:59 +02:00
|
|
|
|
2008-09-02 22:15:59 +02:00
|
|
|
if(method == METHOD_MC_SLOTA || method == METHOD_MC_SLOTB)
|
|
|
|
{
|
|
|
|
// Copy in save icon
|
|
|
|
memcpy (savebuffer, saveicon, sizeof(saveicon));
|
|
|
|
offset += sizeof (saveicon);
|
|
|
|
}
|
2008-08-06 03:09:59 +02:00
|
|
|
|
2008-09-02 22:15:59 +02:00
|
|
|
// Copy in the sramcomments
|
2009-01-05 23:23:41 +01:00
|
|
|
char sramcomment[2][32];
|
2008-12-22 10:20:35 +01:00
|
|
|
memset(sramcomment, 0, 64);
|
2008-12-24 09:02:04 +01:00
|
|
|
sprintf (sramcomment[0], "%s SRAM", APPNAME);
|
2008-09-02 22:15:59 +02:00
|
|
|
sprintf (sramcomment[1], Memory.ROMName);
|
|
|
|
memcpy (savebuffer + offset, sramcomment, 64);
|
|
|
|
offset += 64;
|
2008-08-06 03:09:59 +02:00
|
|
|
|
2008-09-02 22:15:59 +02:00
|
|
|
if(method != METHOD_MC_SLOTA && method != METHOD_MC_SLOTB)
|
|
|
|
{
|
|
|
|
// make it a 512 byte header so it is compatible with other platforms
|
|
|
|
if (offset <= 512)
|
|
|
|
offset = 512;
|
|
|
|
// header was longer than 512 bytes - hopefully this never happens!
|
|
|
|
else
|
|
|
|
return 0;
|
|
|
|
}
|
2008-08-07 05:25:02 +02:00
|
|
|
|
2008-09-02 22:15:59 +02:00
|
|
|
// Copy in the SRAM
|
2008-08-06 03:09:59 +02:00
|
|
|
size = Memory.SRAMSize ? (1 << (Memory.SRAMSize + 3)) * 128 : 0;
|
2008-08-07 05:25:02 +02:00
|
|
|
|
2008-08-06 03:09:59 +02:00
|
|
|
if (size > 0x20000)
|
2008-09-02 22:15:59 +02:00
|
|
|
size = 0x20000;
|
2008-08-07 05:25:02 +02:00
|
|
|
|
2008-08-06 03:09:59 +02:00
|
|
|
if (size != 0)
|
|
|
|
{
|
2008-09-02 22:15:59 +02:00
|
|
|
memcpy (savebuffer + offset, Memory.SRAM, size);
|
|
|
|
offset += size;
|
2008-08-06 03:09:59 +02:00
|
|
|
}
|
2008-09-05 00:42:33 +02:00
|
|
|
else
|
|
|
|
{
|
|
|
|
offset = 0;
|
|
|
|
}
|
2008-08-07 05:25:02 +02:00
|
|
|
|
2008-08-06 03:09:59 +02:00
|
|
|
return offset;
|
|
|
|
}
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Decode Save Data
|
2008-09-12 07:28:40 +02:00
|
|
|
***************************************************************************/
|
2009-01-05 23:23:41 +01:00
|
|
|
static void
|
2008-09-02 22:15:59 +02:00
|
|
|
decodesavedata (int method, int readsize)
|
2008-08-06 03:09:59 +02:00
|
|
|
{
|
2008-09-05 00:42:33 +02:00
|
|
|
int offset = 0;
|
2008-09-02 22:15:59 +02:00
|
|
|
char sramsavecomment[32];
|
2008-08-07 05:25:02 +02:00
|
|
|
|
2008-09-02 22:15:59 +02:00
|
|
|
int size = Memory.SRAMSize ? (1 << (Memory.SRAMSize + 3)) * 128 : 0;
|
2008-08-07 05:25:02 +02:00
|
|
|
|
2008-09-02 22:15:59 +02:00
|
|
|
if (size > 0x20000)
|
|
|
|
size = 0x20000;
|
2008-08-07 05:25:02 +02:00
|
|
|
|
2008-09-02 22:15:59 +02:00
|
|
|
// memory card save
|
|
|
|
if(method == METHOD_MC_SLOTA || method == METHOD_MC_SLOTB)
|
2008-09-05 00:42:33 +02:00
|
|
|
offset = sizeof (saveicon); // skip save icon
|
2008-08-06 03:09:59 +02:00
|
|
|
|
2008-09-05 00:42:33 +02:00
|
|
|
// Check for sram comment
|
2008-09-02 22:15:59 +02:00
|
|
|
memcpy (sramsavecomment, savebuffer+offset, 32);
|
2008-08-07 05:25:02 +02:00
|
|
|
|
2008-09-05 00:42:33 +02:00
|
|
|
// version 0xx found!
|
|
|
|
if ( (strncmp (sramsavecomment, "Snes9x GX 0", 11) == 0) )
|
2008-08-06 03:09:59 +02:00
|
|
|
{
|
2008-09-05 00:42:33 +02:00
|
|
|
// adjust offset
|
2008-09-10 00:38:02 +02:00
|
|
|
if(method != METHOD_MC_SLOTA && method != METHOD_MC_SLOTB)
|
2008-09-05 00:42:33 +02:00
|
|
|
offset = 512; // skip entire 512 byte header
|
|
|
|
else
|
|
|
|
offset += 64; // skip savecomments
|
|
|
|
|
2008-09-02 22:15:59 +02:00
|
|
|
// import the SRAM
|
|
|
|
memcpy (Memory.SRAM, savebuffer + offset, size);
|
2008-08-06 03:09:59 +02:00
|
|
|
}
|
2008-09-02 22:15:59 +02:00
|
|
|
// check for SRAM from other version/platform of snes9x
|
|
|
|
else if ( readsize == size || readsize == size + SRTC_SRAM_PAD)
|
2008-08-06 03:09:59 +02:00
|
|
|
{
|
|
|
|
// SRAM data should be at the start of the file, just import it and
|
|
|
|
// ignore anything after the SRAM
|
|
|
|
memcpy (Memory.SRAM, savebuffer, size);
|
2008-09-02 22:15:59 +02:00
|
|
|
}
|
|
|
|
else if ( readsize == size + 512 )
|
|
|
|
{
|
2008-08-06 03:09:59 +02:00
|
|
|
// SRAM has a 512 byte header - remove it, then import the SRAM,
|
|
|
|
// ignoring anything after the SRAM
|
2008-09-02 22:15:59 +02:00
|
|
|
memcpy(Memory.SRAM, savebuffer+512, size);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2009-03-11 18:28:37 +01:00
|
|
|
ErrorPrompt("Incompatible SRAM save!");
|
2008-08-06 03:09:59 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-08-07 05:25:02 +02:00
|
|
|
/****************************************************************************
|
|
|
|
* Load SRAM
|
2008-09-12 07:28:40 +02:00
|
|
|
***************************************************************************/
|
2009-01-05 23:23:41 +01:00
|
|
|
bool
|
2009-03-11 18:28:37 +01:00
|
|
|
LoadSRAM (char * filepath, int method, bool silent)
|
2008-08-06 03:09:59 +02:00
|
|
|
{
|
2008-11-12 08:50:39 +01:00
|
|
|
int offset = 0;
|
2008-08-12 05:25:16 +02:00
|
|
|
|
2008-08-07 05:25:02 +02:00
|
|
|
if(method == METHOD_AUTO)
|
2008-12-22 10:20:35 +01:00
|
|
|
method = autoSaveMethod(silent); // we use 'Save' because SRAM needs R/W
|
2008-08-07 05:25:02 +02:00
|
|
|
|
2009-03-11 18:28:37 +01:00
|
|
|
if(method == METHOD_AUTO)
|
2009-01-05 23:23:41 +01:00
|
|
|
return false;
|
2008-08-07 05:25:02 +02:00
|
|
|
|
2008-11-12 08:50:39 +01:00
|
|
|
AllocSaveBuffer();
|
2008-08-17 07:25:33 +02:00
|
|
|
|
2008-11-12 08:50:39 +01:00
|
|
|
offset = LoadFile(filepath, method, silent);
|
2008-08-07 05:25:02 +02:00
|
|
|
|
|
|
|
if (offset > 0)
|
|
|
|
{
|
2008-09-02 22:15:59 +02:00
|
|
|
decodesavedata (method, offset);
|
2008-08-07 05:25:02 +02:00
|
|
|
S9xSoftReset();
|
2008-11-12 08:50:39 +01:00
|
|
|
FreeSaveBuffer ();
|
2009-01-05 23:23:41 +01:00
|
|
|
return true;
|
2008-09-27 09:13:52 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2008-11-12 08:50:39 +01:00
|
|
|
FreeSaveBuffer ();
|
|
|
|
|
2008-09-27 09:13:52 +02:00
|
|
|
// if we reached here, nothing was done!
|
|
|
|
if(!silent)
|
2009-03-11 18:28:37 +01:00
|
|
|
ErrorPrompt("SRAM file not found");
|
2008-09-27 09:13:52 +02:00
|
|
|
|
2009-01-05 23:23:41 +01:00
|
|
|
return false;
|
2008-09-27 09:13:52 +02:00
|
|
|
}
|
2008-08-06 03:09:59 +02:00
|
|
|
}
|
|
|
|
|
2009-03-11 18:28:37 +01:00
|
|
|
bool
|
|
|
|
LoadSRAMAuto (int method, bool silent)
|
|
|
|
{
|
|
|
|
char filepath[1024];
|
|
|
|
|
|
|
|
if(method == METHOD_MC_SLOTA || method == METHOD_MC_SLOTB)
|
|
|
|
sprintf(filepath, "%s Auto.srm", Memory.ROMFilename);
|
|
|
|
else
|
|
|
|
sprintf(filepath, "%s/%s Auto.srm", GCSettings.SaveFolder, Memory.ROMFilename);
|
|
|
|
return LoadSRAM(filepath, method, silent);
|
|
|
|
}
|
|
|
|
|
2008-08-07 05:25:02 +02:00
|
|
|
/****************************************************************************
|
|
|
|
* Save SRAM
|
2008-09-12 07:28:40 +02:00
|
|
|
***************************************************************************/
|
2008-08-07 05:25:02 +02:00
|
|
|
bool
|
2009-03-11 18:28:37 +01:00
|
|
|
SaveSRAM (char * filepath, int method, bool silent)
|
2008-08-06 03:09:59 +02:00
|
|
|
{
|
2008-08-07 05:25:02 +02:00
|
|
|
bool retval = false;
|
|
|
|
int datasize;
|
|
|
|
int offset = 0;
|
|
|
|
|
2008-11-12 08:50:39 +01:00
|
|
|
if(method == METHOD_AUTO)
|
2008-12-22 10:20:35 +01:00
|
|
|
method = autoSaveMethod(silent);
|
2008-11-12 08:50:39 +01:00
|
|
|
|
2009-03-11 18:28:37 +01:00
|
|
|
if(method == METHOD_AUTO)
|
2008-11-12 08:50:39 +01:00
|
|
|
return false;
|
|
|
|
|
2008-09-27 09:13:52 +02:00
|
|
|
AllocSaveBuffer ();
|
|
|
|
|
2008-09-02 22:15:59 +02:00
|
|
|
datasize = preparesavedata (method);
|
2008-08-07 05:25:02 +02:00
|
|
|
|
2008-11-12 08:50:39 +01:00
|
|
|
if (datasize)
|
2008-08-07 05:25:02 +02:00
|
|
|
{
|
2008-11-12 08:50:39 +01:00
|
|
|
offset = SaveFile(filepath, datasize, method, silent);
|
2008-08-07 05:25:02 +02:00
|
|
|
|
|
|
|
if (offset > 0)
|
|
|
|
{
|
2009-03-11 18:28:37 +01:00
|
|
|
if (!silent)
|
|
|
|
InfoPrompt("Save successful");
|
2008-08-07 05:25:02 +02:00
|
|
|
retval = true;
|
|
|
|
}
|
|
|
|
}
|
2008-09-09 06:13:42 +02:00
|
|
|
else
|
|
|
|
{
|
|
|
|
if(!silent)
|
2009-03-11 18:28:37 +01:00
|
|
|
ErrorPrompt("No SRAM data to save!");
|
2008-09-09 06:13:42 +02:00
|
|
|
}
|
2008-09-27 09:13:52 +02:00
|
|
|
|
|
|
|
FreeSaveBuffer ();
|
2008-08-07 05:25:02 +02:00
|
|
|
return retval;
|
2008-08-06 03:09:59 +02:00
|
|
|
}
|
2009-03-11 18:28:37 +01:00
|
|
|
|
|
|
|
bool
|
|
|
|
SaveSRAMAuto (int method, bool silent)
|
|
|
|
{
|
|
|
|
char filepath[1024];
|
|
|
|
|
|
|
|
if(method == METHOD_MC_SLOTA || method == METHOD_MC_SLOTB)
|
|
|
|
sprintf(filepath, "%s Auto.srm", Memory.ROMFilename);
|
|
|
|
else
|
|
|
|
sprintf(filepath, "%s/%s Auto.srm", GCSettings.SaveFolder, Memory.ROMFilename);
|
|
|
|
return SaveSRAM(filepath, method, silent);
|
|
|
|
}
|