

IITB-CPU

EE224 : Digital Systems

By

FORAM TRIVEDI  
(23B1269)

DEV ARORA  
(23B1271)

AMAN RUSSEL  
(23B1270)

Under the guidance of  
Prof. Virendra Singh.

Electrical Engineering IITB

# WORK DISTRIBUTION

1) Dev

- (i.) All Jump statements
  - (ii.) Final FSM
  - (iii.) Code of ALU, memory unit
  - (iv.) Testing and circuit verification
- 

2) Aman

- (i) All load/store statements
  - (ii) Final Circuit Design
  - (iii) Code of Entire FSM and State outputs
  - (iv) Testing and circuit verification
- 

3) Forum

- (i) All Arithmetic logical Unit statements
- (ii) Final State Diagram
- (iii) Code of All other components ; i.e. MDX-3, MVX-16, SE-6, SE-9, Register file, Register 16Bit, CPU Testbench
- (iv) Testing and circuit verification

# IITB - CPU

Register File (16 bit Reg, 8 Registers);



General purpose register:



Condition code Register



In VHDL, registers can be implemented using easily.

Memory unit:



LOAD higher Immediate (LHI); (1000)

M<sub>o</sub> - fetch

|                  |          |
|------------------|----------|
| PC → Mem-Address | PC-en    |
| Mem-Data → IR    | Mem-read |
| CP → ALU A       | ALU_ADD  |
| +2 → ALU B       | IR-en    |
| ALUC → PC        |          |



M<sub>i</sub> - Store on MSBs

|                 |          |
|-----------------|----------|
| IR_0-7 → rZEB   | RF_Write |
| rZEB → RF_D3    |          |
| IR_9-11 → RF_A3 |          |

## LOAD LOWER IMM : (LLI) (1001)

M<sub>0</sub> - fetch Instr.

|                  |          |
|------------------|----------|
| PC → Mem-Address | PC_en    |
| Mem_Data → IR    | Mem-read |
| CP → ALUA        | ALU_ADD  |
| +2 → ALUB        | IR_en    |
| ALUC → PC        |          |



M<sub>2</sub> - Store on LSB's

|                 |          |
|-----------------|----------|
| IR_0-7 → IZ8    | RF_write |
| IZ8 → RF_D3     |          |
| IR_9-11 → RF_A3 |          |

## LOAD (LW) (1010) :

M<sub>0</sub> - fetch

|                  |          |
|------------------|----------|
| PC → Mem-Address | PC_en    |
| Mem_Data → IR    | Mem-read |
| CP → ALUA        | ALU_ADD  |
| +2 → ALUB        | IR_en    |
| ALUC → PC        |          |

M<sub>3</sub>: Understand Opr (I type)

|                 |          |
|-----------------|----------|
| IR_6-8 → RF_A1  | T1-write |
| RF_D1 → T1      | T2-write |
| IR_9-11 → RF_A2 |          |
| RF_D2 → T2      |          |

This part is useless but we want to minimize no of stages & this is reusable.



M<sub>4</sub>: Compute Address (Add T<sub>1</sub> & Imm)

|              |          |
|--------------|----------|
| T1 → ALU_A   | ALU_ADD  |
| IR_0-5 → SE6 | T3-write |
| SE6 → ALU_B  |          |
| ALU_C → T3   |          |

M<sub>5</sub> : Memory Read

|               |          |
|---------------|----------|
| T3 → Mem_Addr | Mem_Read |
| Mem_Data → T3 | T3_Write |

M<sub>6</sub> - Load to Register (T<sub>3</sub> → Reg)

|                                    |          |
|------------------------------------|----------|
| T <sub>3</sub> → RF-D <sub>3</sub> | RF-write |
| IR_9-11 → RF-A <sub>3</sub>        |          |

**STORE (SW)(1011):**

M<sub>0</sub> - fetch

|                  |          |
|------------------|----------|
| PC → Mem-Address | PC_en    |
| Mem-Data → IR    | Mem-read |
| CP → ALU_A       | ALU_ADD  |
| +2 → ALU_B       |          |
| ALUC → PC        |          |



M<sub>3</sub>: Understand Opr (I type)

|                 |          |
|-----------------|----------|
| IR_6-8 → RF-A1  | T1-write |
| RF-D1 → T1      | T2-write |
| IR_9-11 → RF-A2 |          |
| RF-D2 → T2      |          |

M<sub>4</sub>: Compute Address (Add T<sub>1</sub> & Imm)

|                        |          |
|------------------------|----------|
| T <sub>1</sub> → ALU_A | ALU_ADD  |
| IR_0-5 → SE6           | T3-write |
| SE6 → ALU_B            |          |
| ALUC → T3              |          |

M<sub>5</sub>: Memory write

|                           |           |
|---------------------------|-----------|
| T <sub>3</sub> → Mem-Addr | Mem-write |
| T <sub>2</sub> → Mem-Data |           |

*Memory*  
Net diagram with all LOAD statements:



# Arithmetic Logical Instructions

- 1 - Bring (Fetch) instructions from memory
- 2 - Understand Instruction
- 3 - Read operands
- 4 - Compute the result
- 5 - Update PC



Addition (ADD): (0000)

S<sub>0</sub> - Fetch

PC → Mem\_Address  
 Mem\_Data → IR  
 PC → ALU-A  
 $t_2 \rightarrow ALU-B$   
 $ALU-C \rightarrow PC$

PC\_en  
 Mem\_read  
 ALU-ADD  
 IR\_en

S<sub>1</sub> - Read Operands

$IR_{11-9} \rightarrow RF.A_1$   
 $IR_{8-6} \rightarrow RF.A_2$   
 $RF.D_1 \rightarrow T_1$   
 $RF.D_2 \rightarrow T_2$

$T_2.en$   
 $T_2.en$

S<sub>2</sub> - Operation

$T_1 \rightarrow ALU.A$   
 $T_2 \rightarrow ALU.B$   
 $ALU.C \rightarrow T_3$

ADD  
 $T_2.en$

S<sub>3</sub> - Update result

$T_3 \rightarrow RF.D_3$   
 $IR_{5-3} \rightarrow RF.A_3$

RF\_en



## Subtraction (SUB) : (0010)

### S<sub>5</sub> - Fetch

PC → Mem\_Address  
 Mem\_Data → IR  
 PC → ALU-A  
 $t_2 \rightarrow ALU-B$   
 ALU-C → PC

PC-en  
 Mem-read  
 ALU-ADD  
 IR-en

### S<sub>6</sub> - Read Operands

IR<sub>11-9</sub> → RF\_A<sub>1</sub>  
 IR<sub>8-6</sub> → RF\_A<sub>2</sub>  
 RF\_D<sub>1</sub> → T<sub>1</sub>  
 RF\_D<sub>2</sub> → T<sub>2</sub>

T<sub>2</sub>-en  
 T<sub>2</sub>-en

### S<sub>7</sub> - Operation

T<sub>1</sub> → ALU-A  
 T<sub>2</sub> → ALU-B  
 ALU-C → T<sub>3</sub>

SUB  
 T<sub>3</sub>-en

### S<sub>8</sub> - Update result

T<sub>3</sub> → RF\_D<sub>3</sub>  
 IR<sub>5-3</sub> → RF\_A<sub>3</sub>

RF-en



## Multiplication (MUL): (0011)

### S<sub>9</sub> - Fetch

|                  |          |
|------------------|----------|
| PC → Mem_Address | PC_en    |
| Mem_Data → IR    | Mem_read |
| PC → ALU-A       | ALU_ADD  |
| +2 → ALU-B       | IR_en    |
| ALU-C → PC       |          |

### S<sub>10</sub> - Read Operands

|                                        |                    |
|----------------------------------------|--------------------|
| IR <sub>11-9</sub> → RF_A <sub>1</sub> | T <sub>1</sub> _en |
| IR <sub>8-6</sub> → RF_A <sub>2</sub>  | T <sub>2</sub> _en |
| RF_D <sub>1</sub> → T <sub>1</sub>     |                    |
| RF_D <sub>2</sub> → T <sub>2</sub>     |                    |



### S<sub>11</sub> - Operation

|                        |                    |
|------------------------|--------------------|
| T <sub>1</sub> → ALU-A | MUL                |
| T <sub>2</sub> → ALU-B |                    |
| ALU-C → T <sub>3</sub> | T <sub>3</sub> _en |

### S<sub>12</sub> - Update result

|                                       |       |
|---------------------------------------|-------|
| T <sub>3</sub> → RF_D <sub>3</sub>    | RF_en |
| IR <sub>5-3</sub> → RF_A <sub>3</sub> |       |

## Add immediate (ADD): 00001

### S<sub>3</sub> - Fetch

PC → Mem\_Address  
 Mem\_Data → IR  
 PC → ALU\_A  
 +2 → ALU\_B  
 ALU\_C → PC

PC\_en  
 Mem\_read  
 ALU\_ADD  
 IR\_en

### S<sub>4</sub> - Read Operands

IR<sub>11-9</sub> → RF\_A<sub>1</sub>  
 RF\_D<sub>1</sub> → T<sub>1</sub>

T<sub>1</sub> → ALU\_A  
 IR<sub>5-0</sub> → SF6 → ALU\_B  
 ALU\_C → T<sub>3</sub>

T<sub>1</sub> → RF\_en  
 SF6 → T<sub>3</sub> → RF\_en

### S<sub>5</sub> - Operation

T<sub>1</sub> → ALU\_A  
 IR<sub>5-0</sub> → SF6 → ALU\_B  
 ALU\_C → T<sub>3</sub>

ADD  
 T<sub>3</sub> → RF\_en

### S<sub>6</sub> - Update result

T<sub>3</sub> → RF\_D<sub>3</sub>  
 IR<sub>6-8</sub> → RF\_A<sub>3</sub>

RF\_en

IR



## Logical And (AND) : (0100)

### S<sub>17</sub> - Fetch

PC → Mem\_Address  
 Mem\_Data → IR  
 PC → ALU\_A  
 $+2 \rightarrow ALU_B$   
 ALU\_C → PC

PC\_en  
 Mem\_read  
 ALU\_ADD  
 IR\_en

### S<sub>18</sub> - Read Operands

IR<sub>11-9</sub> → RF\_A<sub>1</sub>  
 IR<sub>8-6</sub> → RF\_A<sub>2</sub>  
 RF\_D<sub>1</sub> → T<sub>1</sub>  
 RF\_D<sub>2</sub> → T<sub>2</sub>

T<sub>1</sub>\_en  
 T<sub>2</sub>\_en

### S<sub>19</sub> - Operation

T<sub>1</sub> → ALU\_A  
 T<sub>2</sub> → ALU\_B  
 ALU\_C → T<sub>3</sub>

AND  
 T<sub>3</sub>\_en

### S<sub>20</sub> - Update result

T<sub>3</sub> → RF\_D<sub>3</sub>  
 IR<sub>5-3</sub> → RF\_A<sub>3</sub>

RF\_en



## Logical OR (ORA): (0101)

### S<sub>21</sub>-Fetch

PC → Mem\_Address  
 Mem\_Data → IR  
 PC → ALU-A  
 $T_2 \rightarrow ALU-B$   
 $ALU-C \rightarrow PC$

### S<sub>22</sub>-Read Operands

$IR_{11-9} \rightarrow RF-A_1$   
 $IR_{8-6} \rightarrow RF-A_2$   
 $RF-D_1 \rightarrow T_1$   
 $RF-D_2 \rightarrow T_2$

### S<sub>23</sub>-Operation

$T_1 \rightarrow ALU-A$   
 $T_2 \rightarrow ALU-B$   
 $ALU-C \rightarrow T_3$

### S<sub>24</sub>-Update result

$T_3 \rightarrow RF-D_3$   
 $IR_{5-3} \rightarrow RF-A_3$



## Logical Implication (IMP): (0110)

### S<sub>35</sub> - Fetch

PC → Mem\_Address  
 Mem\_Data → IR  
 PC → ALU-A  
 $T_2 \rightarrow ALU-B$   
 ALU-C → PC

PC\_en  
 Mem\_read  
 ALU\_ADD  
 IR\_en

### S<sub>46</sub> - Read Operands

$IR_{11-9} \rightarrow RF.A_1$   
 $IR_{8-6} \rightarrow RF.A_2$   
 $RF.D_1 \rightarrow T_1$   
 $RF.P_2 \rightarrow T_2$

T<sub>1</sub>\_en  
 T<sub>2</sub>\_en

### S<sub>47</sub> - Operation

$T_1 \rightarrow ALU-A$   
 $T_2 \rightarrow ALU-B$   
 ALU-C → T<sub>3</sub>

IMP  
 T<sub>3</sub>\_en

### S<sub>48</sub> - Update result

$T_3 \rightarrow RF.D_3$   
 $IR_{5-3} \rightarrow RF.A_3$

RF\_en



## BEQ (Branch on Equality)

IR



- 1) Fetch Instruction
- 2) Update PC
- 3) Understand Instruction
- 4) Read Operands
- 5) Check for equality

Do:-

$$\begin{array}{l|l}
 \text{PC} \rightarrow \text{Mem-A} & \text{Mem-Read} \\
 \text{PC} \rightarrow \text{ALU-A} & \text{ALU-ADD} \\
 \text{Mem-D} \rightarrow \text{IR} & \text{IR-en} \\
 \text{ALU-C} \rightarrow \text{PC} & \\
 +2 \rightarrow \text{ALU-B} & \text{PC-en}
 \end{array}$$

D<sub>1</sub>:-

$$\begin{array}{l|l}
 \text{IR}_{11-4} \rightarrow \text{RF-A}_1 & \text{T}_1\text{-en} \\
 \text{IR}_{8-6} \rightarrow \text{RF-A}_2 & \text{T}_2\text{-en} \\
 \text{RF-D}_1 \rightarrow \text{T}_1 & \\
 \text{RF-D}_2 \rightarrow \text{T}_2 &
 \end{array}$$

D<sub>2</sub>:- ( $Z=1$  if  $\text{ALU-C}=0$ ; else = 0)

$$\begin{array}{l|l}
 \text{T}_1 \rightarrow \text{ALU-A} & \text{ALU-SUB} \\
 \text{T}_2 \rightarrow \text{ALU-B} & \\
 \text{ALU-C} \rightarrow Z &
 \end{array}$$

D<sub>3</sub>:- (If  $Z=1$ )

$$\begin{array}{l|l}
 \text{PC} \rightarrow \text{ALU-A} & \text{ALU-ADD} \\
 \text{IR}_{5-0} \rightarrow \text{SE-6} & \text{PC-en} \\
 \text{SE-6} \rightarrow \text{LS-1} & \\
 \text{LS-1} \rightarrow \text{ALU-B} & \\
 \text{ALU-C} \rightarrow \text{PC} &
 \end{array}$$



D<sub>4</sub>:-

$$\begin{array}{l|l}
 \text{PC} \rightarrow \text{ALU-A} & \text{PC-en} \\
 +2 \rightarrow \text{ALU-B} & \text{ALU-SUB} \\
 \text{ALU-C} \rightarrow \text{PC} &
 \end{array}$$

## Jump and Link

- 1) Fetch Instruction
- 2) Update PC
- 3) Understand instruction and fetch operand
- 4) Store PC value
- 5) Compute PC and update



D<sub>1</sub>:

$$\begin{array}{l|l}
 \text{PC} \rightarrow \text{Mem-A} & \text{Mem-Read} \\
 \text{PC} \rightarrow \text{ALU-A} & \text{ALU-ADD} \\
 \text{Mem-D} \rightarrow \text{IR} & \text{IR-en} \\
 \text{ALU-C} \rightarrow \text{PC} & \\
 +2 \rightarrow \text{ALU-B} & \text{PC-en}
 \end{array}$$



D<sub>2</sub>:

no data transfer | Understand instruction

D<sub>3</sub>:

$$\begin{array}{l|l}
 \text{IR}_{9-11} \rightarrow \text{RF-A}_3 & \text{RF-en} \\
 \text{PC} \rightarrow \text{RF-D}_3 &
 \end{array}$$

D<sub>4</sub>:

$$\begin{array}{l|l}
 \text{PC} \rightarrow \text{ALU-A} & \text{ALU-ADD} \\
 \text{IR}_{5-0} \rightarrow \text{SE-9} & \text{PC-en} \\
 \text{SE-6} \rightarrow \text{LS-1} & \\
 \text{LS-1} \rightarrow \text{ALU-B} & \\
 \text{ALU-C} \rightarrow \text{PC} &
 \end{array}$$

D<sub>5</sub>:

$$\begin{array}{l|l}
 \text{PC} \rightarrow \text{ALU-A} & \text{PC-en} \\
 +2 \rightarrow \text{ALU-B} & \text{ALU-SOB} \\
 \text{ALU-C} \rightarrow \text{PC} &
 \end{array}$$

## Jump and Link to Register

- 1) Fetch Instruction
- 2) Update PC
- 3) Understand instruction and fetch operand
- 4) Store PC value
- 5) Compute PC and update

IR



D<sub>0</sub>:

$$\begin{array}{l}
 \text{PC} \rightarrow \text{Mem-A} \quad | \text{Mem-Read} \\
 \text{PC} \rightarrow \text{ALU-A} \quad | \text{ALU-ADD} \\
 \text{Mem-D} \rightarrow \text{IR} \quad | \text{IR-en} \\
 \text{ALU-C} \rightarrow \text{PC} \quad | \\
 +2 \rightarrow \text{ALU-B} \quad | \text{PC-en}
 \end{array}$$

D<sub>4</sub>:

no data transfer | Understand instruction



D<sub>5</sub>:

$$\begin{array}{l}
 \text{IR}_{9-11} \rightarrow \text{RF-A}_3 \quad | \text{RF-en} \\
 \text{PC} \rightarrow \text{RF-D}_3 \quad |
 \end{array}$$

D<sub>7</sub>:

$$\begin{array}{l}
 \text{IR}_{8-6} \rightarrow \text{RF-A}_1 \quad \text{PC-en} \\
 \text{RF-D}_1 \rightarrow \text{PC}
 \end{array}$$

## Jump

- 1) Fetch Instruction
- 2) Update PC
- 3) Understand instruction
- 4) Compute PC ; Update PC



Do:-

$$\begin{array}{l|l} \text{PC} \rightarrow \text{Mem-A} & \text{Mem-Read} \\ \text{PC} \rightarrow \text{ALU-A} & \text{ALU-ADD} \\ \text{Mem-D} \rightarrow \text{IR} & \text{IR-en} \\ \text{ALU-C} \rightarrow \text{PC} & \\ +2 \rightarrow \text{ALU-B} & \text{PC-en} \end{array}$$

Dy:-

no data transfer | Understand instruction



D8:-

$$\begin{array}{l|l} \text{PC} \rightarrow \text{ALU-A} & \text{ALU-ADD} \\ \text{IR}_{11-0} \rightarrow \text{SE-9} & \text{PC-en} \\ \text{SE-12} \rightarrow \text{LS-1} & \\ \text{LS-1} \rightarrow \text{ALU-B} & \\ \text{ALU-C} \rightarrow \text{PC} & \end{array}$$

D9:-

$$\begin{array}{l|l} \text{PC} \rightarrow \text{ALU-A} & \text{PC-en} \\ +2 \rightarrow \text{ALU-B} & \text{ALU-SUB} \\ \text{ALU-C} \rightarrow \text{PC} & \end{array}$$

# FSM



## S<sub>1</sub> - Fetch

$PC \rightarrow \text{Mem-Address}$   
 $\text{Mem-data} \rightarrow IR$   
 $PC \rightarrow ALU-A$   
 $+2 \rightarrow ALU-B$   
 $ALU-C \rightarrow PC$

$PC_{en}$   
 $\text{Mem-read}$   
 $ADD$   
 $IR-en$

## S<sub>2</sub> - Loading T<sub>1</sub>, T<sub>2</sub> (I)

|                                |          |
|--------------------------------|----------|
| $IR_{11-9} \rightarrow RF-A_1$ | $T_1-en$ |
| $RF-D_1 \rightarrow T_1$       | $T_2-en$ |
| $IR_{8-6} \rightarrow RF-A_2$  |          |
| $RF-D_2 \rightarrow T_2$       |          |

## S<sub>3</sub> - Loading T<sub>1</sub>, T<sub>2</sub> (II)

|                                |          |
|--------------------------------|----------|
| $IR_{8-6} \rightarrow RF-A_1$  | $T_1-en$ |
| $RF-D_1 \rightarrow T_1$       | $T_2-en$ |
| $IR_{11-9} \rightarrow RF-A_2$ |          |
| $RF-D_2 \rightarrow T_2$       |          |

## S<sub>4</sub> - Operation

$T_1 \rightarrow ALU-A$   
 $T_2 \rightarrow ALU-B$   
 $ALU-C \rightarrow T_3$

*Open<sup>n</sup>*

## S<sub>5</sub> - Addition with Imm.

$T_1 \rightarrow ALU-A$   
 $IR_{0-5} \rightarrow SE6$   
 $SE6 \rightarrow ALU-B$   
 $ALU-C \rightarrow T_3$

*ADD*

*T<sub>3</sub>-en*

## S<sub>6</sub> - (Z=1 if ALU-C=0 else =0)

$T_1 \rightarrow ALU-A$   
 $T_2 \rightarrow ALU-B$   
 $ALU-C \rightarrow Z$

*SUB*

## S<sub>7</sub> - Store PC value

$IR_{11-9} \rightarrow RF\_A_3$   
 $PC \rightarrow RF\_D_3$

## S<sub>13</sub> - Memory Read

$T_3 \rightarrow Mem\_Address$   
 $Mem\_data \rightarrow T_3$

Memory  
 $T_3\_en$

## S<sub>8</sub> - Change PC value (I)

$PC \rightarrow ALU\_A$   
 $IR_{8-0} \rightarrow SE_9$   
 $SE_9 \rightarrow LS\_1$   
 $LS\_1 \rightarrow ALU\_B$   
 $ALU\_C \rightarrow PC$

## S<sub>14</sub> - Memory write

$T_3 \rightarrow Mem\_Address$   
 $T_2 \rightarrow Mem\_data$

Memory  
 $Mem\_en$

## S<sub>15</sub> - if ( $Z = 1$ )

$PC \rightarrow ALU\_A$   
 $IR_{5-0} \rightarrow SE_6$   
 $SE_6 \rightarrow LS\_1$   
 $LS\_1 \rightarrow ALU\_B$   
 $ALU\_C \rightarrow PC$

## S<sub>9</sub> - Store on MSBs

$IR_{7-0} \rightarrow YZE_8$   
 $YZE_8 \rightarrow RF\_D_3$   
 $IR_{11-9} \rightarrow RF\_A_3$

## S<sub>16</sub> - Change PC value (II)

$IR_{8-0} \rightarrow RF\_A_1$   
 $RF\_D_1 \rightarrow PC$   
 $T_2 \rightarrow PC$

## S<sub>17</sub> - Load to Register (III)

$T_3 \rightarrow RF\_D_3$   
 $IR_{11-9} \rightarrow RF\_A_3$

## S<sub>18</sub> - Subtraction of PC

$PC \rightarrow ALU\_A$   
 $+2 \rightarrow ALU\_B$   
 $ALU\_C \rightarrow PC$

## S<sub>11</sub> - Load to register (I)

$T_3 \rightarrow RF\_D_3$   
 $IR_{5-3} \rightarrow RF\_A_3$

## S<sub>12</sub> - Load to register (II)

$T_3 \rightarrow RF\_D_3$   
 $IR_{6-8} \rightarrow RF\_A_3$

gnd | A-DJA + IT  
       | B-DJA + IT  
       | S + D-DJA

IT + RF\_A1  
 $T \leftarrow 12.32$   
 $A-5R \leftarrow 12.32$   
 $T \leftarrow 12.32$

IT + RF\_A1  
 $T \leftarrow 12.32$   
 $A-5R + RF_A1$   
 $T \leftarrow 12.32$



### MUX TABLES:

| MUX 1 |                |  |
|-------|----------------|--|
| 0 0   | Disconnect     |  |
| 0 1   | PC             |  |
| 1 0   | T <sub>3</sub> |  |

  

| MUX 2 |            |  |
|-------|------------|--|
| 0 0   | Disconnect |  |
| 0 1   | 9-11       |  |
| 1 0   | 6-8        |  |

  

| MUX 3 |            |  |
|-------|------------|--|
| 0 0   | Disconnect |  |
| 0 1   | 9-11       |  |
| 1 0   | 6-8        |  |

  

| MUX 4 |            |  |
|-------|------------|--|
| 0 0   | Disconnect |  |
| 0 1   | 2-5        |  |
| 1 0   | 9-11       |  |
| 1 1   | 6-8        |  |

  

| MUX 5 |                |  |
|-------|----------------|--|
| 0 0 0 | Disconnect     |  |
| 0 0 1 | +2             |  |
| 0 1 0 | T <sub>2</sub> |  |
| 0 1 1 | SEG-L5         |  |
| 1 0 0 | SEG            |  |
| 1 0 1 | SEG-L5         |  |

  

| MUX 6 |                |  |
|-------|----------------|--|
| 0 0 0 | Disconnect     |  |
| 0 0 1 | +2             |  |
| 0 1 0 | T <sub>2</sub> |  |
| 0 1 1 | SEG-L5         |  |
| 1 0 0 | SEG            |  |
| 1 0 1 | SEG-L5         |  |

  

| MUX 7 |                |  |
|-------|----------------|--|
| 0 0 0 | Disconnect     |  |
| 0 0 1 | PC             |  |
| 0 1 0 | T2E            |  |
| 0 1 1 | 1ZE            |  |
| 1 0 0 | T <sub>C</sub> |  |

  

| MUX 8 |            |  |
|-------|------------|--|
| 0 0 0 | Disconnect |  |
| 0 0 1 | ALU-C      |  |
| 0 1 0 | Mean-Data  |  |

→ ALU-B

|                 | A              | 19             | 17   | 16   | 15   | 14   | 13   | 12   | 11   | 10   | 9     | 7     | 6     | 4     | 3     | 2     | 1     | 0     | MUX ALU Mode |
|-----------------|----------------|----------------|------|------|------|------|------|------|------|------|-------|-------|-------|-------|-------|-------|-------|-------|--------------|
| State           | MUX1<br>Select | MUX1<br>Select | MUX2 | MUX3 | MUX4 | MUX5 | MUX6 | MUX7 | MUX8 | MUX9 | MUX10 | MUX11 | MUX12 | MUX13 | MUX14 | MUX15 | MUX16 | MUX17 | MUX18        |
| S <sub>1</sub>  | 01             | 00             | 00   | 00   | 00   | 01   | 001  | 000  | 000  | 000  | 11    | 0000  | 0000  | 0000  | 0000  | 0000  | 0000  | 0000  | 0000         |
| S <sub>2</sub>  | 00             | 01             | 10   | 00   | 00   | 000  | 000  | 000  | 000  | 000  | 00    | 0000  | 0000  | 0000  | 0000  | 0000  | 0000  | 0000  | 0000         |
| S <sub>3</sub>  | 00             | 00             | 00   | 00   | 00   | 010  | 10   | 010  | 000  | 000  | 01    | 00    | 0000  | 0000  | 0000  | 0000  | 0000  | 0000  | 0000         |
| S <sub>4</sub>  | 00             | 00             | 00   | 00   | 00   | 010  | 010  | 010  | 000  | 000  | 00    | 00    | 0000  | 0000  | 0000  | 0000  | 0000  | 0000  | 0010         |
| S <sub>5</sub>  | 00             | 00             | 00   | 00   | 10   | 00   | 000  | 000  | 000  | 000  | 00    | 00    | 0000  | 0000  | 0000  | 0000  | 0000  | 0000  | 0000         |
| S <sub>6</sub>  | 00             | 00             | 00   | 00   | 00   | 010  | 01   | 011  | 000  | 000  | 00    | 00    | 0000  | 0000  | 0000  | 0000  | 0000  | 0000  | 0000         |
| S <sub>7</sub>  | 00             | 00             | 00   | 00   | 10   | 00   | 000  | 000  | 010  | 000  | 00    | 00    | 0000  | 0000  | 0000  | 0000  | 0000  | 0000  | 0000         |
| S <sub>8</sub>  | 00             | 00             | 00   | 00   | 10   | 00   | 000  | 000  | 011  | 000  | 00    | 00    | 0000  | 0000  | 0000  | 0000  | 0000  | 0000  | 0000         |
| S <sub>9</sub>  | 00             | 00             | 00   | 00   | 00   | 010  | 10   | 100  | 000  | 000  | 01    | 00    | 0000  | 0000  | 0000  | 0000  | 0000  | 0000  | 0000         |
| S <sub>10</sub> | 00             | 00             | 00   | 00   | 01   | 00   | 000  | 000  | 100  | 00   | 00    | 00    | 0000  | 0000  | 0000  | 0000  | 0000  | 0000  | 0000         |
| S <sub>11</sub> | 00             | 00             | 00   | 00   | 10   | 00   | 000  | 000  | 100  | 00   | 00    | 00    | 0000  | 0000  | 0000  | 0000  | 0000  | 0000  | 0000         |
| S <sub>12</sub> | 00             | 00             | 00   | 00   | 00   | 00   | 000  | 000  | 000  | 000  | 00    | 00    | 0000  | 0000  | 0000  | 0000  | 0000  | 0000  | 0000         |
| S <sub>13</sub> | 10             | 00             | 00   | 00   | 00   | 00   | 000  | 000  | 000  | 000  | 10    | 00    | 0000  | 0000  | 0000  | 0000  | 0000  | 0000  | 0000         |
| S <sub>14</sub> | 10             | 00             | 00   | 00   | 00   | 00   | 000  | 000  | 000  | 000  | 00    | 00    | 0000  | 0000  | 0000  | 0000  | 0000  | 0000  | 0000         |
| S <sub>15</sub> | 00             | 00             | 00   | 00   | 11   | 00   | 000  | 000  | 100  | 00   | 00    | 00    | 0000  | 0000  | 0000  | 0000  | 0000  | 0000  | 0000         |
| S <sub>16</sub> | 01             | 00             | 00   | 00   | 00   | 01   | 001  | 000  | 000  | 000  | 11    | 0000  | 0000  | 0000  | 0000  | 0000  | 0000  | 0000  | 0010         |

# SCREENSHOTS OF WORKING SIMULATIONS

## 1) ADD



## 2) SUBTRACT



### 3) MUL



### 4) ADI



## 5) AND



## 6) ORA



## 7) **IMP**



8) LHI



## 9) LLI

|                      |                      |                      |                      |                      |
|----------------------|----------------------|----------------------|----------------------|----------------------|
| 0000000010001000     |                      |                      |                      |                      |
| 1011100100000000     |                      |                      |                      |                      |
| 1011100110001000     |                      |                      |                      |                      |
| 10111000001111000    |                      |                      |                      |                      |
| 00000000000001010    |                      |                      |                      |                      |
| 1011100110001000     |                      |                      |                      |                      |
| UUUUUUUUUUUUUUUUU    |                      |                      |                      |                      |
| UUUUUUUUUUUUUUUUU    |                      |                      |                      | 0000000010001000     |
| 00000000000000000000 | 00011000000000000000 | 00000000000000000000 | 00000000000000000000 | 01000000000000000000 |
| 000000000000010100   |                      |                      |                      |                      |
| 1001111010001000     |                      |                      |                      |                      |
| 000000000000000000   |                      |                      |                      |                      |
| 1001                 |                      |                      |                      |                      |

## 10) LW

|      |                      |                      |                      |                      |                      |
|------|----------------------|----------------------|----------------------|----------------------|----------------------|
| 000  | 0000000010001000     |                      |                      |                      |                      |
| 000  | 1011100100000000     |                      |                      |                      |                      |
| 000  | 1011100110001000     |                      |                      |                      |                      |
| 000  | 10111000001111000    |                      |                      |                      |                      |
| 010  | 00000000000001010    |                      |                      |                      |                      |
| 000  | 1011100110001000     |                      |                      |                      |                      |
| ...  | UUUUUUUUUUUUUUUUU    |                      |                      | 1011100110001000     |                      |
| 000  | 0000000010001000     |                      |                      |                      |                      |
| 0..  | 00100100000000000000 | 00000000001000000000 | 10000000000000000000 | 00000000000000000000 | 01000000000000000000 |
| 110  | 000000000000000000   |                      |                      |                      |                      |
| 111  | 10101000111111       |                      |                      |                      |                      |
| 000  | 000000000000000000   |                      |                      |                      |                      |
| 1010 |                      |                      |                      |                      |                      |

## 11) SW



## 12) BEQ



## 13) JAL



## 14) JLR



### 15) Jump

## Reference:

|   |                  | Msgs              |
|---|------------------|-------------------|
| + | /cpu_tb/R1o      | 0000000010001000  |
| + | /cpu_tb/R2o      | 1011100100000000  |
| + | /cpu_tb/R3o      | 1011100110001000  |
| + | /cpu_tb/R4o      | 1011100001111000  |
| + | /cpu_tb/R5o      | 00000000000001011 |
| + | /cpu_tb/R6o      | 1011100110001000  |
| + | /cpu_tb/R7o      | 1011100110001000  |
| + | /cpu_tb/R8o      | 0000000010001000  |
|   | /cpu_tb/dk       | 1                 |
|   | /cpu_tb/reset    | 0                 |
| + | /cpu_tb/mux_out  | 00000010000000... |
| + | /cpu_tb/PC_out   | 00000000000011100 |
| + | /cpu_tb/IR_out   | 1111001010000000  |
| + | /cpu_tb/CCR_out  | 0000000000000000  |
| + | /cpu_tb/oper_out | 1111              |