data:image/s3,"s3://crabby-images/98434/984347d5214b27f31251c62d188480d1b3fac077" alt=""
PDP-8 on an FPGA: State Machine Diagrams
These are modified from Prosser. The Verilog code is on a separate page that was prepared using the excellent Verilog to html converter v2html. The Verilog code has been edited from the version in the quartus project for clarity.
​
Note that, for all signals that need to stay stable for more than one state, I used a "next_X" format where X will change to the new value at the start of the next state. For example, in IDLE, next_halted is set to 0; this means that halted will become 0 at the start of F1.
First, the Fetch states - in Prosser, he does not split them into Fetch and Defer like the DEC-based PDP-8 descriptions do.
data:image/s3,"s3://crabby-images/0c2fa/0c2fadbec480059c7fbe739c227451df3da4211d" alt="PDP-8 State Machine 1.gif"
data:image/s3,"s3://crabby-images/751a1/751a102de4e3563eb7984c6275f11d897ac1ff60" alt="PDP-8 State Machine 2.gif"
Next, the Execute states:
data:image/s3,"s3://crabby-images/1d443/1d443e7acf42a73651213045965b99ffca458b5b" alt="PDP-8 State Machine 3.gif"
These are the Operate states - the Microinstructions.
data:image/s3,"s3://crabby-images/acf5c/acf5c65c02c129ae1a4fa6c013b3425cf4c018bd" alt="PDP-8 State Machine 4.gif"
data:image/s3,"s3://crabby-images/9b3f3/9b3f3968d037ccd0b03670bd7abc31c3943a5bb5" alt="PDP-8 State Machine 5.gif"
The extended addressing and IOP instructions:
data:image/s3,"s3://crabby-images/f48c2/f48c2fb444f8e652f5498c3ea403c3fedb088d0a" alt="PDP-8 State Machine 6.gif"