# EE 224 Course Project : CPU

Atharva Kulkarni(210070047) Harshit Raj(20d070033) Shreyas Grampurohit(21d070029) Varad Deshpande(21d070024)

9 Nov 2022

# **State Descriptions**

#### $S_0$ (Fetching instruction from memory)

| Data Transfer              | Commands |
|----------------------------|----------|
| $PC \rightarrow M_{-}add$  | MDR      |
| $M_{-}data \rightarrow T1$ | $T1\_E$  |

#### $S_1$ (Updating PC)

| Data Transfer            | Commands |
|--------------------------|----------|
| $PC \rightarrow ALU\_A$  | PC_E     |
| $+1 \rightarrow ALU\_B$  | ALU_J    |
| $ALU\_CND \leftarrow 11$ |          |
| $ALU\_S \rightarrow PC$  |          |

#### $S_2$ (Reading operands)

| Data Transfer                  | Commands |
|--------------------------------|----------|
| $T1_{11-9} \rightarrow RF\_A1$ | T2_E     |
| $T1_{8-6} \rightarrow RF\_A2$  | T3_E     |
| $RF\_D1 \rightarrow T2$        |          |
| $RF\_D2 \rightarrow T3$        |          |

#### $S_3$ (Execution)

| Data Transfer                          | Commands |
|----------------------------------------|----------|
| $T2 \rightarrow ALU\_A$                | T2_E     |
| $T3 \rightarrow ALU_B$                 | ALU_J    |
| $T1_{1-0} \rightarrow \text{ALU\_CND}$ |          |
| $ALU\_S \rightarrow T2$                |          |
| $ALU\_C \rightarrow FC$                |          |
| $ALU_Z \to FZ$                         |          |

#### $S_4$ (Storing the output)

| Data Transfer                        | Commands |
|--------------------------------------|----------|
| $T2 \rightarrow RF_D3$               | RF_WE    |
| $T1_{5-3} \rightarrow \text{RF\_A3}$ |          |

#### $S_5$ (Reading operands (for ADI))

|    | Data Transfer                                           | Commands  |
|----|---------------------------------------------------------|-----------|
| T  | $1_{11-9} \rightarrow RF\_A1$                           | $T2_{-}E$ |
|    | $RF\_D1 \to T2$                                         | T3_E      |
| T1 | $_{5-0} \rightarrow \text{SE\_6} \rightarrow \text{T3}$ |           |

# $S_6$ (Checking whether the two operands are equal, and storing zero flag into T2 (without changing FZ))

| Data Transfer                           | Commands |
|-----------------------------------------|----------|
| $T2 \rightarrow ALU\_A$                 | ALU_J    |
| $T3 \rightarrow ALU\_B$                 | $T2\_E$  |
| $ALU_C \rightarrow SE_2 \rightarrow T2$ |          |
| $ALU\_CND \leftarrow 00$                |          |

#### S<sub>7</sub> (Updating PC if BEQ)

| Data Transfer                                            | Commands |
|----------------------------------------------------------|----------|
| $\mathrm{PC} 	o \mathrm{ALU}$ _A                         | ALU_J    |
| $T1 \rightarrow \text{SE\_10} \rightarrow \text{ALU\_B}$ | $PC\_E$  |
| $ALU\_CND \leftarrow 11$                                 |          |
| $if(T2_0 == 0)$ then ALU_C $\rightarrow$ PC              |          |
| else $PC \to PC$                                         |          |

#### S<sub>8</sub> (Storing PC into REG\_A)

| Data Transfer                  | Commands |
|--------------------------------|----------|
| $T1_{11-9} \rightarrow RF\_A3$ | RF_WE    |
| $PC \rightarrow RF\_D3$        |          |

#### $S_9$ (Branching PC to the address PC + immediate)

| Data Transfer                                                 | Commands                      |
|---------------------------------------------------------------|-------------------------------|
| $\mathrm{PC} 	o \mathrm{ALU}$ _A                              | $\mathrm{ALU}_{	extsf{-}\!J}$ |
| $T1_{8-0} \rightarrow \text{SE\_9} \rightarrow \text{ALU\_B}$ |                               |
| $ALU\_CND \leftarrow 11$                                      |                               |
| $ALU\_S \rightarrow PC$                                       |                               |

#### $S_{10}$ (Branching PC to the address in REG\_B)

| Data Transfer                 | Commands |
|-------------------------------|----------|
| $T1_{8-6} \rightarrow RF\_A1$ | PC_E     |
| $RF_D1 \rightarrow PC$        |          |

#### $S_{11}$ (Executing Load Higher Immediate)

| Data Transfer                                  | Commands |
|------------------------------------------------|----------|
| $T1_{11-9} \rightarrow RF\_A3$                 | RF_WE    |
| $T1_{11-9} \rightarrow PZ_7 \rightarrow RF_D3$ |          |

#### $S_{12}$ (Executing Load Higher Immediate)

| Data Transfer                                  | Commands |
|------------------------------------------------|----------|
| $T1_{11-9} \rightarrow \text{RF\_A3}$          | RF_WE    |
| $T1_{11-9} \rightarrow PZ_7 \rightarrow RF_D3$ |          |

#### $S_{14}$ (Computing address of the memory destination)

| Data Transfer                                                      | Commands  |
|--------------------------------------------------------------------|-----------|
| $T3 \rightarrow ALU\_A$                                            | ALU_CND   |
| $T1_{5-0} \rightarrow \text{SE}_{-16} \rightarrow \text{ALU}_{-B}$ | $T3_{-}E$ |
| $ALU_C \rightarrow T3$                                             |           |

#### $S_{15}$ (Writing to the memory)

| Data Transfer              | Commands |
|----------------------------|----------|
| $T3 \rightarrow M_add$     | MWR      |
| $T2 \rightarrow M_{-}data$ |          |

#### $S_{16}$ (Computing address of the memory destination)

| Data Transfer                                                  | Commands |
|----------------------------------------------------------------|----------|
| $T3 \rightarrow ALU\_A$                                        | ALU_CND  |
| $T1_{5-0} \rightarrow \text{SE\_16} \rightarrow \text{ALU\_B}$ | T3_E     |
| $ALU\_C \rightarrow T3$                                        | ALU_CND  |

#### $S_{17}$ (Reading from memory)

| Data Transfer              | Commands  |
|----------------------------|-----------|
| $T3 \rightarrow M_add$     | MDR       |
| $T2 \rightarrow M_{-}data$ | $T2_{-}E$ |

#### $S_{18}$ (Writing to the register)

| Data Transfer                  | Commands |
|--------------------------------|----------|
| $T1_{11-9} \rightarrow RF\_A3$ | RF_WE    |
| $T2 \rightarrow RF\_D3$        |          |

#### $S_{19}$ (Initial step of SM)

| Data Transfer                         | Commands |
|---------------------------------------|----------|
| $(00000000000000000) \rightarrow T2$  | T2_WE    |
| $T1_{11-9} \rightarrow \text{RF\_A2}$ | T3_E     |
| $RF_D2 \rightarrow T3$                |          |

#### $S_{20}$ (Looping step 1 of SM)

| Data Transfer                                      | Commands |
|----------------------------------------------------|----------|
| $counter := int(T2_{2-0})$                         | MWR      |
| $if(T1_{counter}==1) \text{ then } T3 \rightarrow$ |          |
| $RF\_D1 \rightarrow M\_data$                       |          |
| $T2_{2-0} \rightarrow RF\_A1$                      |          |

# $S_{21}$ (Looping step 2 of SM)

| Data Transfer                                         | Commands |
|-------------------------------------------------------|----------|
| $T3 \rightarrow ALU\_A$                               | T3_E     |
| $1 \to \mathrm{ALU}_{-\mathrm{B}}$                    | ADD      |
| if $(T1_{counter} = = 1)$ then ALU_C $\rightarrow$ T3 |          |

#### $S_{22}$ (Looping step 3 of SM)

| Data Transfer           | Commands  |
|-------------------------|-----------|
| $T2 \rightarrow ALU\_A$ | ADD       |
| $1 \to ALU\_B$          | $T2_{-}E$ |
| $ALUC \rightarrow T2$   |           |

#### $S_{23}$ (Initial step of LM)

| Data Transfer                        | Commands |
|--------------------------------------|----------|
| $(0000000000000000) \rightarrow T2$  | T2_WE    |
| $T1_{11-9} \rightarrow \text{RF-A2}$ | T3_E     |
| $RF_D3 \rightarrow T3$               |          |

#### $S_{24}$ (Looping step 1 of LM)

| Data Transfer                    | Commands |
|----------------------------------|----------|
| counter := $int(T2_{2-0})$       | MDR      |
| $T1_{counter} \rightarrow RF_WR$ | MDR      |
| $T3 \rightarrow M_add$           |          |
| $M_{data} \rightarrow RF_D3$     |          |
| $T2_{2-0} \rightarrow RF\_A3$    |          |

# $S_{25}$ (Looping step 2 of LM)

| Data Transfer                                         | Commands |
|-------------------------------------------------------|----------|
| $T3 \rightarrow ALU\_A$                               | T3_E     |
| $1 \to ALU_B$                                         | ADD      |
| if $(T1_{counter} = = 1)$ then ALU_C $\rightarrow$ T3 |          |

#### $S_{26}$ (Looping step 3 of LM)

| Data Transfer           | Commands |
|-------------------------|----------|
| $T2 \rightarrow ALU\_A$ | ADD      |
| $1 \to ALUB$            | $T2\_E$  |
| $ALU_C \rightarrow T2$  |          |

# Instructions with their State Diagrams and Control Signals

| Instruction | State flow                                                            | Control |
|-------------|-----------------------------------------------------------------------|---------|
| ADD         | $S_0 \rightarrow S_1 \rightarrow S_2 \rightarrow S_3 \rightarrow S_4$ |         |
| ADC         | $S_0 \rightarrow S_1 \rightarrow S_2 \rightarrow S_3 \rightarrow S_4$ |         |
| ADZ         | $S_0 \rightarrow S_1 \rightarrow S_2 \rightarrow S_3 \rightarrow S_4$ |         |
| ADI         | $S_0 \rightarrow S_1 \rightarrow S_5 \rightarrow S_3 \rightarrow S_4$ |         |