diff options
| author | Peter Fors <peter.fors@mindkiller.com> | 2025-05-02 23:15:47 +0200 |
|---|---|---|
| committer | Peter Fors <peter.fors@mindkiller.com> | 2025-05-02 23:15:47 +0200 |
| commit | 5808f00555c48e1cc1cc110af6a5cd73ddf13010 (patch) | |
| tree | dff942b61441bafe297e7a99f0e799f32ae978b1 /mappers/mapper_011_0.c | |
| parent | 9463faa436e1b981ef72000568445a83682f2658 (diff) | |
cleanup and rewrite of ppu_registers.c
Diffstat (limited to 'mappers/mapper_011_0.c')
| -rw-r--r-- | mappers/mapper_011_0.c | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/mappers/mapper_011_0.c b/mappers/mapper_011_0.c new file mode 100644 index 0000000..ce390a0 --- /dev/null +++ b/mappers/mapper_011_0.c @@ -0,0 +1,37 @@ + + +static uint8_t mapper_011_0_prg_read(struct nes_state *state, uint32_t addr) { + struct mapper_011_0 *mapper = (struct mapper_011_0 *)&state->map; + + if(addr >= 0x8000) { + return mapper->prg_rom[addr - 0x8000]; + } + return 0; +} + +static void mapper_011_0_prg_write(struct nes_state *state, uint32_t addr, uint8_t value) { + struct mapper_011_0 *mapper = (struct mapper_011_0 *)&state->map; + + if(addr >= 0x8000) { + mapper->prg_rom = state->prg_rom + ((value >> 4) & 7) * 0x8000; + mapper->chr_ptr = state->chr_rom + (value & 0x0F) * 0x2000; + } +} + +static uint8_t mapper_011_0_chr_read(struct nes_state *state, uint32_t addr) { + struct mapper_011_0 *mapper = (struct mapper_011_0 *)&state->map; + + return mapper->chr_ptr[addr]; +} + +static void mapper_011_0_init(struct nes_state *state) { + struct mapper_011_0 *mapper = (struct mapper_011_0 *)&state->map; + + mapper->prg_rom = state->prg_rom; + mapper->chr_ptr = state->chr_rom; + + state->mapper.prg_read = mapper_011_0_prg_read; + state->mapper.prg_write = mapper_011_0_prg_write; + state->mapper.chr_read = mapper_011_0_chr_read; +} + |
