1
0
mirror of https://github.com/mre/mos6502.git synced 2024-11-28 07:49:19 +00:00

Fix breaking changes.

This commit is contained in:
Andrew Keeton 2015-01-17 17:53:21 -05:00
parent bd30f8c6cc
commit 5e4dc965bf
8 changed files with 58 additions and 48 deletions

View File

@ -38,3 +38,6 @@ name = "emu6502"
# This will look in src/bin/emu6502.rs
name = "emu6502"
[dependencies]
log = "0.1.0"

View File

@ -26,17 +26,20 @@
// POSSIBILITY OF SUCH DAMAGE.
use std::num::Int;
use std::ops::Add;
// The idea here is that it doesn't make sense to add two addresses, but it
// does make sense to add an address and an "address-difference". (If this
// is too annoying to work with we should let it go.)
#[deriving(Copy, PartialEq, Eq, PartialOrd, Ord, Show)]
#[derive(Copy, PartialEq, Eq, PartialOrd, Ord, Show)]
pub struct AddressDiff(pub i32);
#[deriving(Copy, PartialEq, Eq, PartialOrd, Ord, Show)]
#[derive(Copy, PartialEq, Eq, PartialOrd, Ord, Show)]
pub struct Address(pub u16);
impl Add<AddressDiff, Address> for Address {
impl Add<AddressDiff> for Address {
type Output = Address;
fn add(self, AddressDiff(rhs): AddressDiff) -> Address {
let Address(lhs) = self;
@ -45,17 +48,21 @@ impl Add<AddressDiff, Address> for Address {
}
}
impl Add<AddressDiff, AddressDiff> for AddressDiff {
impl Add for AddressDiff {
type Output = AddressDiff;
fn add(self, AddressDiff(rhs): AddressDiff) -> AddressDiff {
let AddressDiff(lhs) = self;
AddressDiff(lhs + rhs)
}
}
#[deriving(Copy, PartialEq, Eq, PartialOrd, Ord)]
#[derive(Copy, PartialEq, Eq, PartialOrd, Ord)]
pub struct CheckedAddressDiff(u16);
impl Add<CheckedAddressDiff, Address> for Address {
impl Add<CheckedAddressDiff> for Address {
type Output = Address;
fn add(self, CheckedAddressDiff(rhs): CheckedAddressDiff) -> Address {
let Address(lhs) = self;
@ -74,8 +81,8 @@ impl Address {
}
}
pub fn to_uint(&self) -> uint {
self.to_u16() as uint
pub fn to_usize(&self) -> usize {
self.to_u16() as usize
}
pub fn get_page_number(&self) -> u8 {

View File

@ -42,7 +42,7 @@ fn main() {
// JAM: FIXME: What's the syntax for specifying the array element type,
// but not the length? (For a fixed-size array)
let zero_page_data: [u8, ..17] = [
let zero_page_data: [u8; 17] = [
// ZeroPage data start
0x00,
0x02, // ADC ZeroPage target
@ -63,7 +63,7 @@ fn main() {
0x80, // ADC IndirectIndexedY address
];
let program: [u8, ..33] = [
let program: [u8; 33] = [
// Code start
0xA9, // LDA Immediate
0x01, // Immediate operand
@ -115,7 +115,7 @@ fn main() {
0xFF, // Something invalid -- the end!
];
let data: [u8, ..25] = [
let data: [u8; 25] = [
0x00,
0x09, // ADC Absolute target
0x00,
@ -151,6 +151,6 @@ fn main() {
machine.run();
println!("{}", machine);
println!("{:?}", machine);
}

View File

@ -46,7 +46,7 @@ use machine::Machine;
// PC | program counter
//
#[deriving(Copy, Show, PartialEq, Eq)]
#[derive(Copy, Show, PartialEq, Eq)]
pub enum Instruction
// i/o vars should be listed as follows:
// NV BDIZC A X Y S PC M
@ -113,7 +113,7 @@ pub enum Instruction
, TYA // Transfer Y to Accumulator..... | N. ...Z. A = Y
}
#[deriving(Copy)]
#[derive(Copy)]
pub enum OpInput {
UseImplied,
UseImmediate(u8),
@ -121,7 +121,7 @@ pub enum OpInput {
UseAddress(Address),
}
#[deriving(Copy)]
#[derive(Copy)]
pub enum AddressingMode
// length
{ Accumulator // 1 LSR A work directly on accumulator
@ -144,7 +144,7 @@ pub enum AddressingMode
fn arr_to_addr(arr: &[u8]) -> Address {
debug_assert!(arr.len() == 2);
let x = (arr[0] as u16) + (arr[1] as u16 << 8u);
let x = (arr[0] as u16) + ((arr[1] as u16) << 8us);
Address(x)
}
@ -171,7 +171,7 @@ impl AddressingMode {
pub fn process(self, machine: &Machine, arr: &[u8]) -> OpInput {
debug_assert!({let AddressDiff(x) = self.extra_bytes();
arr.len() == x as uint});
arr.len() == x as usize});
let x = machine.registers.index_x as u8;
let y = machine.registers.index_y as u8;
@ -258,7 +258,7 @@ impl AddressingMode {
pub type DecodedInstr = (Instruction, OpInput);
pub static OPCODES: [Option<(Instruction, AddressingMode)>, ..256] = [
pub static OPCODES: [Option<(Instruction, AddressingMode)>; 256] = [
/*0x00*/ Some((Instruction::BRK, AddressingMode::Implied)),
/*0x01*/ Some((Instruction::ORA, AddressingMode::IndexedIndirectX)),
/*0x02*/ None,

View File

@ -26,9 +26,7 @@
// POSSIBILITY OF SUCH DAMAGE.
// Needed for debug! / log! macros
#![feature(phase)]
#[phase(plugin, link)]
#[macro_use]
extern crate log;
pub mod address;
@ -36,4 +34,3 @@ pub mod instruction;
pub mod machine;
pub mod memory;
pub mod registers;

View File

@ -35,7 +35,7 @@ use registers::{ Registers, StackPointer, Status, StatusArgs };
use registers::{ PS_NEGATIVE, PS_DECIMAL_MODE, PS_OVERFLOW, PS_ZERO, PS_CARRY,
PS_DISABLE_INTERRUPTS };
#[deriving(Copy)]
#[derive(Copy)]
pub struct Machine {
pub registers: Registers,
pub memory: Memory
@ -56,7 +56,7 @@ impl Machine {
pub fn fetch_next_and_decode(&mut self) -> Option<DecodedInstr> {
let x: u8 = self.memory.get_byte(self.registers.program_counter);
match instruction::OPCODES[x as uint] {
match instruction::OPCODES[x as usize] {
Some((instr, am)) => {
let extra_bytes = am.extra_bytes();
let num_bytes = AddressDiff(1) + extra_bytes;
@ -85,7 +85,7 @@ impl Machine {
}
(Instruction::ADC, OpInput::UseAddress(addr)) => {
let val = self.memory.get_byte(addr) as i8;
debug!("add with carry. address: {}. value: {}", addr, val);
debug!("add with carry. address: {:?}. value: {}", addr, val);
self.add_with_carry(val);
}
@ -154,7 +154,7 @@ impl Machine {
(Instruction::BMI, OpInput::UseRelative(rel)) => {
let addr = self.registers.program_counter
+ AddressDiff(rel as i32);
debug!("branch if minus relative. address: {}", addr);
debug!("branch if minus relative. address: {:?}", addr);
self.branch_if_minus(addr);
}
@ -255,7 +255,7 @@ impl Machine {
}
(Instruction::LDA, OpInput::UseAddress(addr)) => {
let val = self.memory.get_byte(addr);
debug!("load A. address: {}. value: {}", addr, val);
debug!("load A. address: {:?}. value: {}", addr, val);
self.load_accumulator(val as i8);
}
@ -265,7 +265,7 @@ impl Machine {
}
(Instruction::LDX, OpInput::UseAddress(addr)) => {
let val = self.memory.get_byte(addr);
debug!("load X. address: {}. value: {}", addr, val);
debug!("load X. address: {:?}. value: {}", addr, val);
self.load_x_register(val as i8);
}
@ -275,7 +275,7 @@ impl Machine {
}
(Instruction::LDY, OpInput::UseAddress(addr)) => {
let val = self.memory.get_byte(addr);
debug!("load Y. address: {}. value: {}", addr, val);
debug!("load Y. address: {:?}. value: {}", addr, val);
self.load_y_register(val as i8);
}
@ -355,7 +355,7 @@ impl Machine {
}
(Instruction::SBC, OpInput::UseAddress(addr)) => {
let val = self.memory.get_byte(addr) as i8;
debug!("subtract with carry. address: {}. value: {}",
debug!("subtract with carry. address: {:?}. value: {}",
addr, val);
self.subtract_with_carry(val);
}
@ -729,6 +729,7 @@ impl Machine {
}
}
#[allow(unstable)]
impl std::fmt::Show for Machine {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
write!(f, "Machine Dump:\n\nAccumulator: {}",
@ -1128,8 +1129,8 @@ fn branch_if_overflow_set_test() {
}
#[cfg(test)]
fn compare_test_helper(
compare: |&mut Machine, u8|,
fn compare_test_helper<F: FnMut(&mut Machine, u8)> (
compare: F,
load_instruction: Instruction
) {
let mut machine = Machine::new();

View File

@ -46,48 +46,49 @@ pub const STACK_ADDRESS_HI: Address = Address(0x01FF);
pub const IRQ_INTERRUPT_VECTOR_LO: Address = Address(0xFFFE);
pub const IRQ_INTERRUPT_VECTOR_HI: Address = Address(0xFFFF);
const MEMORY_SIZE: uint = (ADDR_HI_BARE - ADDR_LO_BARE) as uint + 1u;
const MEMORY_SIZE: usize = (ADDR_HI_BARE - ADDR_LO_BARE) as usize + 1us;
// FIXME: Should this use indirection for `bytes`?
#[deriving(Copy)]
#[derive(Copy)]
pub struct Memory {
bytes: [u8, ..MEMORY_SIZE]
bytes: [u8; MEMORY_SIZE]
}
impl Memory {
pub fn new() -> Memory {
Memory { bytes: [0, ..MEMORY_SIZE] }
Memory { bytes: [0; MEMORY_SIZE] }
}
pub fn get_byte(&self, address: Address) -> u8 {
self.bytes[address.to_uint()]
self.bytes[address.to_usize()]
}
pub fn get_byte_mut_ref(&mut self, address: Address) -> &mut u8 {
&mut self.bytes[address.to_uint()]
&mut self.bytes[address.to_usize()]
}
pub fn get_slice(&self, Address(start): Address,
AddressDiff(diff): AddressDiff) -> &[u8] {
let start = start as uint;
let diff = diff as uint;
let start = start as usize;
let diff = diff as usize;
let end = start + diff;
self.bytes.slice(start, end)
&self.bytes[start..end]
}
// Sets the byte at the given address to the given value and returns the
// previous value at the address.
pub fn set_byte(&mut self, address: Address, value: u8) -> u8 {
let old_value = self.get_byte(address);
self.bytes[address.to_uint()] = value;
self.bytes[address.to_usize()] = value;
old_value
}
pub fn set_bytes(&mut self, Address(start): Address, values: &[u8]) {
let start = start as uint;
let start = start as usize;
// This panics if the range is invalid
let slice = self.bytes.slice_mut(start, start + values.len());
let end = start + values.len();
let slice = &mut self.bytes[start..end];
// JAM: Is this the best way to do this copy?
for (dest, src) in slice.iter_mut().zip(values.iter()) {

View File

@ -29,7 +29,7 @@ use address::{Address, AddressDiff};
use memory::{STACK_ADDRESS_LO, STACK_ADDRESS_HI};
// Useful for constructing Status instances
#[deriving(Copy)]
#[derive(Copy)]
pub struct StatusArgs {
pub negative: bool,
pub overflow: bool,
@ -55,7 +55,8 @@ impl StatusArgs {
}
pub bitflags! {
#[deriving(Show)]
#[allow(unstable)]
#[derive(Show)]
flags Status: u8 {
const PS_NEGATIVE = 0b10000000,
const PS_OVERFLOW = 0b01000000,
@ -121,7 +122,7 @@ impl Status {
}
}
#[deriving(Copy, PartialEq, Eq, PartialOrd, Ord, Show)]
#[derive(Copy, PartialEq, Eq, PartialOrd, Ord, Show)]
pub struct StackPointer(pub u8);
impl StackPointer {
@ -144,7 +145,7 @@ impl StackPointer {
}
}
#[deriving(Copy, PartialEq, Eq, Show)]
#[derive(Copy, PartialEq, Eq, Show)]
pub struct Registers {
pub accumulator: i8,
pub index_x: i8,