CPU Design
Context
This project was conducted by me and three friends in the context of our Digital System course. The goal was to design a simple CPU with logic gates in a somewhat high-level language, compile it in a netlist then program a netlist simulator and run the CPU with some programs.
Designing the CPU
When designing the CPU, a lot of decisions had to be made. Mainly, we had to settle on an instruction set and the size and quantity of registers.
data:image/s3,"s3://crabby-images/4f9e8/4f9e8a82cfc6e910918cd3455844f29ca3e765eb" alt="alt"
data:image/s3,"s3://crabby-images/02d72/02d7242cc8ddc020a025e311a4522190c7775e36" alt="alt"
From the design of the CPU results the definition of a machine/assembly language.
data:image/s3,"s3://crabby-images/304d1/304d1609b5f52ff279608fb745ed3f8803ea047c" alt="alt"
Simulation
To simulate a netlist, we wrote an OCaml program that parses the netlist and outputs some C code that does the simulation.
data:image/s3,"s3://crabby-images/8fcbf/8fcbf80f16ca46bca3f2f7e779ed26fae014787e" alt="alt"
Running programs
The CPU runs which ever assembly program is written on its ROM. Now, writing programs in binary is tedious so we wrote a text assembly compiler and also a higher level language ‘Tong’. We wrote most programs in Tong and compiled them in binary with a compiler written in Java.
data:image/s3,"s3://crabby-images/3e44e/3e44ecba4c1379b24c76e6653a6bddab445ed0db" alt="alt"
data:image/s3,"s3://crabby-images/304d1/304d1609b5f52ff279608fb745ed3f8803ea047c" alt="alt"
Pong example
For example we were able to make a pong program. The interface is a Java program that provides a screen and user inputs to the simulator.
data:image/s3,"s3://crabby-images/63026/6302671c3014d5adce4f66f8cbaf5164c6db4614" alt="alt"
data:image/s3,"s3://crabby-images/abac8/abac88c1f00b4462774505fbcf8643590a59a97a" alt="alt"