# **Control Signal:**

- WB
- Read\_Mem
- Write\_Mem
- immediate\_value(Mux before ALU)
- branch\_pc (MUX before PC)
- branch (signal from control unit)
- ALU\_selection\_lines (4 bits temp)
- Port flag (for input port)
- SP (is addressing going into data memory stack pointer or normal memory address)
- Return (1 for RET & RETI, 0 For other instruction)
- Push
- Pop

| Instruct                  | R<br>TI | I<br>n<br>t | Me n_t o_ Re g | W<br>B | Rea<br>d_M<br>em | write<br>_ME<br>M | imm<br>ediat<br>e_va<br>lue | No _C on d_ Bra nc h | bra<br>nc<br>h | SP | Por<br>t.fla<br>g | Ret<br>urn | Pus<br>h | Po<br>p | Cal<br>I | ALU_sele<br>ction_line<br>s |
|---------------------------|---------|-------------|----------------|--------|------------------|-------------------|-----------------------------|----------------------|----------------|----|-------------------|------------|----------|---------|----------|-----------------------------|
| Interru<br>pt             | 0       | 1           | 0              | 0      | 0                | 1                 | 0                           | 0                    | 0              | 1  | 0                 | 0          | 1        | 0       | 0        | 1010                        |
| NOP                       | 0       | 0           | 0              | 0      | 0                | 0                 | 0                           | 0                    | 0              | 0  | 0                 | 0          | 0        | 0       | 0        | 1010                        |
| SETC                      | 0       | 0           | 0              | 0      | 0                | 0                 | 0                           | 0                    | 0              | 0  | 0                 | 0          | 0        | 0       | 0        | 0100                        |
| CLRC                      | 0       | 0           | 0              | 0      | 0                | 0                 | 0                           | 0                    | 0              | 0  | 0                 | 0          | 0        | 0       | 0        | 0110                        |
| OUT<br>Rsrc1              | 0       | 0           | 0              | 0      | 0                | 0                 | 0                           | 0                    | 0              | 0  | 0                 | 0          | 0        | 0       | 0        | 1110                        |
| IN<br>Rdst                | 0       | 0           | 0              | 1      | 0                | 0                 | 0                           | 0                    | 0              | 0  | 1                 | 0          | 0        | 0       | 0        | 1010                        |
|                           |         |             |                |        |                  |                   |                             | R-T                  | ypes           |    |                   |            |          |         |          |                             |
| INC<br>Rdst,<br>Rsrc<br>1 | 0       | 0           | 0              | 1      | 0                | 0                 | 0                           | 0                    | 0              | 0  | 0                 | 0          | 0        | 0       | 0        | 1100                        |
| DEC<br>Rdst,              | 0       | 0           | 0              | 1      | 0                | 0                 | 0                           | 0                    | 0              | 0  | 0                 | 0          | 0        | 0       | 0        | 1101                        |

|                                 |    | Γ.     | l                          | Ī |                  |                   |                             |                                       |                |    |                   |            | _        |         | Ι        |                             |
|---------------------------------|----|--------|----------------------------|---|------------------|-------------------|-----------------------------|---------------------------------------|----------------|----|-------------------|------------|----------|---------|----------|-----------------------------|
| Instruct<br>ion                 | RF | n<br>t | Me<br>n_t<br>o_<br>Re<br>g | B | Rea<br>d_M<br>em | write<br>_ME<br>M | imm<br>ediat<br>e_va<br>lue | No<br>C<br>on<br>d_<br>Bra<br>nc<br>h | bra<br>nc<br>h | SP | Por<br>t.fla<br>g | Ret<br>urn | Pus<br>h | Po<br>p | Cal<br>I | ALU_sele<br>ction_line<br>s |
| Rsrc1                           |    |        |                            |   |                  |                   |                             |                                       |                |    |                   |            |          |         |          |                             |
| NOT<br>Rdst,<br>Rsrc1           | 0  | 0      | 0                          | 1 | 0                | 0                 | 0                           | 0                                     | 0              | 0  | 0                 | 0          | 0        | 0       | 0        | 1111                        |
| MOV<br>Rdst,<br>Rsrc1           | 0  | 0      | 0                          | 1 | 0                | 0                 | 0                           | 0                                     | 0              | 0  | 0                 | 0          | 0        | 0       | 0        | 1110                        |
| ADD<br>Rdst,<br>Rsrc1,<br>Rsrc2 | 0  | 0      | 0                          | 1 | 0                | 0                 | 0                           | 0                                     | 0              | 0  | 0                 | 0          | 0        | 0       | 0        | 0111                        |
| IADD<br>Rdst,<br>Rsrc1,<br>Imm  | 0  | 0      | 0                          | 1 | 0                | 0                 | 1                           | 0                                     | 0              | 0  | 0                 | 0          | 0        | 0       | 0        | 0111                        |
| SUB<br>Rdst,<br>Rsrc1,<br>Rsc2  | 0  | 0      | 0                          | 1 | 0                | 0                 | 0                           | 0                                     | 0              | 0  | 0                 | 0          | 0        | 0       | 0        | 0001                        |
| AND<br>Rdst,<br>Rsrc1,<br>Rsrc2 | 0  | 0      | 0                          | 1 | 0                | 0                 | 0                           | 0                                     | 0              | 0  | 0                 | 0          | 0        | 0       | 0        | 0010                        |
| OR<br>Rdst,<br>Rsrc1,<br>Rsrc2  | 0  | 0      | 0                          | 1 | 0                | 0                 | 0                           | 0                                     | 0              | 0  | 0                 | 0          | 0        | 0       | 0        | 0011                        |
|                                 |    | •      |                            |   |                  | 1                 |                             | I-T                                   | YPE            |    |                   |            |          |         |          |                             |
| PUSH<br>Rsrc1                   | 0  | 0      | 0                          | 0 | 0                | 1                 | 0                           | 0                                     | 0              | 1  | 0                 | 0          | 1        | 0       | 0        | 1010                        |
| POP                             | 0  | 0      | 1                          | 1 | 1                | 0                 | 0                           | 0                                     | 0              | 1  | 0                 | 0          | 0        | 1       | 0        | 1010                        |

| Instruct<br>ion       | R<br>TI | I<br>n<br>t | Me<br>n_t<br>o_<br>Re<br>g | W<br>B | Rea<br>d_M<br>em | write<br>_ME<br>M | imm<br>ediat<br>e_va<br>lue | No _C on d_ Bra nc h | bra<br>nc<br>h | SP | Por<br>t.fla<br>g | Ret<br>urn | Pus<br>h | Po<br>p | Cal<br>I | ALU_sele ction_line s |
|-----------------------|---------|-------------|----------------------------|--------|------------------|-------------------|-----------------------------|----------------------|----------------|----|-------------------|------------|----------|---------|----------|-----------------------|
| Rdst                  | 0       |             |                            |        |                  |                   |                             |                      |                |    |                   |            |          |         |          |                       |
| LDM<br>Rdst,<br>Imm   | 0       | 0           | 0                          | 1      | 1                | 0                 | 1                           | 0                    | 0              | 0  | 0                 | 0          | 0        | 0       | 0        | 1000                  |
| LDD<br>Rdst,<br>Rsrc1 | 0       | 0           | 1                          | 1      | 1                | 0                 | 0                           | 0                    | 0              | 0  | 0                 | 0          | 0        | 0       | 0        | 1110                  |
| STD                   | 0       | 0           | 0                          | 0      | 0                | 1                 | 0                           | 0                    | 0              | 0  | 0                 | 0          | 0        | 0       | 0        | 1000                  |
|                       |         |             |                            |        |                  |                   |                             | J-T                  | YPE            |    |                   |            |          |         |          |                       |
| JZ<br>Rdst            | 0       | 0           | 0                          | 0      | 0                | 0                 | 0                           | 0                    | 1              | 0  | 0                 | 0          | 0        | 0       | 0        | 1010                  |
| JC<br>Rdst            | 0       | 0           | 0                          | 0      | 0                | 0                 | 0                           | 0                    | 1              | 0  | 0                 | 0          | 0        | 0       | 0        | 1010                  |
| JMP<br>Rdst           | 0       | 0           | 0                          | 0      | 0                | 0                 | 0                           | 1                    | 0              | 0  | 0                 | 0          | 0        | 0       | 0        | 1010                  |
| CALL<br>Rdst          | 0       | 0           | 0                          | 0      | 0                | 0                 | 0                           | 1                    | 0              | 1  | 0                 | 0          | 1        | 0       | 1        | 1110                  |
| RET                   | 0       | 0           | 0                          | 0      | 1                | 0                 | 0                           | 0                    | 0              | 1  | 0                 | 1          | 0        | 1       | 0        | 1010                  |
| RTI                   | 1       | 0           | 0                          | 0      | 1                | 0                 | 0                           | 0                    | 0              | 1  | 0                 | 1          | 0        | 1       | 0        | 1010                  |

| ADD                                 | 0010 |
|-------------------------------------|------|
| SUB                                 | 0001 |
| INC (takes A & B and outputs A+1)   | 1100 |
| DEC (takes A & B and outputs A-1)   | 1101 |
| MOV (takes A & B and outputs A )    | 1110 |
| NOT (takes A & B and outputs not A) | 1111 |

| AND                                                                  | 0010 |
|----------------------------------------------------------------------|------|
| OR                                                                   | 0011 |
| SETC (takes A&B and outputs garbage but changes the carry flag to 1) | 0100 |
| CLRC (takes A&B and outputs garbage but changes the carry flag to 0) | 0110 |
| LDM (takes A & B and outputs B)                                      | 1000 |
| Reset (Make output = 0)                                              | 0101 |
| NOP                                                                  | 1010 |
| First time to enter simulation                                       | 0000 |

# PC Mux 4x1

| 0 0 | Add 2, From Branching     |
|-----|---------------------------|
| 0 1 | Ret, RetI, pc ← dataM[sp] |
| 10  | PC ← M[0]                 |
| 11  | PC ← M[1]                 |

# Data1 (Mux 8x1) Output of forward unit

| FW | [2] FW[ | 1] FW[0] |                           |
|----|---------|----------|---------------------------|
| 0  | 0       | 0        | Data1                     |
| 0  | 1       | 0        | Data from Memory1         |
| 1  | 0       | 0        | Data from Memory 2        |
| 1  | 1       | 0        | Data from WB              |
| 0  | 1       | 1        | Data from in port Memory1 |
| 1  | 0       | 1        | Data from in port Memory2 |
| 1  | 1       | 1        | Data from in port WB      |

# Data2 (Mux 8x1) Output of forward unit

| FW[2 | 2] FW[ | 1] Fw[0] |                   |
|------|--------|----------|-------------------|
| 0    | 0      | 1        | Immediate         |
| 0    | 0      | 0        | Data2             |
| 0    | 1      | 0        | Data from Memory1 |
| 1    | 0      | 0        | Data from Memory2 |
| 1    | 1      | 0        | Data from WB      |
| 0    | 1      | 1        | In port memory 1  |
| 1    | 0      | 1        | In port memory 2  |
| 1    | 1      | 1        | In port WB        |

| Instruction        | opCode(6-bit s) | 1st operand<br>(RSrc1)(3-bit<br>s) | 2nd operand<br>(Rsrc2)(3-bits<br>) | 3rd operand (Rdst)(3-bits) | Extra<br>bit(1-bit) |
|--------------------|-----------------|------------------------------------|------------------------------------|----------------------------|---------------------|
| NOP                | 000001          | xxx                                | xxx                                | xxx                        | х                   |
| SETC               | 000010          | xxx                                | xxx                                | xxx                        | х                   |
| CLRC               | 000011          | xxx                                | xxx                                | xxx                        | х                   |
| OUT Rsrc1          | 000100          | Rsrc1                              | xxx                                | OUT.PORT                   | х                   |
| IN Rdst            | 000101          | IN.PORT                            | xxx                                | Rdst                       | х                   |
|                    |                 | R-Ty                               | /pes                               |                            |                     |
| INC Rdst,<br>Rsrc1 | 000110          | Rsrc1                              | xxx                                | Rdst                       | х                   |
| DEC Rdst,<br>Rsrc1 | 000111          | Rsrc1                              | xxx                                | Rdst                       | х                   |
| NOT Rdst,<br>Rsrc1 | 001000          | Rsrc1                              | xxx                                | Rdst                       | х                   |
| MOV Rdst,<br>Rsrc1 | 001001          | Rsrc1                              | xxx                                | Rdst                       | х                   |
| ADD Rdst,          | 001010          | Rsrc1                              | Rsrc2                              | Rdst                       | х                   |

| Rsrc1,Rsrc2              |        |       |       |      |   |
|--------------------------|--------|-------|-------|------|---|
| RSIC1,RSIC2              |        |       |       |      |   |
| IADD Rdst,<br>Rsrc1, Imm | 001011 | Rsrc1 | xxx   | Rdst | х |
| SUB Rdst,<br>Rsrc1,Rsc2  | 001100 | Rsrc1 | Rsc2  | Rdst | х |
| AND Rdst,<br>Rsrc1,Rsrc2 | 001101 | Rsrc1 | Rsc2  | Rdst | х |
| OR Rdst,<br>Rsrc1,Rsrc2  | 001110 | Rsrc1 | Rsc2  | Rdst | х |
|                          |        | I-T\  | /PE   |      |   |
| PUSH Rsrc1               | 001111 | Rsrc1 | xxx   | xxx  | х |
| POP Rdst                 | 010000 | xxx   | xxx   | Rdst | х |
| LDM Rdst,<br>Imm         | 010001 | xxx   | xxx   | Rdst | х |
| LDD Rdst,<br>Rsrc1       | 010010 | Rsrc1 | xxx   | Rdst | x |
| STD Rsrc2,<br>Rsrc1      | 010011 | Rsrc1 | Rsrc2 | xxx  | х |
|                          |        | J-T`  | YPE   |      |   |
| JZ Rdst                  | 010100 | Rdst  | xxx   | xxx  | х |
| JC Rdst                  | 010101 | Rdst  | xxx   | xxx  | х |
| JMP Rdst                 | 010110 | Rdst  | xxx   | xxx  | х |
| CALL Rdst                | 010111 | Rdst  | xxx   | xxx  | х |
| RET                      | 011000 | xxx   | xxx   | xxx  | х |
| RTI                      | 011001 | xxx   | xxx   | xxx  | х |
| INT                      | 011010 | xxx   | xxx   | xxx  | x |

# **Interrupt sequence:**

- 1) An int signal enters to the instruction memory and the M[1] is out to the FD buffer
- 2) PC for Int passes through the buffers to the memory stage to be stored in the memory[SP]
- 3) From the WB stage: the INT signal and M1 enters PC decision unit, and INT enters to be then used to flush the buffers that needs to be flushed
- 4) At the Execute stage: the CCR is stored