notaz.gp2x.de
/
picodrive.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
32x: move sh2 peripheral emu code to it's own file
[picodrive.git]
/
pico
/
state.c
diff --git
a/pico/state.c
b/pico/state.c
index
6b91d48
..
3969e18
100644
(file)
--- a/
pico/state.c
+++ b/
pico/state.c
@@
-11,15
+11,11
@@
\r
#include "../cpu/sh2/sh2.h"
\r
#include "sound/ym2612.h"
\r
\r
#include "../cpu/sh2/sh2.h"
\r
#include "sound/ym2612.h"
\r
+#include "state.h"
\r
\r
// sn76496
\r
extern int *sn76496_regs;
\r
\r
\r
// sn76496
\r
extern int *sn76496_regs;
\r
\r
-typedef size_t (arearw)(void *p, size_t _size, size_t _n, void *file);
\r
-typedef size_t (areaeof)(void *file);
\r
-typedef int (areaseek)(void *file, long offset, int whence);
\r
-typedef int (areaclose)(void *file);
\r
-
\r
static arearw *areaRead;
\r
static arearw *areaWrite;
\r
static areaeof *areaEof;
\r
static arearw *areaRead;
\r
static arearw *areaWrite;
\r
static areaeof *areaEof;
\r
@@
-174,6
+170,9
@@
typedef enum {
CHUNK_SDRAM,
\r
CHUNK_DRAM,
\r
CHUNK_32XPAL,
\r
CHUNK_SDRAM,
\r
CHUNK_DRAM,
\r
CHUNK_32XPAL,
\r
+ CHUNK_32X_EVT,
\r
+ CHUNK_32X_FIRST = CHUNK_MSH2,
\r
+ CHUNK_32X_LAST = CHUNK_32X_EVT,
\r
//
\r
CHUNK_DEFAULT_COUNT,
\r
CHUNK_CARTHW_ = CHUNK_CARTHW, // defined in PicoInt
\r
//
\r
CHUNK_DEFAULT_COUNT,
\r
CHUNK_CARTHW_ = CHUNK_CARTHW, // defined in PicoInt
\r
@@
-222,6
+221,7
@@
static const char * const chunk_names[] = {
"SDRAM",
\r
"DRAM",
\r
"PAL",
\r
"SDRAM",
\r
"DRAM",
\r
"PAL",
\r
+ "events",
\r
};
\r
\r
static int write_chunk(chunk_name_e name, int len, void *data, void *file)
\r
};
\r
\r
static int write_chunk(chunk_name_e name, int len, void *data, void *file)
\r
@@
-334,7
+334,9
@@
static int state_save(void *file)
CHECKED_WRITE_BUFF(CHUNK_DRAM, Pico32xMem->dram);
\r
CHECKED_WRITE_BUFF(CHUNK_32XPAL, Pico32xMem->pal);
\r
\r
CHECKED_WRITE_BUFF(CHUNK_DRAM, Pico32xMem->dram);
\r
CHECKED_WRITE_BUFF(CHUNK_32XPAL, Pico32xMem->pal);
\r
\r
- sh2s[0].m68krcycles_done = sh2s[1].m68krcycles_done = SekCycleCnt;
\r
+ memset(buff, 0, 0x40);
\r
+ memcpy(buff, event_times, sizeof(event_times));
\r
+ CHECKED_WRITE(CHUNK_32X_EVT, 0x40, buff);
\r
}
\r
#endif
\r
\r
}
\r
#endif
\r
\r
@@
-384,6
+386,7
@@
static int state_load(void *file)
unsigned char buff_m68k[0x60], buff_s68k[0x60];
\r
unsigned char buff_z80[Z80_STATE_SIZE];
\r
unsigned char buff_sh2[SH2_STATE_SIZE];
\r
unsigned char buff_m68k[0x60], buff_s68k[0x60];
\r
unsigned char buff_z80[Z80_STATE_SIZE];
\r
unsigned char buff_sh2[SH2_STATE_SIZE];
\r
+ unsigned char buff[0x40];
\r
unsigned char chunk;
\r
void *ym2612_regs;
\r
char header[8];
\r
unsigned char chunk;
\r
void *ym2612_regs;
\r
char header[8];
\r
@@
-406,8
+409,8
@@
static int state_load(void *file)
if (len < 0 || len > 1024*512) R_ERROR_RETURN("bad length");
\r
if (CHUNK_S68K <= chunk && chunk <= CHUNK_MISC_CD && !(PicoAHW & PAHW_MCD))
\r
R_ERROR_RETURN("cd chunk in non CD state?");
\r
if (len < 0 || len > 1024*512) R_ERROR_RETURN("bad length");
\r
if (CHUNK_S68K <= chunk && chunk <= CHUNK_MISC_CD && !(PicoAHW & PAHW_MCD))
\r
R_ERROR_RETURN("cd chunk in non CD state?");
\r
- if (CHUNK_
MSH2 <= chunk && chunk <= CHUNK_32XPAL
&& !(PicoAHW & PAHW_32X))
\r
-
R_ERROR_RETURN("32x chunk in non 32x state?"
);
\r
+ if (CHUNK_
32X_FIRST <= chunk && chunk <= CHUNK_32X_LAST
&& !(PicoAHW & PAHW_32X))
\r
+
Pico32xStartup(
);
\r
\r
switch (chunk)
\r
{
\r
\r
switch (chunk)
\r
{
\r
@@
-478,6
+481,11
@@
static int state_load(void *file)
case CHUNK_SDRAM: CHECKED_READ_BUFF(Pico32xMem->sdram); break;
\r
case CHUNK_DRAM: CHECKED_READ_BUFF(Pico32xMem->dram); break;
\r
case CHUNK_32XPAL: CHECKED_READ_BUFF(Pico32xMem->pal); break;
\r
case CHUNK_SDRAM: CHECKED_READ_BUFF(Pico32xMem->sdram); break;
\r
case CHUNK_DRAM: CHECKED_READ_BUFF(Pico32xMem->dram); break;
\r
case CHUNK_32XPAL: CHECKED_READ_BUFF(Pico32xMem->pal); break;
\r
+
\r
+ case CHUNK_32X_EVT:
\r
+ CHECKED_READ_BUFF(buff);
\r
+ memcpy(event_times, buff, sizeof(event_times));
\r
+ break;
\r
#endif
\r
default:
\r
if (carthw_chunks != NULL)
\r
#endif
\r
default:
\r
if (carthw_chunks != NULL)
\r
@@
-507,18
+515,22
@@
readend:
\r
if (!(Pico_mcd->s68k_regs[0x36] & 1) && (Pico_mcd->scd.Status_CDC & 1))
\r
cdda_start_play();
\r
\r
if (!(Pico_mcd->s68k_regs[0x36] & 1) && (Pico_mcd->scd.Status_CDC & 1))
\r
cdda_start_play();
\r
-
\r
- SekUnpackCpu(buff_s68k, 1);
\r
}
\r
\r
}
\r
\r
+ if (PicoAHW & PAHW_32X)
\r
+ Pico32xStateLoaded(1);
\r
+
\r
// must unpack 68k and z80 after banks are set up
\r
if (!(PicoAHW & PAHW_SMS))
\r
SekUnpackCpu(buff_m68k, 0);
\r
// must unpack 68k and z80 after banks are set up
\r
if (!(PicoAHW & PAHW_SMS))
\r
SekUnpackCpu(buff_m68k, 0);
\r
+ if (PicoAHW & PAHW_MCD)
\r
+ SekUnpackCpu(buff_s68k, 1);
\r
\r
z80_unpack(buff_z80);
\r
\r
\r
z80_unpack(buff_z80);
\r
\r
+ // due to dep from 68k cycles..
\r
if (PicoAHW & PAHW_32X)
\r
if (PicoAHW & PAHW_32X)
\r
- Pico32xStateLoaded();
\r
+ Pico32xStateLoaded(
0
);
\r
\r
return 0;
\r
}
\r
\r
return 0;
\r
}
\r
@@
-578,15
+590,10
@@
readend:
return 0;
\r
}
\r
\r
return 0;
\r
}
\r
\r
-
int PicoState(const char *fnam
e, int is_save)
\r
+
static int pico_state_internal(void *afil
e, int is_save)
\r
{
\r
{
\r
- void *afile = NULL;
\r
int ret;
\r
\r
int ret;
\r
\r
- afile = open_save_file(fname, is_save);
\r
- if (afile == NULL)
\r
- return -1;
\r
-
\r
if (is_save)
\r
ret = state_save(afile);
\r
else {
\r
if (is_save)
\r
ret = state_save(afile);
\r
else {
\r
@@
-601,10
+608,35
@@
int PicoState(const char *fname, int is_save)
Pico.m.dirtyPal = 1;
\r
}
\r
\r
Pico.m.dirtyPal = 1;
\r
}
\r
\r
+ return ret;
\r
+}
\r
+
\r
+int PicoState(const char *fname, int is_save)
\r
+{
\r
+ void *afile = NULL;
\r
+ int ret;
\r
+
\r
+ afile = open_save_file(fname, is_save);
\r
+ if (afile == NULL)
\r
+ return -1;
\r
+
\r
+ ret = pico_state_internal(afile, is_save);
\r
areaClose(afile);
\r
return ret;
\r
}
\r
\r
areaClose(afile);
\r
return ret;
\r
}
\r
\r
+int PicoStateFP(void *afile, int is_save,
\r
+ arearw *read, arearw *write, areaeof *eof, areaseek *seek)
\r
+{
\r
+ areaRead = read;
\r
+ areaWrite = write;
\r
+ areaEof = eof;
\r
+ areaSeek = seek;
\r
+ areaClose = NULL;
\r
+
\r
+ return pico_state_internal(afile, is_save);
\r
+}
\r
+
\r
int PicoStateLoadGfx(const char *fname)
\r
{
\r
void *afile;
\r
int PicoStateLoadGfx(const char *fname)
\r
{
\r
void *afile;
\r