# Indian Institute of Technology Bombay Department of Electrical Engineering EE-224: Digital Design

Course Project: IITB-CPU

#### Team Members:

- Deep Boliya
- Scaria Kochidanadu
- Shambhavi Shanker
- Swadhin Dash

#### **COMPONENTS:**

- ALU
- Memory
- Incrementor
- MUX\_1\_TO\_2(DeMUX)
- MUX\_1\_TO\_3(DeMUX)
- MUX\_1\_TO\_5(DeMUX)
- MUX\_2\_TO\_1
- MUX\_3\_TO\_1
- MUX\_4\_TO\_1
- MUX\_5\_TO\_1
- Mux81
- Register\_1
- Register\_16
- Register\_File
- Shifter\_7bits
- Sign\_Ext\_6
- Controller
- Dataflow
- CPU

#### **DATAPATH**



## STATES

S1:

| (PC→Mem_Add)  |            |
|---------------|------------|
| "111"→RF_A1   | RF_RE1='1' |
| RF_D1→Mem_Add | Mem_RE='1' |
| Mem_out→IR    | IR_E=1     |

S2:

| IR <sub>11→9</sub> →RF_A1              | RF_RE1='1'          |
|----------------------------------------|---------------------|
| $IR_{8\rightarrow6}\rightarrow RF\_A2$ | RF_RE2='1'          |
| $IR_{5\rightarrow3}\rightarrow RF\_A3$ | RF_WE3='1'          |
| IR <sub>15→12</sub> →ALU_Sel           |                     |
| RF_D1→ALU_A                            |                     |
| RF-D2→ALU_B                            |                     |
| ALU_C→RF_D3                            |                     |
| ALU_Carry→C                            | Cflag_E=not(IR(13)) |
| ALU_Zero→Z                             | Zflag_E='1'         |

S3:

| IR→INC      |             |
|-------------|-------------|
| (PC→INC)    | PC_E='1'    |
| "111"→RF_A1 | RF_RE1='1'  |
| RF_D1→INC   |             |
| T→INC       |             |
| (INC→PC)    |             |
| ToBit→RF_A3 | ToBit="111" |
| INC→RF_D3   | RF_WE3='1'  |
|             |             |

S4:

| IR <sub>11→9</sub> →RF_A1              | RF_RE1='1'  |
|----------------------------------------|-------------|
| $IR_{8\rightarrow6}\rightarrow RF\_A3$ |             |
| $IR_{5\rightarrow0}\rightarrow SE\_6$  | RF_WE3='1'  |
| IR <sub>15→12</sub> →ALU_Sel           |             |
| RF_D1→ALU_A                            |             |
| SE_6→ALU_B                             |             |
| ALU_C→RF_D3                            |             |
| ALU_Carry→C                            | Cflag_E='1' |
| ALU_Zero→Z                             | Zflag_E='1' |

S5:

| IR <sub>8→6</sub> →RF_A1     | RF_RE1='1'  |
|------------------------------|-------------|
| IR <sub>11→9</sub> →RF_A3    |             |
| IR <sub>5→0</sub> →SE_6      | RF_WE3='1'  |
| IR <sub>15→12</sub> →ALU_Sel |             |
| RF_D1→ALU_A                  |             |
| SE_6→ALU_B                   |             |
| ALU_C→MEM_Add                | Mem_RE='1'  |
| MEM_Out→RF_D3                |             |
| ALU_Zero→Z                   | Zflag_E='1' |

S6:

| IR <sub>8→6</sub> →RF_A1  | RF_RE1='1' |
|---------------------------|------------|
| IR <sub>11→9</sub> →RF_A2 | RF_RE2='1' |
| IR <sub>5→0</sub> →SE_6   |            |
| RF_D1→ALU_A               |            |
| SE_6→ALU_B                |            |
| ALU_C→MEM_Add             | Mem_WE='1' |
| RF_D2→Mem_Din             |            |

| $\mathbf{C}$ | 7 |  |
|--------------|---|--|
| 5            | 1 |  |

| IR <sub>11→9</sub> →RF_A3 | RF_WE3='1' |
|---------------------------|------------|
| IR <sub>8→0</sub> →SH_7   |            |
| SH_7→RF_D3                |            |

S8:

| IR <sub>11→9</sub> →RF_A1              | RF_RE1='1' |
|----------------------------------------|------------|
| $IR_{8\rightarrow6}\rightarrow RF\_A2$ | RF_RE2='1' |
| IR <sub>15→12</sub> →ALU_Sel           |            |
| RF_D1→ALU_A                            |            |
| RF-D2→ALU_B                            |            |
| ALU_C→T                                | T_E='1'    |

| S9: |                                          |            |
|-----|------------------------------------------|------------|
|     | IR₁₁→9→RF A3                             | RF RE1='1' |
|     | IR <sub>11→9</sub> →RF_A3<br>"111"→RF_A1 | RF WE3='1' |
|     | _<br>RF-D1→RF_D3                         | _          |
|     |                                          |            |

| S10: |                          |             |
|------|--------------------------|-------------|
|      | ID DE A1                 | DE DE1-'1'  |
|      | IR <sub>8→6</sub> →RF_A1 | RF_RE1='1'  |
|      | ToBit→RF_A3              | ToBit="111" |
|      | RF-D1→RF_D3              | RF_WE3='1'  |

| S11: |                           |            |
|------|---------------------------|------------|
|      | IR <sub>11→9</sub> →RF_A1 | RF_RE1='1' |
|      | RF_D1→T                   | T_E='1'    |

S12:

| 12. |                       |                      |
|-----|-----------------------|----------------------|
|     | T→Mem_Add             | Mem_RE='1'           |
|     | ToBit(count_13)→RF_A3 | RF_WE3=IR(count_13); |
|     |                       |                      |
|     |                       |                      |

S13:

S14:



### STATE TRANSITION

```
ADD/ADC/ADZ/NDU/NDC/NDZ
 S1→S2→S3
ADI
 S1→S4→S3
LW
 S1→S5→S3
SW
 S1→S6→S3
LHI
 S1→S7→S3
BEQ
 S1→S8→S3
JAL
S1→S9→S3
JLR
S1→S9→S10
LM
S1→S11→S12
          S13_count_13=8 - S3
SM
 S1→S11→S14
           \uparrow\downarrow
          S13 -count_14=8 - S3
```

