Skip to content
This repository has been archived by the owner on Dec 24, 2020. It is now read-only.

Latest commit

 

History

History
50 lines (39 loc) · 2.32 KB

README.md

File metadata and controls

50 lines (39 loc) · 2.32 KB
layout title permalink redirect_from machines
page
8080 Exerciser Test Machine
/devices/pc8080/machine/exerciser/
/devices/pc8080/machine/test/
id type debugger
test8080
pc8080
true

8080 Exerciser Test Machine

This is a test of PC8080, a new 8080-based machine emulator recently added to the PCjs Project.

The test machine below loads a copy of the 8080 Exerciser (specifically, 8080EX1) and intercepts the exerciser's CP/M console calls so that you can see its progress in the Control Panel window. This is a "headless" test machine (no keyboard or display), so that's all you get.

The good news: PC8080 passes all the 8080 Exerciser tests. And it doesn't do it by using all sorts of weird "flags tables" that most other 8080 emulators seem to fall back on.

Like all the other CPU emulations in the PCjs Project, PC8080 never "calculates" the flags unless/until they are actually required, which considerably speeds up all arithmetic operations.

Of particular note are the 8080's subtract, compare, and decrement operations, which actually perform addition, not subtraction, by using two's complement arithmetic in "stages": the first stage (inverting the source operand) occurs before the addition, and the second stage (incrementing the inverted operand) occurs after the addition. And it appears to be the result of the first stage, not the second, that determines the state of the Auxiliary Carry flag (AF).

At 2Mhz, the 8080 Exerciser tests take quite a while, but you can click the speed button while the machine is running to increase the simulated speed; it will revert to 2Mhz when you exceed the maximum speed that your system supports.

NOTE: The original 8080 Exerciser website is currently unavailable, so we refer you to the copy on archive.org. The 8080 Exerciser source code has also been "forked" on GitHub.

{% include machine.html id="test8080" %}

8080 Online Resources

8080 Opcode Map