

## Indian Institute of Technology Bombay



### IITB CPU Project Report

by

TEAM ID: 11  
**Takshit Aggarwal** (22B1236)  
**Harsh Anand** (22B1249)  
**Medhansh Sharma** (22B1287)  
**Sarthak Niranjan** (22B3923)

#### Course Instructor

**Prof. Virendra Singh,**  
Department of Electrical Engineering,  
IIT Bombay.

EE 224 : Digital Systems  
Course Project  
Autumn, 2023

# Objective

---

This project required us to develop a 16-bit computing system named IITB-CPU with a specified instruction set architecture. We were required to implement the system using VHDL as the Hardware Description Language (HDL). The IITB-CPU should features an 8-register architecture and operate on 16-bit data, utilizing a point-to-point communication infrastructure for efficient data exchange.

## Simulation

---



# All States

S1

- RF\_A1 -> 111
- Mem\_Add -> RF\_D1
- IR\_in > Memory
- OpCode -> IR\_out(15:12)

S2

- RF\_A1 -> IR\_out(11:0)
- RF\_A2 -> IR\_out(8:6)
- T1\_in -> RF\_D1
- T2\_in -> RF\_D2
- RF\_A3 -> IR\_out(5:3)

S3

- OpCode -> IR(15:12)
- ALU\_A -> T1\_out
- ALU\_B -> T2\_out
- T3\_in -> ALU\_C

S4

- RF\_A1 -> 111
- ALU\_A -> RF\_D1
- ALU\_B -> 0000000000000001
- RF\_A3 -> 111
- RF\_D3 -> ALU\_C

S5

- RF\_A1 -> IR\_out(11:9)
- T1\_in -> RF\_D1
- SE10\_in -> IR\_out(5:0)
- T2 -> SE10
- RF\_A3 -> IR\_out(8:6)

S6

- SE7\_in -> IR\_out(8:0)
- T1\_in -> SE7\_out
- RF\_A3 -> IR\_out(11:9)
- RF\_D3 -> T1\_out

S7

- SE7\_in -> IR\_out(8:0)
- L8\_in -> SE7\_out
- T1\_in -> L8\_out
- RF\_A3 -> IR\_out(11:9)
- RF\_D3 -> T1\_out

S8

- RF\_A1 -> IR\_out(11:9)
- RF\_A2 -> IR\_out(8:6)
- T1\_in -> RF\_D1
- T2\_in -> RF\_D2

S9

- RF\_A1 -> "111"
- ALU\_A -> T1\_out
- ALU\_B -> T2\_out
- ALU\_A -> RF\_D1
- SE10\_in -> IR\_out (5:0)
- ALU\_b -> SE\_10\_out
- RF\_A3 ->"111"
- RF\_D3 -> ALU\_C

S10

- RF\_A1 -> "111"
- ALU\_A -> T1\_out
- ALU\_B -> T2\_out
- ALU\_A -> RF\_D1
- ALU\_b -> "0000000000000001"
- RF\_A3 -> "111"
- RF\_D3 -> ALU\_C

511

- RF\_A1 ->"111"
- RF\_A3 -> IR\_OUT (11:9)
- RF\_D3 ->RF\_D1
- T1\_in -> Rf\_D1
- SE10\_in ->IR\_out (5:0)
- T2\_in -> SE10\_out

512

- ALU\_C ->T1\_out
  - AILU\_B ->T2\_out
  - RF\_A3 ->"111"
  - Rf\_D3 ->ALU\_C
- 

513

- RF\_A1 -> "111"
- RF\_A3 -> IR\_out(11:9)
- RF\_D3 ->Rf\_D1

514

- RF\_A1 -> IR\_out  
(8:6)
- RFRf\_A3 ->  
"111"
- RF\_D3 -> RF\_D1

515

- RF\_A2 ->IR\_out(8:6)
- ALU\_B ->RF\_D2
- SE10\_in ->IR\_out(5:0)
- ALU\_A ->SE10\_out
- M\_A ->ALU\_C

516

- RF\_A3 -> IR\_out (11:9)
- RF\_D3 -> M\_out

517

- RF\_A1 ->IR\_out (11:9)
- T1\_in ->RF\_D1
- M\_in ->T1\_out

## Instruction State Diagrams

ADD / SUB / MUL / AND / ORA / IMP



ADI



LHI / LLI



BEO





JAL



JLR



LW



SW







## **Contributions**

---

### **Takshit Aggarwal (Project Leader) :**

- Handled distribution and supervision of work among team members.
- Encoded the multiplexers used for controlling the Datapath in VHDL.
- Wrote the VHDL code for a hard-coded Memory.
- Helped in designing and coding the Datapath and Control signals for the system.
- Helped in Debugging the code to ensure proper functioning.

### **Harsh Anand :**

- Designed the pen-paper State Machine Diagrams of the instructions.
- Encoded the registers used to store data in VHDL.
- Helped in encoding the state machines in VHDL.
- Contributed to compiling our progress in a detailed Project Report.

### **Medhansh Sharma :**

- Encoded the components such as sign extender, register file and left shifters.
- Helped in designing and coding the Datapath and Control signals for the system.
- Wrote the VHDL code for ALU used for performing multiple different operations as required.
- Helped in Debugging the code to ensure proper functioning.

### **Sarthak Niranjan :**

- Helped in designing and encoding the state machines in VHDL.
- Wrote the VHDL code for CPU used for integrating the Datapath with the State Machine encoded previously.
- Contributed to compiling our progress in a detailed Project Report.

# Changes

January 30, 2024

- A 6x1 mux was added to the ALU to synchronise it with the clock of CPU
- ALU was coded in behavioral modelling earlier but as structural modelling gave better result so we changed the ALU to structural modelling
- A functional reset button was added to the CPU
- The LEDs were mapped to various registers and memory and the switches were used to alternate between them
- Some of the instructions whose simulations were not working earlier were improved by adding extra states which made the other functions functional.
- A functional reset button was added to the CPU