Mercurial > repos > blastem
diff realtec.c @ 1444:14a2834d010c
Save/restore mapper state in native save states
author | Michael Pavone <pavone@retrodev.com> |
---|---|
date | Sun, 27 Aug 2017 18:15:00 -0700 |
parents | 11ac0b511cff |
children | adb62000d296 |
line wrap: on
line diff
--- a/realtec.c Sat Aug 26 11:29:46 2017 -0700 +++ b/realtec.c Sun Aug 27 18:15:00 2017 -0700 @@ -20,6 +20,14 @@ return memcmp(rom + 0x7E100, "SEGA", 4) == 0; } +static realtec *get_realtec(genesis_context *gen) +{ + if (!gen->extra) { + gen->extra = gen->m68k->mem_pointers[0]; + } + return gen->extra; +} + static void *realtec_write_b(uint32_t address, void *context, uint8_t value) { if (address & 1) { @@ -27,12 +35,8 @@ } m68k_context *m68k = context; genesis_context *gen = m68k->system; - if (!gen->extra) { - gen->extra = m68k->mem_pointers[0]; - } - realtec *r = gen->extra; + realtec *r = get_realtec(gen); uint32_t offset = address >> 13; - uint8_t dirty = 0; if (offset < 3 && r->regs[offset] != value) { r->regs[offset] = value; //other regs are only 3 bits, so assume 3 for this one too @@ -61,6 +65,21 @@ return realtec_write_b(address, context, value >> 8); } +void realtec_serialize(genesis_context *gen, serialize_buffer *buf) +{ + realtec *r = get_realtec(gen); + save_buffer8(buf, r->regs, sizeof(r->regs)); +} + +void realtec_deserialize(deserialize_buffer *buf, genesis_context *gen) +{ + realtec *r = get_realtec(gen); + for (int i = 0; i < sizeof(r->regs); i++) + { + realtec_write_b(i << 13, gen, load_int8(buf)); + } +} + rom_info realtec_configure_rom(uint8_t *rom, uint32_t rom_size, memmap_chunk const *base_map, uint32_t base_chunks) { rom_info info; @@ -104,6 +123,7 @@ info.eeprom_map = NULL; info.rom = rom; info.rom_size = rom_size; + info.mapper_type = MAPPER_REALTEC; info.is_save_lock_on = 0; info.port1_override = info.port2_override = info.ext_override = info.mouse_mode = NULL; info.map_chunks = base_chunks + 2;