adjustable memory size
This commit is contained in:
parent
1f98c57eb0
commit
14d04d32ee
|
@ -3,6 +3,8 @@ use instructions::arithmetic;
|
||||||
|
|
||||||
mod instructions;
|
mod instructions;
|
||||||
|
|
||||||
|
const MEMORY_SIZE: usize = 8192;
|
||||||
|
|
||||||
pub struct EmulatorState {
|
pub struct EmulatorState {
|
||||||
a: u8,
|
a: u8,
|
||||||
b: u8,
|
b: u8,
|
||||||
|
@ -21,7 +23,7 @@ pub struct EmulatorState {
|
||||||
/// Enable interrupts
|
/// Enable interrupts
|
||||||
ei: bool,
|
ei: bool,
|
||||||
/// Memory map
|
/// Memory map
|
||||||
memory: [u8; 8000],
|
memory: [u8; MEMORY_SIZE],
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct ConditionCodes {
|
pub struct ConditionCodes {
|
||||||
|
@ -117,7 +119,7 @@ fn main() {
|
||||||
cc: ConditionCodes { z: true, s: true, p: true, c: true },
|
cc: ConditionCodes { z: true, s: true, p: true, c: true },
|
||||||
pc: 0,
|
pc: 0,
|
||||||
ei: true,
|
ei: true,
|
||||||
memory: [0; 8000],
|
memory: [0; MEMORY_SIZE],
|
||||||
};
|
};
|
||||||
|
|
||||||
// Load the ROM into memory
|
// Load the ROM into memory
|
||||||
|
@ -127,13 +129,16 @@ fn main() {
|
||||||
.expect("Provide a path to a ROM file to emulate as an argument");
|
.expect("Provide a path to a ROM file to emulate as an argument");
|
||||||
let file = fs::read(filename).expect("where file");
|
let file = fs::read(filename).expect("where file");
|
||||||
|
|
||||||
for i in 0..8000 {
|
for i in 0..8192 {
|
||||||
state.memory[i] = file[i];
|
state.memory[i] = file[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
while state.pc < 8000 {
|
while state.pc < 8192 {
|
||||||
tick(&mut state);
|
tick(&mut state);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
println!("Program counter reached end of memory; exiting");
|
||||||
|
print_state(&state);
|
||||||
}
|
}
|
||||||
|
|
||||||
fn tick(state: &mut EmulatorState) {
|
fn tick(state: &mut EmulatorState) {
|
||||||
|
|
Loading…
Reference in a new issue