1
0
mirror of https://github.com/mre/mos6502.git synced 2025-01-18 04:30:07 +00:00

Merge pull request #33 from amw-zero/ark-ora

Implement ORA
This commit is contained in:
Andrew Keeton 2014-11-20 18:52:13 -05:00
commit a6c59c3ff1

View File

@ -291,6 +291,14 @@ impl Machine {
&mut self.registers.status); &mut self.registers.status);
} }
(Instruction::ORA, OpInput::UseImmediate(val)) => {
self.inclusive_or(val);
}
(Instruction::ORA, OpInput::UseAddress(addr)) => {
let val = self.memory.get_byte(addr);
self.inclusive_or(val);
}
(Instruction::PHA, OpInput::UseImplied) => { (Instruction::PHA, OpInput::UseImplied) => {
// Push accumulator // Push accumulator
let val = self.registers.accumulator as u8; let val = self.registers.accumulator as u8;
@ -701,6 +709,11 @@ impl Machine {
self.load_accumulator(a_after); self.load_accumulator(a_after);
} }
fn inclusive_or(&mut self, val: u8) {
let a_after = self.registers.accumulator | (val as i8);
self.load_accumulator(a_after);
}
fn push_on_stack(&mut self, val: u8) { fn push_on_stack(&mut self, val: u8) {
let addr = self.registers.stack_pointer.to_address(); let addr = self.registers.stack_pointer.to_address();
self.memory.set_byte(addr, val); self.memory.set_byte(addr, val);
@ -1239,3 +1252,33 @@ fn exclusive_or_test() {
} }
} }
} }
#[test]
fn inclusive_or_test() {
let mut machine = Machine::new();
for a_before in range(0u8, 255u8) {
for val in range(0u8, 255u8) {
machine.execute_instruction(
(Instruction::LDA, OpInput::UseImmediate(a_before))
);
machine.inclusive_or(val);
let a_after = a_before | val;
assert_eq!(machine.registers.accumulator, a_after as i8);
if a_after == 0 {
assert!(machine.registers.status.contains(PS_ZERO));
} else {
assert!(!machine.registers.status.contains(PS_ZERO));
}
if (a_after as i8) < 0 {
assert!(machine.registers.status.contains(PS_NEGATIVE));
} else {
assert!(!machine.registers.status.contains(PS_NEGATIVE));
}
}
}
}