aboutsummaryrefslogtreecommitdiff
path: root/src/mapper.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/mapper.rs')
-rw-r--r--src/mapper.rs55
1 files changed, 30 insertions, 25 deletions
diff --git a/src/mapper.rs b/src/mapper.rs
index 7522454..c54acb4 100644
--- a/src/mapper.rs
+++ b/src/mapper.rs
@@ -1,40 +1,44 @@
#![allow(dead_code)]
use memory::VMem;
use cartridge::{Cartridge, BankType};
+use core::cell::RefCell;
+
pub struct Mapper2<'a> {
cart: &'a Cartridge,
- prg_bank1: &'a [u8],
- prg_bank2: &'a [u8],
- chr_bank: &'a mut [u8],
- sram: &'a mut [u8],
- bank_num: usize
+ prg_bank1: RefCell<&'a [u8]>,
+ prg_bank2: RefCell<&'a [u8]>,
+ chr_bank: RefCell<&'a mut [u8]>,
+ sram: RefCell<&'a mut [u8]>,
+ prg_nbank: usize
}
impl<'a> VMem for Mapper2<'a> {
fn read(&self, addr: u16) -> u8 {
let addr = addr as usize;
- if addr < 0x2000 {
- self.chr_bank[addr]
- } else if addr >= 0xc000 {
- self.prg_bank2[addr - 0xc000]
- } else if addr >= 0x8000 {
- self.prg_bank1[addr - 0x8000]
+ if addr < 0x2000 { /* 0x2000 size bank */
+ self.chr_bank.borrow()[addr]
+ } else if addr >= 0xc000 { /* 0x4000 size bank */
+ self.prg_bank2.borrow()[addr - 0xc000]
+ } else if addr >= 0x8000 { /* 0x4000 size bank */
+ self.prg_bank1.borrow()[addr - 0x8000]
} else if addr >= 0x6000 {
- self.sram[addr - 0x6000]
+ self.sram.borrow()[addr - 0x6000]
} else {
panic!("unmapped address: 0x{:04x}", addr)
}
}
- fn write(&mut self, addr: u16, data: u8) {
+ fn write(&self, addr: u16, data: u8) {
let addr = addr as usize;
if addr < 0x2000 {
- self.chr_bank[addr] = data;
+ self.chr_bank.borrow_mut()[addr] = data;
} else if addr >= 0x8000 {
- self.prg_bank1 = unsafe {&*self.cart.get_bank(
- data as usize % self.bank_num, BankType::PrgRom)};
+ (*self.prg_bank1.borrow_mut()) = unsafe {
+ &*self.cart.get_bank(((data as usize) % self.prg_nbank) << 14,
+ 0x4000,
+ BankType::PrgRom)};
} else if addr >= 0x6000 {
- self.sram[addr - 0x6000] = data;
+ self.sram.borrow_mut()[addr - 0x6000] = data;
} else {
panic!("invalid write to address: 0x{:04x}", addr);
}
@@ -42,15 +46,16 @@ impl<'a> VMem for Mapper2<'a> {
}
impl<'a> Mapper2<'a> {
- pub fn new(cart: &'a mut Cartridge) -> Self {
- let bank_num = cart.get_bank_num(BankType::PrgRom);
+ pub fn new(cart: *const Cartridge) -> Self {
unsafe {
- Mapper2{cart,
- prg_bank1: &*cart.get_bank(0, BankType::PrgRom),
- prg_bank2: &*cart.get_bank(bank_num - 1, BankType::PrgRom),
- chr_bank: &mut *cart.get_bank(0, BankType::ChrRom),
- sram: &mut *cart.get_bank(0, BankType::Sram),
- bank_num}
+ let cart = &*cart;
+ let nbank = cart.get_size(BankType::PrgRom) >> 14;
+ Mapper2{cart: &cart,
+ prg_bank1: RefCell::new(&*cart.get_bank(0, 0x4000, BankType::PrgRom)),
+ prg_bank2: RefCell::new(&*cart.get_bank((nbank - 1) << 14, 0x4000, BankType::PrgRom)),
+ chr_bank: RefCell::new(&mut *cart.get_bank(0, 0x2000, BankType::ChrRom)),
+ sram: RefCell::new(&mut *cart.get_bank(0, 0x2000, BankType::Sram)),
+ prg_nbank: nbank}
}
}
}