diff options
author | Michael Pavone <pavone@retrodev.com> | 2017-08-27 18:15:00 -0700 |
---|---|---|
committer | Michael Pavone <pavone@retrodev.com> | 2017-08-27 18:15:00 -0700 |
commit | c96509a56b532eb7aff8e589b5e76a2b7c9e943f (patch) | |
tree | 160007e470da63c1d6c9761915840937c1c0476d /xband.c | |
parent | cae76760c6f9167b71b5035326c74d7cecd3c3e8 (diff) |
Save/restore mapper state in native save states
Diffstat (limited to 'xband.c')
-rw-r--r-- | xband.c | 20 |
1 files changed, 20 insertions, 0 deletions
@@ -293,6 +293,25 @@ static uint16_t xband_reg_read_w(uint32_t address, void *context) return value; } +void xband_serialize(genesis_context *gen, serialize_buffer *buf) +{ + xband *x = get_xband(gen); + save_int8(buf, x->kill); + save_int8(buf, x->control); + save_buffer8(buf, x->regs, XBAND_REGS); +} + +void xband_deserialize(deserialize_buffer *buf, genesis_context *gen) +{ + xband *x = get_xband(gen); + x->kill = load_int8(buf); + update_control(gen, load_int8(buf)); + for (int i = 0; i < XBAND_REGS; i++) + { + xband_write_b(0x3BC001 + i*2, gen, load_int8(buf)); + } +} + rom_info xband_configure_rom(tern_node *rom_db, void *rom, uint32_t rom_size, void *lock_on, uint32_t lock_on_size, memmap_chunk const *base_map, uint32_t base_chunks) { rom_info info; @@ -334,6 +353,7 @@ rom_info xband_configure_rom(tern_node *rom_db, void *rom, uint32_t rom_size, vo byteswap_rom(0x400000, x->cart_space); + info.mapper_type = MAPPER_XBAND; info.map_chunks = base_chunks + 5; info.map = calloc(sizeof(memmap_chunk), info.map_chunks); info.map[0].mask = 0xFFFFFF; |