| nstruc | cDescription                                                                                                                                                                                                                     | Current Stat<br>cur_cycle |                      | Inputs<br>e subfunc | t zero        | Next State<br>next_cycle |                               | mem_rd                     | mem_wrt                       | IdPC               | IdMAR                      | IdIR                          | IdMDSR                        | IdMDLR                     | ldALUout           | Outputs                    | wreg_addr_mux   | pc_mux        | addr_mux           | a_mux         | b_mux               | reg_write_mux    | func |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|----------------------|---------------------|---------------|--------------------------|-------------------------------|----------------------------|-------------------------------|--------------------|----------------------------|-------------------------------|-------------------------------|----------------------------|--------------------|----------------------------|-----------------|---------------|--------------------|---------------|---------------------|------------------|------|
| VII    | Default outputs                                                                                                                                                                                                                  | ×                         | Х                    | Х                   | Х             | Х                        | false                         | false                      | false                         | false              | false                      | false                         | false                         | false                      | false              | false                      | WA_RD           | PC_ALU        | ADDR_PC            | A_PC          | B_REG               | RW_ALU_OUT       | ADD  |
| All .  | Fetch instruction<br>IR=Mem[PC]<br>PC=PC+4                                                                                                                                                                                       | 0                         | х                    | x                   | х             | 1                        | (false)                       | true                       | (false)                       | true               | (false)                    | true                          | (false)                       | (false)                    | (false)            | (false)                    | х               | (PC_ALU)      | (ADDR_PC)          | (A_PC)        | B_4                 | х                | (ADE |
| alt    |                                                                                                                                                                                                                                  | 1                         | 0x0                  | 0xc                 | Х             | Х                        | true                          | (false)                    | (false)                       | (false)            | (false)                    | (false)                       | (false)                       | (false)                    | (false)            | (false)                    | X               | X             | х                  | X             | Х                   | ×                | ×    |
|        | Set PC to jump address<br>PC=PC[31-28]  (IR[25-0]<<2)                                                                                                                                                                            | 1                         | 0x2                  | х                   | х             | 0                        | (false)                       | (false)                    | (false)                       | true               | (false)                    | (false)                       | (false)                       | (false)                    | (false)            | (false)                    | ×               | PC_IMM        | х                  | x             | ×                   | ×                | х    |
|        | Set ALUout to addition result<br>A_reg=Reg[IR[25-21]]<br>alu=A_reg+sign-extend(IR[15-                                                                                                                                            |                           |                      |                     |               |                          |                               |                            |                               |                    |                            |                               |                               |                            |                    |                            |                 |               |                    |               |                     |                  | Ī    |
| ıddi   | U])<br>ALUout=alu<br>Store ALUout to Register File                                                                                                                                                                               | 1                         | 0x8                  | х                   | х             | 2                        | (false)                       | (false)                    | (false)                       | (false)            | (false)                    | (false)                       | (false)                       | (false)                    | true               | (false)                    | x               | x             | х                  | A_REG         | B_IR_16             | х                | (ADI |
| ıddi   | Reg[IR[20-16]]=ALUout                                                                                                                                                                                                            | 2                         | 0x8                  | х                   | х             | 0                        | (false)                       | (false)                    | (false)                       | (false)            | (false)                    | (false)                       | (false)                       | (false)                    | (false)            | true                       | WA_RT           | ×             | х                  | х             | х                   | (RW_ALU_OUT)     | ) ×  |
| ıdd    | Set ALUout to addition result<br>A_reg=Reg[IR[25-21]] B_reg<br>= Reg[IR[20-16]]<br>alu=A_reg+B_reg ALUout=alu                                                                                                                    | 1                         | 0x0                  | 0x20                | x             | 2                        | (false)                       | (false)                    | (false)                       | (false)            | (false)                    | (false)                       | (false)                       | (false)                    | true               | (false)                    | ×               | х             | x                  | A_REG         | (B_REG)             | x                | (ADI |
| ıdd    | Store ALUout to Register File<br>Reg[IR[15-11]]=ALUout                                                                                                                                                                           | 2                         | 0x0                  | 0x20                | х             | 0                        | (false)                       | (false)                    | (false)                       | (false)            | (false)                    | (false)                       | (false)                       | (false)                    | (false)            | true                       | WA_RD           | ×             | х                  | ×             | x                   | (RW_ALU_OUT)     | ) ×  |
| ub     | Set ALUout to addition result<br>A_reg=Reg[IR[25-21]] B_reg<br>= Reg[IR[20-16]]<br>alu=A_reg+B_reg ALUout=alu<br>Store ALUout to Register File                                                                                   | 1                         | 0x0                  | 0x22                | ×             | 2                        | (false)                       | (false)                    | (false)                       | (false)            | (false)                    | (false)                       | (false)                       | (false)                    | true               | (false)                    | x               | х             | х                  | A_REG         | (B_REG)             | x                | SUE  |
| ub     | Reg[IR[15-11]]=ALUout                                                                                                                                                                                                            | 2                         | 0x0                  | 0x22                | Х             | 0                        | (false)                       | (false)                    | (false)                       | (false)            | (false)                    | (false)                       | (false)                       | (false)                    | (false)            | true                       | WA_RD           | x             | x                  | ×             | х                   | (RW_ALU_OUT)     | )  X |
| N<br>N | Set MAR to Memory Address which is the addition result. A_REG = Reg[IR[25-21]] alu = A_REG + Sign_extend(IR[15-0]) MAR = alu MDSR = Reg [20-16] Store the word from Rt to the MDRL = Mem[MAR] Reg[15-0] = MDLR                   | 1<br>2<br>3               | 0x23<br>0x23<br>0x23 | x<br>x              | x<br>x        | 2<br>3<br>0              | (false)<br>(false)<br>(false) | (false)<br>true<br>(false) | (false)<br>(false)<br>(false) | (false)<br>(false) | true<br>(false)<br>(false) | (false)<br>(false)<br>(false) | (false)<br>(false)<br>(false) | (false)<br>true<br>(false) | (false)<br>(false) | (false)<br>(false)<br>true | X<br>X<br>WA_RT | x<br>x        | X<br>ADDR_MEM<br>X |               | B_IR_16<br>X<br>X   | X<br>X<br>RW_MEM | (AD  |
| w      | Set MAR to Memory Address which is the addition result, A_REG = Reg[Rr[25-21]]alu = A_REG + sign_extend(IR[15-0]) MAR = alu, Store the wor into MDSR from Rt MDSR = Reg [20-16] Store word from MDSR into memory Mem[MAR] = MDSR | 1 2                       | 0x2b<br>0x2b         | x<br>x              | x<br>x        | 2                        | (false)                       | (false)                    | (false)<br>true               | (false)            | true<br>(false)            | (false)                       | true<br>(false)               | (false)                    | (false)            | (false)                    | x<br>x          | x<br>x        | X<br>ADDR_MAR      | $\overline{}$ | <u>B IR 16</u><br>X | x<br>x           | (AD  |
|        | Substract A_REG =<br>REG[IR[25-21]] and B_REG =<br>REG[IR[20-15]], alu = A_REG<br>- B_REG. Zero will be set to<br>either to true or false                                                                                        |                           |                      |                     |               |                          | (4-1)                         | #-I>                       | ((-1)                         | (f=1==)            | (6-1)                      | (6-1)                         | (folio - )                    | ((-1)                      | (f-1)              | (f-l)                      |                 |               |                    |               | D 050               |                  | (6)  |
| eq     | depeding on the substraction<br>Branch take nas numbers are<br>equal. PC is set to to branch<br>the address Then A_REG =<br>PC,B_REG = sign_extend<br>[IR[15-0]]<<2, alu = A_REG =                                               |                           | 0x4                  | ^                   | Î             |                          | (false)                       | (false)                    | (false)                       | (idiSe)            | (false)                    | (false)                       |                               | (false)                    | (false)            | (false)                    |                 | ^             |                    |               | B_REG               |                  | (SL  |
| eq     | B_REG, PC=alu<br>Branch not taken.                                                                                                                                                                                               | 2                         | 0x4<br>0x4           | X                   | true<br>false | 0<br>0                   | (false)<br>(false)            | (false)                    | (false)                       | true<br>(false)    | (false)                    | (false)<br>(false)            | (false)                       | (false)                    | (false)            | (false)                    | X<br>X          | (PC_ALU)<br>X | X                  | A_PC<br>X     | B_IR_16X<br>X       | ×                | (AE  |
| ine    | Substract A_REG = REG[IR[25-21]] and B_REG = REG[IR[20-15]], alu = A_REG - B_REG. Zero will be set to either to true or false depeding on the substraction                                                                       | 1                         | 0x5                  | x                   | x             | 2                        | (false)                       | (false)                    | (false)                       | (false)            | (false)                    | (false)                       | (false)                       | (false)                    | (false)            | (false)                    | x               | x             | x                  | A_REG         | B_REG               | ×                | (SL  |
|        | Branch taken as numbers are<br>not equal. PC is set to to<br>branch the address. Then<br>A_REG = PC,B_REG =<br>sign_extend [IR[15-0]]<<2, alu<br>= A_REG = B_REG, PC=alu                                                         |                           |                      |                     |               |                          |                               |                            |                               |                    |                            |                               |                               |                            |                    |                            |                 |               |                    |               |                     |                  |      |
| ne     | - A_NEG - B_REG, PC=alli                                                                                                                                                                                                         | 2                         | ny5                  | v                   | false         | h                        | (false)                       | (false)                    | (false)                       | true               | (false)                    | (false)                       | (false)                       | (false)                    | (false)            | (false)                    | l.              | (PC ALU)      | l <sub>v</sub>     | A PC          | B IR 16X            | ak.              | (A   |