1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
//! Yet another Intel 8080 Emulator. It passes the TST8080, 8080PRE, CPUTEST and 8080EXM tests.
//!
//! Example for a small loop:
//! ```rust
//! use intel8080::cpu::CPU;
//! let mut c = CPU::new();
//! c.pc = 0x0100; // sets pc to $100
//! // Here we create a small machine code program for demo purpose.
//! // Usually you will rather load an assembled code in memory (see below).
//! c.bus.write_byte(0x0100, 0x3e); // MVI A,$0F
//! c.bus.write_byte(0x0101, 0x0F);
//! c.bus.write_byte(0x0102, 0x3d); // DCR A
//! c.bus.write_byte(0x0103, 0xc2); // JNZ $0102
//! c.bus.write_word(0x0104, 0x0102);
//! c.bus.write_byte(0x0106, 0xc9); // RET
//! loop {
//! c.execute();
//! if c.pc == 0x0000 { break }
//! }
//! ```
//!
//! Debug mode outputs CPU state and disassembled code to an internal string after each execute():
//! ```text
//! 3E 0f MVI A,$0f
//! PC : 0x0003 SP : 0xff00 S : 0 Z : 0 A : 0 P : 0 C : 0
//! B : 0x00 C : 0x00 D : 0x00 E : 0x00 H : 0x00 L : 0x00 ...
//! ```
//!
//! Includes a "cpmrun" example which loads and executes basic CP/M programs:
//!
//! ```text
//! cargo run --release --example cpmrun bin/helloworld.bin
//! ```
//!
//! You can also check my [Altair 8800 / 88-SIO / teletype emulator](https://github.com/nicolasbauw/Altair8800).
//!
//! The provided source code examples can be assembled with [Retro Assembler](https://enginedesigns.net/retroassembler/).
//!
mod bit;
pub mod cpu;
mod dasm;
mod flags;
pub mod memory;
#[doc(hidden)]
pub mod register;
#[cfg(test)]
mod tests;