#![allow(dead_code, non_snake_case)] use super::{R6502, Bus}; // Instruction decoding: // https://llx.com/Neil/a2/opcodes.html // GROUP ONE ADDRESS MODES // 000 (zero page,X) IZX // 001 zero page ZP0 // 010 #immediate IMM // 011 absolute ABS // 100 (zero page),Y IZY // 101 zero page,X ZPX // 110 absolute,Y ABY // 111 absolute,X ABX // GROUP TWO ADDRESS MODES // 000 #immediate IMM // 001 zero page ZP0 // 010 accumulator IMP // 011 absolute ABS // 101 zero page,X ZPX // 111 absolute,X ABX pub struct AddressingModes; impl AddressingModes { pub const GROUP_ONE_ADDRS: [fn(&mut R6502, &mut dyn Bus); 8] = [ AddressingModes::IZX, AddressingModes::ZP0, AddressingModes::IMM, AddressingModes::ABS, AddressingModes::IZY, AddressingModes::ZPX, AddressingModes::ABY, AddressingModes::ABX, ]; } impl AddressingModes { // This is also the accumulator mode pub fn IMP(cpu: &mut R6502, bus: &mut dyn Bus) { } pub fn IMM(cpu: &mut R6502, bus: &mut dyn Bus) { cpu.working_data = bus.read(cpu.pc); cpu.pc += 1; } pub fn ZP0(cpu: &mut R6502, bus: &mut dyn Bus) { } pub fn ZPX(cpu: &mut R6502, bus: &mut dyn Bus) { } pub fn ZPY(cpu: &mut R6502, bus: &mut dyn Bus) { } pub fn REL(cpu: &mut R6502, bus: &mut dyn Bus) { } pub fn ABS(cpu: &mut R6502, bus: &mut dyn Bus) { } pub fn ABX(cpu: &mut R6502, bus: &mut dyn Bus) { } pub fn ABY(cpu: &mut R6502, bus: &mut dyn Bus) { } pub fn IND(cpu: &mut R6502, bus: &mut dyn Bus) { } pub fn IZX(cpu: &mut R6502, bus: &mut dyn Bus) { } pub fn IZY(cpu: &mut R6502, bus: &mut dyn Bus) { } }