flycast/core/serialize.cpp

1287 lines
30 KiB
C++
Raw Normal View History

2018-09-02 13:49:23 +00:00
// serialize.cpp : save states
#if 1
#include "types.h"
#include "hw/aica/dsp.h"
#include "hw/aica/aica.h"
#include "hw/aica/sgc_if.h"
#include "hw/holly/sb_mem.h"
#include "hw/flashrom/flashrom.h"
#include "hw/mem/_vmem.h"
#include "hw/gdrom/gdromv3.h"
#include "hw/maple/maple_cfg.h"
2018-09-02 13:49:23 +00:00
#include "hw/pvr/Renderer_if.h"
#include "hw/pvr/ta_structs.h"
#include "hw/sh4/sh4_interrupts.h"
#include "hw/sh4/sh4_sched.h"
#include "hw/sh4/sh4_mmr.h"
#include "hw/sh4/modules/mmu.h"
#include "imgread/common.h"
#include "reios/reios.h"
#include <map>
#include <set>
#include "rend/gles/gles.h"
#include "hw/sh4/dyna/blockmanager.h"
#include "hw/sh4/dyna/ngen.h"
2018-11-06 16:54:54 +00:00
#include "hw/naomi/naomi_cart.h"
2018-09-02 13:49:23 +00:00
#define REICAST_SKIP(size) do { *(u8**)data += size; *total_size += size; } while (false)
2018-09-02 13:49:23 +00:00
extern "C" void DYNACALL TAWriteSQ(u32 address,u8* sqb);
enum serialize_version_enum {
2018-10-29 14:11:34 +00:00
V1,
V2,
2018-11-06 16:54:54 +00:00
V3,
V4,
V5_LIBRETRO_UNSUPPORTED,
V6_LIBRETRO,
V5 = 800,
2018-09-02 13:49:23 +00:00
} ;
//./core/hw/arm7/arm_mem.cpp
extern bool aica_interr;
extern u32 aica_reg_L;
extern bool e68k_out;
extern u32 e68k_reg_L;
extern u32 e68k_reg_M;
//./core/hw/arm7/arm7.cpp
extern DECL_ALIGN(8) reg_pair arm_Reg[RN_ARM_REG_COUNT];
extern bool armIrqEnable;
extern bool armFiqEnable;
extern int armMode;
extern bool Arm7Enabled;
//./core/hw/aica/dsp.o
extern DECL_ALIGN(4096) dsp_t dsp;
extern AicaTimer timers[3];
//./core/hw/aica/aica_if.o
extern VLockedMemory aica_ram;
2018-09-02 13:49:23 +00:00
extern u32 VREG;//video reg =P
extern u32 ARMRST;//arm reset reg
extern u32 rtc_EN;
2018-09-20 17:48:46 +00:00
extern int dma_sched_id;
2018-09-02 13:49:23 +00:00
//./core/hw/aica/aica_mem.o
extern u8 aica_reg[0x8000];
//./core/hw/aica/sgc_if.o
struct ChannelEx;
#define AicaChannel ChannelEx
//special handling
#define Chans AicaChannel::Chans
#define CDDA_SIZE (2352/2)
extern s16 cdda_sector[CDDA_SIZE];
extern u32 cdda_index;
//./core/hw/holly/sb.o
extern Array<RegisterStruct> sb_regs;
extern u32 SB_ISTNRM;
extern u32 SB_FFST_rc;
extern u32 SB_FFST;
//./core/hw/holly/sb_mem.o
extern MemChip *sys_rom;
extern MemChip *sys_nvmem;
2018-09-02 13:49:23 +00:00
//./core/hw/gdrom/gdrom_response.o
extern u16 reply_11[] ;
//./core/hw/gdrom/gdromv3.o
extern int gdrom_schid;
extern signed int sns_asc;
extern signed int sns_ascq;
extern signed int sns_key;
extern packet_cmd_t packet_cmd;
extern u32 set_mode_offset;
extern read_params_t read_params ;
extern packet_cmd_t packet_cmd;
//Buffer for sector reads [dma]
extern read_buff_t read_buff ;
//pio buffer
extern pio_buff_t pio_buff ;
extern u32 set_mode_offset;
extern ata_cmd_t ata_cmd ;
extern cdda_t cdda ;
extern gd_states gd_state;
extern DiscType gd_disk_type;
extern u32 data_write_mode;
//Registers
extern u32 DriveSel;
extern GD_ErrRegT Error;
extern GD_InterruptReasonT IntReason;
extern GD_FeaturesT Features;
extern GD_SecCountT SecCount;
extern GD_SecNumbT SecNumber;
extern GD_StatusT GDStatus;
extern ByteCount_t ByteCount ;
//./core/hw/maple/maple_devs.o
extern char EEPROM[0x100];
extern bool EEPROM_loaded;
//./core/hw/maple/maple_if.o
2018-10-29 14:11:34 +00:00
extern int maple_schid;
2018-09-02 13:49:23 +00:00
extern bool maple_ddt_pending_reset;
2018-10-29 14:11:34 +00:00
//./core/hw/modem/modem.cpp
extern int modem_sched;
2018-09-02 13:49:23 +00:00
//./core/hw/pvr/Renderer_if.o
extern bool pend_rend;
//./core/hw/pvr/pvr_mem.o
extern u32 YUV_tempdata[512/4];//512 bytes
extern u32 YUV_dest;
extern u32 YUV_blockcount;
extern u32 YUV_x_curr;
extern u32 YUV_y_curr;
extern u32 YUV_x_size;
extern u32 YUV_y_size;
//./core/hw/pvr/pvr_regs.o
extern bool fog_needs_update;
extern u8 pvr_regs[pvr_RegSize];
//./core/hw/pvr/spg.o
extern u32 in_vblank;
extern u32 clc_pvr_scanline;
extern int render_end_schid;
extern int vblank_schid;
extern int time_sync;
//./core/hw/pvr/ta.o
extern u8 ta_fsm[2049]; //[2048] stores the current state
extern u32 ta_fsm_cl;
//./core/hw/pvr/ta_vtx.o
extern bool pal_needs_update;
//./core/rend/TexCache.o
extern VLockedMemory vram;
2018-09-02 13:49:23 +00:00
//./core/hw/sh4/sh4_mmr.o
extern Array<u8> OnChipRAM;
extern Array<RegisterStruct> CCN; //CCN : 14 registers
extern Array<RegisterStruct> UBC; //UBC : 9 registers
extern Array<RegisterStruct> BSC; //BSC : 18 registers
extern Array<RegisterStruct> DMAC; //DMAC : 17 registers
extern Array<RegisterStruct> CPG; //CPG : 5 registers
extern Array<RegisterStruct> RTC; //RTC : 16 registers
extern Array<RegisterStruct> INTC; //INTC : 4 registers
extern Array<RegisterStruct> TMU; //TMU : 12 registers
extern Array<RegisterStruct> SCI; //SCI : 8 registers
extern Array<RegisterStruct> SCIF; //SCIF : 10 registers
//./core/hw/sh4/sh4_mem.o
extern VLockedMemory mem_b;
2018-09-02 13:49:23 +00:00
//./core/hw/sh4/sh4_interrupts.o
extern DECL_ALIGN(64) u16 InterruptEnvId[32];
extern DECL_ALIGN(64) u32 InterruptBit[32];
extern DECL_ALIGN(64) u32 InterruptLevelBit[16];
extern u32 interrupt_vpend; // Vector of pending interrupts
extern u32 interrupt_vmask; // Vector of masked interrupts (-1 inhibits all interrupts)
extern u32 decoded_srimask; // Vector of interrupts allowed by SR.IMSK (-1 inhibits all interrupts)
//./core/hw/sh4/sh4_core_regs.o
extern Sh4RCB* p_sh4rcb;
//./core/hw/sh4/sh4_sched.o
extern u64 sh4_sched_ffb;
extern u32 sh4_sched_intr;
extern vector<sched_list> sch_list;
2018-09-02 13:49:23 +00:00
//./core/hw/sh4/interpr/sh4_interpreter.o
extern int aica_schid;
extern int rtc_schid;
//./core/hw/sh4/modules/serial.o
extern SCIF_SCFSR2_type SCIF_SCFSR2;
extern u8 SCIF_SCFRDR2;
extern SCIF_SCFDR2_type SCIF_SCFDR2;
//./core/hw/sh4/modules/bsc.o
extern BSC_PDTRA_type BSC_PDTRA;
//./core/hw/sh4/modules/tmu.o
extern u32 tmu_shift[3];
extern u32 tmu_mask[3];
extern u64 tmu_mask64[3];
extern u32 old_mode[3];
extern int tmu_sched[3];
extern u32 tmu_ch_base[3];
extern u64 tmu_ch_base64[3];
//./core/hw/sh4/modules/ccn.o
extern u32 CCN_QACR_TR[2];
//./core/hw/sh4/modules/mmu.o
extern TLB_Entry UTLB[64];
extern TLB_Entry ITLB[4];
#if defined(NO_MMU)
extern u32 sq_remap[64];
#else
static u32 ITLB_LRU_USE[64];
2018-09-02 13:49:23 +00:00
#endif
//./core/imgread/common.o
extern u32 NullDriveDiscType;
extern u8 q_subchannel[96];
//./core/hw/naomi/naomi.o
extern u32 GSerialBuffer;
extern u32 BSerialBuffer;
extern int GBufPos;
extern int BBufPos;
extern int GState;
extern int BState;
extern int GOldClk;
extern int BOldClk;
extern int BControl;
extern int BCmd;
extern int BLastCmd;
extern int GControl;
extern int GCmd;
extern int GLastCmd;
extern int SerStep;
extern int SerStep2;
extern unsigned char BSerial[];
extern unsigned char GSerial[];
extern u32 reg_dimm_command;
extern u32 reg_dimm_offsetl;
extern u32 reg_dimm_parameterl;
extern u32 reg_dimm_parameterh;
extern u32 reg_dimm_status;
2018-09-02 13:49:23 +00:00
extern bool NaomiDataRead;
bool rc_serialize(void *src, unsigned int src_size, void **dest, unsigned int *total_size)
{
if ( *dest != NULL )
{
memcpy(*dest, src, src_size) ;
*dest = ((unsigned char*)*dest) + src_size ;
}
*total_size += src_size ;
return true ;
}
bool rc_unserialize(void *src, unsigned int src_size, void **dest, unsigned int *total_size)
{
if ( *dest != NULL )
{
memcpy(src, *dest, src_size) ;
*dest = ((unsigned char*)*dest) + src_size ;
}
*total_size += src_size ;
return true ;
}
bool register_serialize(Array<RegisterStruct>& regs,void **data, unsigned int *total_size )
{
int i = 0 ;
for ( i = 0 ; i < regs.Size ; i++ )
{
REICAST_S(regs.data[i].data32) ;
}
return true ;
}
bool register_unserialize(Array<RegisterStruct>& regs,void **data, unsigned int *total_size, serialize_version_enum version)
2018-09-02 13:49:23 +00:00
{
int i = 0 ;
u32 dummy = 0 ;
for ( i = 0 ; i < regs.Size ; i++ )
{
if (version < V5)
REICAST_US(dummy); // regs.data[i].flags
2018-09-02 13:49:23 +00:00
if ( ! (regs.data[i].flags & REG_RF) )
REICAST_US(regs.data[i].data32) ;
else
REICAST_US(dummy) ;
}
return true ;
}
bool dc_serialize(void **data, unsigned int *total_size)
{
int i = 0;
int j = 0;
serialize_version_enum version = V5;
2018-09-02 13:49:23 +00:00
*total_size = 0 ;
//dc not initialized yet
if ( p_sh4rcb == NULL )
return false ;
REICAST_S(version) ;
REICAST_S(aica_interr) ;
REICAST_S(aica_reg_L) ;
REICAST_S(e68k_out) ;
REICAST_S(e68k_reg_L) ;
REICAST_S(e68k_reg_M) ;
REICAST_SA(arm_Reg,RN_ARM_REG_COUNT);
REICAST_S(armIrqEnable);
REICAST_S(armFiqEnable);
REICAST_S(armMode);
REICAST_S(Arm7Enabled);
REICAST_S(dsp);
for ( i = 0 ; i < 3 ; i++)
{
REICAST_S(timers[i].c_step);
REICAST_S(timers[i].m_step);
}
REICAST_SA(aica_ram.data,aica_ram.size) ;
REICAST_S(VREG);
REICAST_S(ARMRST);
REICAST_S(rtc_EN);
REICAST_SA(aica_reg,0x8000);
channel_serialize(data, total_size) ;
REICAST_SA(cdda_sector,CDDA_SIZE);
REICAST_S(cdda_index);
register_serialize(sb_regs, data, total_size) ;
REICAST_S(SB_ISTNRM);
REICAST_S(SB_FFST_rc);
REICAST_S(SB_FFST);
sys_rom->Serialize(data, total_size);
sys_nvmem->Serialize(data, total_size);
2018-09-02 13:49:23 +00:00
REICAST_SA(reply_11,16) ;
REICAST_S(sns_asc);
REICAST_S(sns_ascq);
REICAST_S(sns_key);
REICAST_S(packet_cmd);
REICAST_S(set_mode_offset);
REICAST_S(read_params);
REICAST_S(packet_cmd);
REICAST_S(read_buff);
REICAST_S(pio_buff);
REICAST_S(set_mode_offset);
REICAST_S(ata_cmd);
REICAST_S(cdda);
REICAST_S(gd_state);
REICAST_S(gd_disk_type);
REICAST_S(data_write_mode);
REICAST_S(DriveSel);
REICAST_S(Error);
2018-09-02 13:49:23 +00:00
REICAST_S(IntReason);
REICAST_S(Features);
REICAST_S(SecCount);
REICAST_S(SecNumber);
REICAST_S(GDStatus);
REICAST_S(ByteCount);
REICAST_SA(EEPROM,0x100);
REICAST_S(EEPROM_loaded);
REICAST_S(maple_ddt_pending_reset);
mcfg_SerializeDevices(data, total_size);
2018-09-02 13:49:23 +00:00
REICAST_SA(YUV_tempdata,512/4);
REICAST_S(YUV_dest);
REICAST_S(YUV_blockcount);
REICAST_S(YUV_x_curr);
REICAST_S(YUV_y_curr);
REICAST_S(YUV_x_size);
REICAST_S(YUV_y_size);
REICAST_SA(pvr_regs,pvr_RegSize);
REICAST_S(in_vblank);
REICAST_S(clc_pvr_scanline);
REICAST_S(ta_fsm[2048]);
2018-09-02 13:49:23 +00:00
REICAST_S(ta_fsm_cl);
REICAST_SA(vram.data, vram.size);
REICAST_SA(OnChipRAM.data,OnChipRAM_SIZE);
register_serialize(CCN, data, total_size) ;
register_serialize(UBC, data, total_size) ;
register_serialize(BSC, data, total_size) ;
register_serialize(DMAC, data, total_size) ;
register_serialize(CPG, data, total_size) ;
register_serialize(RTC, data, total_size) ;
register_serialize(INTC, data, total_size) ;
register_serialize(TMU, data, total_size) ;
register_serialize(SCI, data, total_size) ;
register_serialize(SCIF, data, total_size) ;
REICAST_SA(mem_b.data, mem_b.size);
REICAST_SA(InterruptEnvId,32);
REICAST_SA(InterruptBit,32);
REICAST_SA(InterruptLevelBit,16);
REICAST_S(interrupt_vpend);
REICAST_S(interrupt_vmask);
REICAST_S(decoded_srimask);
//default to nommu_full
i = 3 ;
if ( do_sqw_nommu == &do_sqw_nommu_area_3)
i = 0 ;
else if (do_sqw_nommu == &do_sqw_nommu_area_3_nonvmem)
i = 1 ;
else if (do_sqw_nommu==(sqw_fp*)&TAWriteSQ)
i = 2 ;
else if (do_sqw_nommu==&do_sqw_nommu_full)
i = 3 ;
REICAST_S(i) ;
REICAST_SA((*p_sh4rcb).sq_buffer,64/8);
REICAST_S((*p_sh4rcb).cntx);
REICAST_S(sh4_sched_ffb);
REICAST_S(sh4_sched_intr);
2018-10-29 14:11:34 +00:00
REICAST_S(sch_list[aica_schid].tag) ;
REICAST_S(sch_list[aica_schid].start) ;
REICAST_S(sch_list[aica_schid].end) ;
2018-10-29 14:11:34 +00:00
REICAST_S(sch_list[rtc_schid].tag) ;
REICAST_S(sch_list[rtc_schid].start) ;
REICAST_S(sch_list[rtc_schid].end) ;
2018-10-29 14:11:34 +00:00
REICAST_S(sch_list[gdrom_schid].tag) ;
REICAST_S(sch_list[gdrom_schid].start) ;
REICAST_S(sch_list[gdrom_schid].end) ;
2018-10-29 14:11:34 +00:00
REICAST_S(sch_list[maple_schid].tag) ;
REICAST_S(sch_list[maple_schid].start) ;
REICAST_S(sch_list[maple_schid].end) ;
2018-10-29 14:11:34 +00:00
REICAST_S(sch_list[dma_sched_id].tag) ;
REICAST_S(sch_list[dma_sched_id].start) ;
REICAST_S(sch_list[dma_sched_id].end) ;
2018-10-29 14:11:34 +00:00
for (int i = 0; i < 3; i++)
2018-09-02 13:49:23 +00:00
{
REICAST_S(sch_list[tmu_sched[i]].tag) ;
REICAST_S(sch_list[tmu_sched[i]].start) ;
REICAST_S(sch_list[tmu_sched[i]].end) ;
2018-09-02 13:49:23 +00:00
}
REICAST_S(sch_list[render_end_schid].tag) ;
REICAST_S(sch_list[render_end_schid].start) ;
REICAST_S(sch_list[render_end_schid].end) ;
2018-10-29 14:11:34 +00:00
REICAST_S(sch_list[vblank_schid].tag) ;
REICAST_S(sch_list[vblank_schid].start) ;
REICAST_S(sch_list[vblank_schid].end) ;
2018-10-29 14:11:34 +00:00
REICAST_S(sch_list[time_sync].tag) ;
REICAST_S(sch_list[time_sync].start) ;
REICAST_S(sch_list[time_sync].end) ;
2018-09-02 13:49:23 +00:00
#ifdef ENABLE_MODEM
REICAST_S(sch_list[modem_sched].tag) ;
REICAST_S(sch_list[modem_sched].start) ;
REICAST_S(sch_list[modem_sched].end) ;
#else
int modem_dummy = 0;
REICAST_S(modem_dummy);
REICAST_S(modem_dummy);
REICAST_S(modem_dummy);
#endif
2018-09-02 13:49:23 +00:00
REICAST_S(SCIF_SCFSR2);
REICAST_S(SCIF_SCFRDR2);
REICAST_S(SCIF_SCFDR2);
REICAST_S(BSC_PDTRA);
REICAST_SA(tmu_shift,3);
REICAST_SA(tmu_mask,3);
REICAST_SA(tmu_mask64,3);
REICAST_SA(old_mode,3);
REICAST_SA(tmu_ch_base,3);
REICAST_SA(tmu_ch_base64,3);
REICAST_SA(CCN_QACR_TR,2);
REICAST_SA(UTLB,64);
REICAST_SA(ITLB,4);
#if defined(NO_MMU)
REICAST_SA(sq_remap,64);
#else
REICAST_SA(ITLB_LRU_USE,64);
#endif
REICAST_S(NullDriveDiscType);
REICAST_SA(q_subchannel,96);
REICAST_S(GSerialBuffer);
REICAST_S(BSerialBuffer);
REICAST_S(GBufPos);
REICAST_S(BBufPos);
REICAST_S(GState);
REICAST_S(BState);
REICAST_S(GOldClk);
REICAST_S(BOldClk);
REICAST_S(BControl);
REICAST_S(BCmd);
REICAST_S(BLastCmd);
REICAST_S(GControl);
REICAST_S(GCmd);
REICAST_S(GLastCmd);
REICAST_S(SerStep);
REICAST_S(SerStep2);
REICAST_SA(BSerial,69);
REICAST_SA(GSerial,69);
REICAST_S(reg_dimm_command);
REICAST_S(reg_dimm_offsetl);
REICAST_S(reg_dimm_parameterl);
REICAST_S(reg_dimm_parameterh);
REICAST_S(reg_dimm_status);
2018-09-02 13:49:23 +00:00
REICAST_S(NaomiDataRead);
REICAST_S(settings.dreamcast.broadcast);
REICAST_S(settings.dreamcast.cable);
REICAST_S(settings.dreamcast.region);
2018-09-02 13:49:23 +00:00
2018-11-06 16:54:54 +00:00
if (CurrentCartridge != NULL)
CurrentCartridge->Serialize(data, total_size);
DEBUG_LOG(SAVESTATE, "Saved %d bytes", *total_size);
2018-09-02 13:49:23 +00:00
return true ;
}
static bool dc_unserialize_libretro(void **data, unsigned int *total_size)
{
int i = 0;
int j = 0;
REICAST_US(aica_interr) ;
REICAST_US(aica_reg_L) ;
REICAST_US(e68k_out) ;
REICAST_US(e68k_reg_L) ;
REICAST_US(e68k_reg_M) ;
REICAST_USA(arm_Reg,RN_ARM_REG_COUNT);
REICAST_US(armIrqEnable);
REICAST_US(armFiqEnable);
REICAST_US(armMode);
REICAST_US(Arm7Enabled);
REICAST_SKIP(256); // cpuBitsSet
bool dummy;
REICAST_US(dummy); // intState
REICAST_US(dummy); // stopState
REICAST_US(dummy); // holdState
REICAST_US(dsp);
for ( i = 0 ; i < 3 ; i++)
{
REICAST_US(timers[i].c_step);
REICAST_US(timers[i].m_step);
}
REICAST_USA(aica_ram.data,aica_ram.size) ;
REICAST_US(VREG);
REICAST_US(ARMRST);
REICAST_US(rtc_EN);
REICAST_USA(aica_reg,0x8000);
u16 dummyshort;
REICAST_SKIP(4 * 16); // volume_lut
REICAST_SKIP(4 * 256 + 768); // tl_lut. Due to a previous bug this is not 4 * (256 + 768)
REICAST_SKIP(4 * 64); // AEG_ATT_SPS
REICAST_SKIP(4 * 64); // AEG_DSR_SPS
REICAST_US(dummyshort); // pl
REICAST_US(dummyshort); // pr
channel_unserialize(data, total_size) ;
REICAST_USA(cdda_sector,CDDA_SIZE);
REICAST_US(cdda_index);
REICAST_SKIP(4 * 64); // mxlr
REICAST_US(i); // samples_gen
register_unserialize(sb_regs, data, total_size, V6_LIBRETRO) ;
REICAST_US(SB_ISTNRM);
REICAST_US(SB_FFST_rc);
REICAST_US(SB_FFST);
REICAST_US(i); //LIBRETRO_S(sys_nvmem_sram.size);
verify(i == 0);
REICAST_US(i); //LIBRETRO_S(sys_nvmem_sram.mask);
//LIBRETRO_SA(sys_nvmem_sram.data,sys_nvmem_sram.size);
REICAST_US(sys_nvmem->size);
REICAST_US(sys_nvmem->mask);
if (settings.platform.system == DC_PLATFORM_DREAMCAST)
REICAST_US(static_cast<DCFlashChip*>(sys_nvmem)->state);
else
// FIXME
die("Naomi/Atomiswave libretro savestates are not supported");
REICAST_USA(sys_nvmem->data, sys_nvmem->size);
REICAST_USA(reply_11,16);
REICAST_US(sns_asc);
REICAST_US(sns_ascq);
REICAST_US(sns_key);
REICAST_US(packet_cmd);
REICAST_US(set_mode_offset);
REICAST_US(read_params);
REICAST_US(packet_cmd);
REICAST_US(read_buff);
REICAST_US(pio_buff);
REICAST_US(set_mode_offset);
REICAST_US(ata_cmd);
REICAST_US(cdda);
REICAST_US(gd_state);
REICAST_US(gd_disk_type);
REICAST_US(data_write_mode);
REICAST_US(DriveSel);
REICAST_US(Error);
REICAST_US(IntReason);
REICAST_US(Features);
REICAST_US(SecCount);
REICAST_US(SecNumber);
REICAST_US(GDStatus);
REICAST_US(ByteCount);
REICAST_US(i); // GDROM_TICK
REICAST_USA(EEPROM,0x100);
REICAST_US(EEPROM_loaded);
bool dumbool;
REICAST_US(maple_ddt_pending_reset);
mcfg_UnserializeDevices(data, total_size, false);
REICAST_US(i); // FrameCount
REICAST_US(dumbool); // pend_rend
pend_rend = false;
REICAST_USA(YUV_tempdata,512/4);
REICAST_US(YUV_dest);
REICAST_US(YUV_blockcount);
REICAST_US(YUV_x_curr);
REICAST_US(YUV_y_curr);
REICAST_US(YUV_x_size);
REICAST_US(YUV_y_size);
REICAST_US(dumbool); // fog_needs_update
REICAST_USA(pvr_regs,pvr_RegSize);
fog_needs_update = true ;
REICAST_US(in_vblank);
REICAST_US(clc_pvr_scanline);
REICAST_US(i); // pvr_numscanlines
REICAST_US(i); // prv_cur_scanline
REICAST_US(i); // vblk_cnt
REICAST_US(i); // Line_Cycles
REICAST_US(i); // Frame_Cycles
REICAST_SKIP(8); // speed_load_mspdf
REICAST_US(i); // mips_counter
REICAST_SKIP(8); // full_rps
REICAST_SKIP(4 * 256); // ta_type_lut
REICAST_USA(ta_fsm,2049);
REICAST_US(ta_fsm_cl);
REICAST_US(dumbool); // pal_needs_update
for (int i = 0; i < 4; i++) REICAST_US(j); // _pal_rev_256
for (int i = 0; i < 64; i++) REICAST_US(j); // _pal_rev_16
for (int i = 0; i < 4; i++) REICAST_US(j); // pal_rev_256
for (int i = 0; i < 64; i++) REICAST_US(j); // pal_rev_16
for ( i = 0 ; i < 3 ; i++ )
{
u32 buf[65536]; //u32 *ptr = decoded_colors[i] ;
REICAST_US(buf); //LIBRETRO_SA(ptr,65536);
}
REICAST_US(i); // tileclip_val
REICAST_SKIP(65536); // f32_su8_tbl
REICAST_SKIP(4); // FaceBaseColor
REICAST_SKIP(4); // FaceOffsColor
REICAST_US(i); // SFaceBaseColor
REICAST_US(i); // SFaceOffsColor
pal_needs_update = true;
REICAST_US(i); // palette_index
REICAST_US(dumbool); // KillTex
REICAST_SKIP(4 * 1024); // palette16_ram
REICAST_SKIP(4 * 1024); // palette32_ram
REICAST_SKIP(2 * 8 * 4 * 1024); // detwiddle[][]
REICAST_USA(vram.data, vram.size);
REICAST_USA(OnChipRAM.data,OnChipRAM_SIZE);
register_unserialize(CCN, data, total_size, V6_LIBRETRO) ;
register_unserialize(UBC, data, total_size, V6_LIBRETRO) ;
register_unserialize(BSC, data, total_size, V6_LIBRETRO) ;
register_unserialize(DMAC, data, total_size, V6_LIBRETRO) ;
register_unserialize(CPG, data, total_size, V6_LIBRETRO) ;
register_unserialize(RTC, data, total_size, V6_LIBRETRO) ;
register_unserialize(INTC, data, total_size, V6_LIBRETRO) ;
register_unserialize(TMU, data, total_size, V6_LIBRETRO) ;
register_unserialize(SCI, data, total_size, V6_LIBRETRO) ;
register_unserialize(SCIF, data, total_size, V6_LIBRETRO) ;
REICAST_USA(mem_b.data, mem_b.size);
REICAST_US(dummyshort); // IRLPriority
REICAST_USA(InterruptEnvId,32);
REICAST_USA(InterruptBit,32);
REICAST_USA(InterruptLevelBit,16);
REICAST_US(interrupt_vpend);
REICAST_US(interrupt_vmask);
REICAST_US(decoded_srimask);
REICAST_US(i) ;
if ( i == 0 )
do_sqw_nommu = &do_sqw_nommu_area_3 ;
else if ( i == 1 )
do_sqw_nommu = &do_sqw_nommu_area_3_nonvmem ;
else if ( i == 2 )
do_sqw_nommu = (sqw_fp*)&TAWriteSQ ;
else if ( i == 3 )
do_sqw_nommu = &do_sqw_nommu_full ;
REICAST_USA((*p_sh4rcb).sq_buffer,64/8);
REICAST_US((*p_sh4rcb).cntx);
REICAST_US(i); // old_rm
REICAST_US(i); // old_dn
REICAST_US(sh4_sched_ffb);
REICAST_US(sh4_sched_intr);
REICAST_US(sch_list[aica_schid].tag) ;
REICAST_US(sch_list[aica_schid].start) ;
REICAST_US(sch_list[aica_schid].end) ;
REICAST_US(sch_list[rtc_schid].tag) ;
REICAST_US(sch_list[rtc_schid].start) ;
REICAST_US(sch_list[rtc_schid].end) ;
REICAST_US(sch_list[gdrom_schid].tag) ;
REICAST_US(sch_list[gdrom_schid].start) ;
REICAST_US(sch_list[gdrom_schid].end) ;
REICAST_US(sch_list[maple_schid].tag) ;
REICAST_US(sch_list[maple_schid].start) ;
REICAST_US(sch_list[maple_schid].end) ;
REICAST_US(sch_list[dma_sched_id].tag) ;
REICAST_US(sch_list[dma_sched_id].start) ;
REICAST_US(sch_list[dma_sched_id].end) ;
for (int i = 0; i < 3; i++)
{
REICAST_US(sch_list[tmu_sched[i]].tag) ;
REICAST_US(sch_list[tmu_sched[i]].start) ;
REICAST_US(sch_list[tmu_sched[i]].end) ;
}
REICAST_US(sch_list[render_end_schid].tag) ;
REICAST_US(sch_list[render_end_schid].start) ;
REICAST_US(sch_list[render_end_schid].end) ;
REICAST_US(sch_list[vblank_schid].tag) ;
REICAST_US(sch_list[vblank_schid].start) ;
REICAST_US(sch_list[vblank_schid].end) ;
REICAST_US(sch_list[time_sync].tag) ;
REICAST_US(sch_list[time_sync].start) ;
REICAST_US(sch_list[time_sync].end) ;
#ifdef ENABLE_MODEM
REICAST_US(sch_list[modem_sched].tag) ;
REICAST_US(sch_list[modem_sched].start) ;
REICAST_US(sch_list[modem_sched].end) ;
#else
int modem_dummy;
REICAST_US(modem_dummy);
REICAST_US(modem_dummy);
REICAST_US(modem_dummy);
#endif
REICAST_US(SCIF_SCFSR2);
REICAST_US(SCIF_SCFRDR2);
REICAST_US(SCIF_SCFDR2);
REICAST_US(BSC_PDTRA);
REICAST_USA(tmu_shift,3);
REICAST_USA(tmu_mask,3);
REICAST_USA(tmu_mask64,3);
REICAST_USA(old_mode,3);
REICAST_USA(tmu_ch_base,3);
REICAST_USA(tmu_ch_base64,3);
REICAST_USA(CCN_QACR_TR,2);
REICAST_USA(UTLB, 64);
REICAST_USA(ITLB, 4);
#if defined(NO_MMU)
REICAST_USA(sq_remap,64);
#else
REICAST_USA(ITLB_LRU_USE,64);
REICAST_US(i); // mmu_error_TT
#endif
REICAST_US(NullDriveDiscType);
REICAST_USA(q_subchannel,96);
REICAST_US(i); // FLASH_SIZE
REICAST_US(i); // BBSRAM_SIZE
REICAST_US(i); // BIOS_SIZE
REICAST_US(i); // RAM_SIZE
REICAST_US(i); // ARAM_SIZE
REICAST_US(i); // VRAM_SIZE
REICAST_US(i); // RAM_MASK
REICAST_US(i); // ARAM_MASK
REICAST_US(i); // VRAM_MASK
REICAST_US(i); // naomi_updates
REICAST_US(i); // BoardID
REICAST_US(GSerialBuffer);
REICAST_US(BSerialBuffer);
REICAST_US(GBufPos);
REICAST_US(BBufPos);
REICAST_US(GState);
REICAST_US(BState);
REICAST_US(GOldClk);
REICAST_US(BOldClk);
REICAST_US(BControl);
REICAST_US(BCmd);
REICAST_US(BLastCmd);
REICAST_US(GControl);
REICAST_US(GCmd);
REICAST_US(GLastCmd);
REICAST_US(SerStep);
REICAST_US(SerStep2);
REICAST_USA(BSerial,69);
REICAST_USA(GSerial,69);
REICAST_US(reg_dimm_command);
REICAST_US(reg_dimm_offsetl);
REICAST_US(reg_dimm_parameterl);
REICAST_US(reg_dimm_parameterh);
REICAST_US(reg_dimm_status);
REICAST_US(NaomiDataRead);
REICAST_US(i); //LIBRETRO_S(cycle_counter);
#if FEAT_SHREC == DYNAREC_CPP
REICAST_US(idxnxx);
#else
REICAST_US(i);
#endif
REICAST_SKIP(sizeof(state_t)); // state
REICAST_US(i); // div_som_reg1
REICAST_US(i); // div_som_reg2
REICAST_US(i); // div_som_reg3
REICAST_US(i); // LastAddr
REICAST_US(i); // LastAddr_min
REICAST_SKIP(1024); // block_hash
for (int i = 0; i < sh4_reg_count; i++) // RegisterRead, RegisterWrite
{
REICAST_US(j);
REICAST_US(j);
}
REICAST_US(i); // fallback_blocks);
REICAST_US(i); // total_blocks);
REICAST_US(i); // REMOVED_OPS
REICAST_US(settings.dreamcast.broadcast);
REICAST_US(settings.dreamcast.cable);
REICAST_US(settings.dreamcast.region);
if (CurrentCartridge != NULL)
CurrentCartridge->Unserialize(data, total_size);
DEBUG_LOG(SAVESTATE, "Loaded %d bytes (libretro compat)", *total_size);
return true ;
}
2018-09-02 13:49:23 +00:00
bool dc_unserialize(void **data, unsigned int *total_size)
{
int i = 0;
int j = 0;
serialize_version_enum version = V1 ;
*total_size = 0 ;
REICAST_US(version) ;
if (version == V6_LIBRETRO)
return dc_unserialize_libretro(data, total_size);
if (version != V4 && version != V5)
2018-10-29 14:11:34 +00:00
{
WARN_LOG(SAVESTATE, "Save State version not supported: %d", version);
2018-10-29 14:11:34 +00:00
return false;
}
2018-09-02 13:49:23 +00:00
REICAST_US(aica_interr) ;
REICAST_US(aica_reg_L) ;
REICAST_US(e68k_out) ;
REICAST_US(e68k_reg_L) ;
REICAST_US(e68k_reg_M) ;
REICAST_USA(arm_Reg,RN_ARM_REG_COUNT);
REICAST_US(armIrqEnable);
REICAST_US(armFiqEnable);
REICAST_US(armMode);
REICAST_US(Arm7Enabled);
if (version < 5)
REICAST_SKIP(256 + 3);
2018-09-02 13:49:23 +00:00
REICAST_US(dsp);
for ( i = 0 ; i < 3 ; i++)
{
REICAST_US(timers[i].c_step);
REICAST_US(timers[i].m_step);
}
REICAST_USA(aica_ram.data,aica_ram.size) ;
REICAST_US(VREG);
REICAST_US(ARMRST);
REICAST_US(rtc_EN);
REICAST_USA(aica_reg,0x8000);
if (version < V5)
{
REICAST_SKIP(4 * 16);
REICAST_SKIP(4 * 256 + 768);
REICAST_SKIP(4 * 64);
REICAST_SKIP(4 * 64);
REICAST_SKIP(2);
REICAST_SKIP(2);
}
2018-09-02 13:49:23 +00:00
channel_unserialize(data, total_size) ;
REICAST_USA(cdda_sector,CDDA_SIZE);
REICAST_US(cdda_index);
if (version < V5)
{
REICAST_SKIP(4 * 64);
REICAST_SKIP(4);
}
2018-09-02 13:49:23 +00:00
register_unserialize(sb_regs, data, total_size, version) ;
2018-09-02 13:49:23 +00:00
REICAST_US(SB_ISTNRM);
REICAST_US(SB_FFST_rc);
REICAST_US(SB_FFST);
if (version < V5)
{
REICAST_SKIP(4); // size
REICAST_SKIP(4); // mask
}
sys_rom->Unserialize(data, total_size);
sys_nvmem->Unserialize(data, total_size);
2018-09-02 13:49:23 +00:00
REICAST_USA(reply_11,16) ;
REICAST_US(sns_asc);
REICAST_US(sns_ascq);
REICAST_US(sns_key);
REICAST_US(packet_cmd);
REICAST_US(set_mode_offset);
REICAST_US(read_params);
REICAST_US(packet_cmd);
REICAST_US(read_buff);
REICAST_US(pio_buff);
REICAST_US(set_mode_offset);
REICAST_US(ata_cmd);
REICAST_US(cdda);
REICAST_US(gd_state);
REICAST_US(gd_disk_type);
REICAST_US(data_write_mode);
REICAST_US(DriveSel);
REICAST_US(Error);
REICAST_US(IntReason);
REICAST_US(Features);
REICAST_US(SecCount);
REICAST_US(SecNumber);
REICAST_US(GDStatus);
REICAST_US(ByteCount);
REICAST_USA(EEPROM,0x100);
REICAST_US(EEPROM_loaded);
REICAST_US(maple_ddt_pending_reset);
mcfg_UnserializeDevices(data, total_size, version < 5);
2018-09-02 13:49:23 +00:00
if (version < V5)
{
REICAST_SKIP(4);
REICAST_SKIP(1); // pend_rend
}
pend_rend = false;
2018-09-02 13:49:23 +00:00
REICAST_USA(YUV_tempdata,512/4);
REICAST_US(YUV_dest);
REICAST_US(YUV_blockcount);
REICAST_US(YUV_x_curr);
REICAST_US(YUV_y_curr);
REICAST_US(YUV_x_size);
REICAST_US(YUV_y_size);
REICAST_USA(pvr_regs,pvr_RegSize);
fog_needs_update = true ;
REICAST_US(in_vblank);
REICAST_US(clc_pvr_scanline);
if (version < V5)
{
REICAST_US(i); // pvr_numscanlines
REICAST_US(i); // prv_cur_scanline
REICAST_US(i); // vblk_cnt
REICAST_US(i); // Line_Cycles
REICAST_US(i); // Frame_Cycles
REICAST_SKIP(8); // speed_load_mspdf
REICAST_US(i); // mips_counter
REICAST_SKIP(8); // full_rps
REICAST_US(i); // fskip
REICAST_SKIP(4 * 256);
REICAST_SKIP(2048); // ta_fsm
}
REICAST_US(ta_fsm[2048]);
2018-09-02 13:49:23 +00:00
REICAST_US(ta_fsm_cl);
if (version < V5)
{
REICAST_SKIP(4);
REICAST_SKIP(65536);
REICAST_SKIP(4);
REICAST_SKIP(4);
REICAST_SKIP(4);
REICAST_SKIP(4);
}
2018-09-20 17:48:46 +00:00
pal_needs_update = true;
2018-09-02 13:49:23 +00:00
REICAST_USA(vram.data, vram.size);
2018-09-02 13:49:23 +00:00
REICAST_USA(OnChipRAM.data,OnChipRAM_SIZE);
register_unserialize(CCN, data, total_size, version) ;
register_unserialize(UBC, data, total_size, version) ;
register_unserialize(BSC, data, total_size, version) ;
register_unserialize(DMAC, data, total_size, version) ;
register_unserialize(CPG, data, total_size, version) ;
register_unserialize(RTC, data, total_size, version) ;
register_unserialize(INTC, data, total_size, version) ;
register_unserialize(TMU, data, total_size, version) ;
register_unserialize(SCI, data, total_size, version) ;
register_unserialize(SCIF, data, total_size, version) ;
2018-09-02 13:49:23 +00:00
REICAST_USA(mem_b.data, mem_b.size);
if (version < V5)
REICAST_SKIP(2);
2018-09-02 13:49:23 +00:00
REICAST_USA(InterruptEnvId,32);
REICAST_USA(InterruptBit,32);
REICAST_USA(InterruptLevelBit,16);
REICAST_US(interrupt_vpend);
REICAST_US(interrupt_vmask);
REICAST_US(decoded_srimask);
REICAST_US(i) ;
if ( i == 0 )
do_sqw_nommu = &do_sqw_nommu_area_3 ;
else if ( i == 1 )
do_sqw_nommu = &do_sqw_nommu_area_3_nonvmem ;
else if ( i == 2 )
do_sqw_nommu = (sqw_fp*)&TAWriteSQ ;
else if ( i == 3 )
do_sqw_nommu = &do_sqw_nommu_full ;
REICAST_USA((*p_sh4rcb).sq_buffer,64/8);
REICAST_US((*p_sh4rcb).cntx);
if (version < V5)
{
REICAST_SKIP(4);
REICAST_SKIP(4);
}
2018-09-02 13:49:23 +00:00
REICAST_US(sh4_sched_ffb);
REICAST_US(sh4_sched_intr);
2018-10-29 14:11:34 +00:00
REICAST_US(sch_list[aica_schid].tag) ;
REICAST_US(sch_list[aica_schid].start) ;
REICAST_US(sch_list[aica_schid].end) ;
2018-10-29 14:11:34 +00:00
REICAST_US(sch_list[rtc_schid].tag) ;
REICAST_US(sch_list[rtc_schid].start) ;
REICAST_US(sch_list[rtc_schid].end) ;
2018-10-29 14:11:34 +00:00
REICAST_US(sch_list[gdrom_schid].tag) ;
REICAST_US(sch_list[gdrom_schid].start) ;
REICAST_US(sch_list[gdrom_schid].end) ;
2018-10-29 14:11:34 +00:00
REICAST_US(sch_list[maple_schid].tag) ;
REICAST_US(sch_list[maple_schid].start) ;
REICAST_US(sch_list[maple_schid].end) ;
2018-10-29 14:11:34 +00:00
REICAST_US(sch_list[dma_sched_id].tag) ;
REICAST_US(sch_list[dma_sched_id].start) ;
REICAST_US(sch_list[dma_sched_id].end) ;
2018-10-29 14:11:34 +00:00
for (int i = 0; i < 3; i++)
2018-09-02 13:49:23 +00:00
{
REICAST_US(sch_list[tmu_sched[i]].tag) ;
REICAST_US(sch_list[tmu_sched[i]].start) ;
REICAST_US(sch_list[tmu_sched[i]].end) ;
2018-09-02 13:49:23 +00:00
}
REICAST_US(sch_list[render_end_schid].tag) ;
REICAST_US(sch_list[render_end_schid].start) ;
REICAST_US(sch_list[render_end_schid].end) ;
2018-10-29 14:11:34 +00:00
REICAST_US(sch_list[vblank_schid].tag) ;
REICAST_US(sch_list[vblank_schid].start) ;
REICAST_US(sch_list[vblank_schid].end) ;
2018-10-29 14:11:34 +00:00
REICAST_US(sch_list[time_sync].tag) ;
REICAST_US(sch_list[time_sync].start) ;
REICAST_US(sch_list[time_sync].end) ;
2018-09-02 13:49:23 +00:00
#ifdef ENABLE_MODEM
REICAST_US(sch_list[modem_sched].tag) ;
REICAST_US(sch_list[modem_sched].start) ;
REICAST_US(sch_list[modem_sched].end) ;
#else
int modem_dummy;
REICAST_US(modem_dummy);
REICAST_US(modem_dummy);
REICAST_US(modem_dummy);
#endif
2018-09-02 13:49:23 +00:00
REICAST_US(SCIF_SCFSR2);
REICAST_US(SCIF_SCFRDR2);
REICAST_US(SCIF_SCFDR2);
REICAST_US(BSC_PDTRA);
REICAST_USA(tmu_shift,3);
REICAST_USA(tmu_mask,3);
REICAST_USA(tmu_mask64,3);
REICAST_USA(old_mode,3);
REICAST_USA(tmu_ch_base,3);
REICAST_USA(tmu_ch_base64,3);
REICAST_USA(CCN_QACR_TR,2);
REICAST_USA(UTLB,64);
REICAST_USA(ITLB,4);
#if defined(NO_MMU)
REICAST_USA(sq_remap,64);
#else
REICAST_USA(ITLB_LRU_USE,64);
#endif
REICAST_US(NullDriveDiscType);
REICAST_USA(q_subchannel,96);
if (version < V5)
{
REICAST_SKIP(4);
REICAST_SKIP(4);
}
2018-09-02 13:49:23 +00:00
REICAST_US(GSerialBuffer);
REICAST_US(BSerialBuffer);
REICAST_US(GBufPos);
REICAST_US(BBufPos);
REICAST_US(GState);
REICAST_US(BState);
REICAST_US(GOldClk);
REICAST_US(BOldClk);
REICAST_US(BControl);
REICAST_US(BCmd);
REICAST_US(BLastCmd);
REICAST_US(GControl);
REICAST_US(GCmd);
REICAST_US(GLastCmd);
REICAST_US(SerStep);
REICAST_US(SerStep2);
REICAST_USA(BSerial,69);
REICAST_USA(GSerial,69);
REICAST_US(reg_dimm_command);
REICAST_US(reg_dimm_offsetl);
REICAST_US(reg_dimm_parameterl);
REICAST_US(reg_dimm_parameterh);
REICAST_US(reg_dimm_status);
2018-09-02 13:49:23 +00:00
REICAST_US(NaomiDataRead);
if (version < V5)
{
REICAST_US(i); // idxnxx
REICAST_SKIP(sizeof(state_t));
REICAST_SKIP(4);
REICAST_SKIP(4);
REICAST_SKIP(4);
REICAST_SKIP(4);
REICAST_SKIP(4);
REICAST_SKIP(1024);
REICAST_SKIP(8 * sh4_reg_count);
REICAST_SKIP(4);
REICAST_SKIP(4);
REICAST_SKIP(4);
REICAST_SKIP(2 * 4);
REICAST_SKIP(4);
REICAST_SKIP(4);
REICAST_SKIP(4 * 4);
REICAST_SKIP(4);
REICAST_SKIP(4);
}
REICAST_US(settings.dreamcast.broadcast);
REICAST_US(settings.dreamcast.cable);
REICAST_US(settings.dreamcast.region);
2018-11-06 16:54:54 +00:00
if (CurrentCartridge != NULL)
CurrentCartridge->Unserialize(data, total_size);
DEBUG_LOG(SAVESTATE, "Loaded %d bytes", *total_size);
2018-09-02 13:49:23 +00:00
return true ;
}
#endif