implement condition register
This commit is contained in:
parent
298d6d5c4c
commit
c8dfa736fd
49
src/main.rs
49
src/main.rs
@ -1,9 +1,6 @@
|
|||||||
#![allow(dead_code)]
|
#![allow(dead_code)]
|
||||||
#![allow(unused_variables)]
|
#![allow(unused_variables)]
|
||||||
|
|
||||||
const MEM_SIZE: usize = 1 << 16;
|
|
||||||
const PC_START: usize = 0x3000;
|
|
||||||
|
|
||||||
enum OpCodes {
|
enum OpCodes {
|
||||||
// branch
|
// branch
|
||||||
BR = 0,
|
BR = 0,
|
||||||
@ -39,6 +36,23 @@ enum OpCodes {
|
|||||||
TRAP,
|
TRAP,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
////////////////
|
||||||
|
// registers
|
||||||
|
////////////////
|
||||||
|
|
||||||
|
//
|
||||||
|
// condition flags
|
||||||
|
//
|
||||||
|
|
||||||
|
enum CondFlags {
|
||||||
|
// positive (P)
|
||||||
|
POS = 1 << 0,
|
||||||
|
// zero (Z)
|
||||||
|
ZRO = 1 << 1,
|
||||||
|
// negative (N)
|
||||||
|
NEG = 1 << 2,
|
||||||
|
}
|
||||||
|
|
||||||
struct Registers {
|
struct Registers {
|
||||||
r0: u16,
|
r0: u16,
|
||||||
r1: u16,
|
r1: u16,
|
||||||
@ -53,6 +67,8 @@ struct Registers {
|
|||||||
count: u16,
|
count: u16,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const PC_START: usize = 0x3000;
|
||||||
|
|
||||||
impl Registers {
|
impl Registers {
|
||||||
fn new() -> Registers {
|
fn new() -> Registers {
|
||||||
Registers {
|
Registers {
|
||||||
@ -94,7 +110,31 @@ impl Registers {
|
|||||||
let reg = &*self.register_reference(idx);
|
let reg = &*self.register_reference(idx);
|
||||||
*reg
|
*reg
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn set_cond(&mut self, idx: u16) {
|
||||||
|
let val = self.get_reg(idx);
|
||||||
|
|
||||||
|
if (val as i16) > 0 {
|
||||||
|
self.cond = CondFlags::POS as u16;
|
||||||
|
} else if (val as i16) < 0 {
|
||||||
|
self.cond = CondFlags::NEG as u16;
|
||||||
|
} else if val == 0 {
|
||||||
|
self.cond = CondFlags::ZRO as u16;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn set_reg_with_cond(&mut self, idx: u16, val: u16) {
|
||||||
|
self.set_reg(idx, val);
|
||||||
|
self.set_cond(idx);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
////////////////
|
||||||
|
// VM interface
|
||||||
|
////////////////
|
||||||
|
|
||||||
|
|
||||||
|
const MEM_SIZE: usize = 1 << 16;
|
||||||
|
|
||||||
struct VM {
|
struct VM {
|
||||||
mem: [u16; MEM_SIZE]
|
mem: [u16; MEM_SIZE]
|
||||||
@ -105,6 +145,7 @@ fn main() {
|
|||||||
|
|
||||||
let mut regs = Registers::new();
|
let mut regs = Registers::new();
|
||||||
println!("was {}", regs.get_reg(0));
|
println!("was {}", regs.get_reg(0));
|
||||||
regs.set_reg(0, 3);
|
regs.set_reg_with_cond(0, (0i16) as u16);
|
||||||
println!("set to {}", regs.get_reg(0));
|
println!("set to {}", regs.get_reg(0));
|
||||||
|
println!("condition: {}", regs.get_reg(9));
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user