



**FACULTY OF ENGINEERING & TECHNOLOGY  
DEPARTMENT OF ELECTRICAL AND COMPUTER  
ENGINEERING  
ENCS4370 - Computer Architecture**

**Project #2: Multi-Cycle**

---

**Prepared by:**

Marah Hamarsheh

**No:**1220281

**Section:** 3

Layan Salem

**No:** 1221026

**Section:** 3

**Instructor:** Aziz Qaroush

**Date:** 10-6-2025

| Team Member Name | Team Member ID | Contributions    |
|------------------|----------------|------------------|
| Marah Hamarsheh  | 1220281        | 1/2              |
| Layan Salem      | 1221026        | 1/2              |
| -                | -              | We work together |

| Processor Implementation (Tick One)                          |                          |
|--------------------------------------------------------------|--------------------------|
| Single Cycle                                                 |                          |
| Multi Cycle                                                  | ✓                        |
| Pipelined                                                    |                          |
| In case of pipeline implementation (Tick the correct answer) |                          |
|                                                              | Implemented in RTL Code? |
| Data hazards detection                                       | -                        |
| Control hazards detection                                    | -                        |
| Structural hazards detection                                 | -                        |
| Forwarding                                                   | -                        |
| Stalling                                                     | -                        |

| Tick the correct answer |                                                |    |                                                           |    |                                                               |    |
|-------------------------|------------------------------------------------|----|-----------------------------------------------------------|----|---------------------------------------------------------------|----|
| Instruction             | Did you implement this instruction in the RTL? |    | Did you write the verification code for this instruction? |    | Did the instruction Work perfectly when it has been verified? |    |
|                         | Yes                                            | No | Yes                                                       | No | Yes                                                           | No |
| OR Rd, Rs, Rt           | Yes                                            |    | Yes                                                       |    | 50%                                                           |    |
| ADD Rd, Rs, Rt          | Yes                                            |    | Yes                                                       |    | 50%                                                           |    |
| SUB Rd, Rs, Rt          | Yes                                            |    | Yes                                                       |    | 50%                                                           |    |
| CMP Rd, Rs, Rt          | Yes                                            |    | Yes                                                       |    | 50%                                                           |    |
| ORI Rd, Rs, Imm         | Yes                                            |    | Yes                                                       |    | 50%                                                           |    |
| ADDI Rd, Rs, Imm        | Yes                                            |    | Yes                                                       |    | 50%                                                           |    |
| LW Rd, Imm (Rs)         | Yes                                            |    | Yes                                                       |    | 50%                                                           |    |
| LDW Rd, Imm (Rs)        | Yes                                            |    | Yes                                                       |    | 50%                                                           |    |

|                                                                                                          |            |  |            |  |            |            |
|----------------------------------------------------------------------------------------------------------|------------|--|------------|--|------------|------------|
| <b>SDW Rd, Imm (Rs)</b>                                                                                  | <b>Yes</b> |  | <b>Yes</b> |  | <b>50%</b> |            |
| <b>BZ Rs, Label</b>                                                                                      | <b>Yes</b> |  | <b>Yes</b> |  | <b>50%</b> |            |
| <b>BGZ Rs, Label</b>                                                                                     | <b>Yes</b> |  | <b>Yes</b> |  | <b>50%</b> |            |
| <b>BLZ Rs, Label</b>                                                                                     | <b>Yes</b> |  | <b>Yes</b> |  | <b>50%</b> |            |
| <b>JR Rs</b>                                                                                             | <b>Yes</b> |  | <b>Yes</b> |  | <b>50%</b> |            |
| <b>J Label</b>                                                                                           | <b>Yes</b> |  | <b>Yes</b> |  | <b>50%</b> |            |
| <b>CALL Label</b>                                                                                        | <b>Yes</b> |  | <b>Yes</b> |  | <b>50%</b> |            |
| <b>Tick one of the following</b>                                                                         |            |  |            |  |            |            |
| <b>My processor can execute only test programs consisting of one instruction only</b>                    |            |  |            |  |            | <b>50%</b> |
| <b>My processor can execute complete programs (A simulation screenshot must be provided as evidence)</b> |            |  |            |  |            | <b>50%</b> |

We tested the instructions, but it didn't work completely because of datapath had an issue that we didn't know how to print the ALU result, but it wrote to the Register correctly, and we noticed that the control unit changed correctly with other things.

The processor operates correctly as a multi-cycle architecture, executing instructions through five stages (IF, ID, EX, MEM, WB) that advance synchronously with each clock cycle, maintaining proper data flow and state preservation between stages.

## **Abstract:**

This project aims to design and verify a simple 32-bit multi-cycle RISC processor using Verilog. Every instruction is carried out by the processor over a number of clock cycles, with separate phases for fetch, decode, execute, memory, and write-back. It supports a custom ISA with ALU, memory, and control flow instructions. There are 16 general-purpose registers in the architecture, with R14 as the return address and R15 as the program counter. Signals are produced by the control unit to control the Datapath at each cycle.

## **Table of Contents:**

|                                           |     |
|-------------------------------------------|-----|
| <b>Abstract:</b> .....                    | III |
| <b>Table of Contents:</b> .....           | IV  |
| <b>Table of Figures:</b> .....            | V   |
| <b>Datapath Components:</b> .....         | 1   |
| <b>Program Counter (PC):</b> .....        | 1   |
| <b>Instruction Memory:</b> .....          | 2   |
| <b>Register File:</b> .....               | 3   |
| <b>Sign/Zero Extension:</b> .....         | 3   |
| <b>ALU:</b> .....                         | 5   |
| <b>Data Memory:</b> .....                 | 6   |
| <b>Write-Back Data Multiplexer:</b> ..... | 7   |
| <b>Control Unit:</b> .....                | 7   |
| <b>RTL:</b> .....                         | 11  |
| <b>Control Unit Truth Table:</b> .....    | 16  |
| <b>K-map and Boolean Equations:</b> ..... | 18  |
| <b>State Diagram:</b> .....               | 27  |
| <b>Conclusion:</b> .....                  | 30  |
| <b>Teamwork:</b> .....                    | 30  |

## **Table of Figures:**

|                                                              |    |
|--------------------------------------------------------------|----|
| Figure 1: PS Block.....                                      | 1  |
| Figure 2: PC Testbench Result.....                           | 1  |
| Figure 3: Instruction Memory Block .....                     | 2  |
| Figure 4: Instruction Memory Testbench Result.....           | 2  |
| Figure 5: Register File Block.....                           | 3  |
| Figure 6: Register File Testbench Result .....               | 3  |
| Figure 7: Sign/Zero Extension Block .....                    | 3  |
| Figure 8: Sign/Zero Extension Testbench Result.....          | 4  |
| Figure 9: ALU Block .....                                    | 5  |
| Figure 10: ALU Testbench Result.....                         | 5  |
| Figure 11: Data Memory Block .....                           | 6  |
| Figure 12: Data Memory Testbench Read Data Result.....       | 6  |
| Figure 13: Data Memory Testbench Write on Memory Result..... | 6  |
| Figure 14: Write-Back Data Multiplexer Block.....            | 7  |
| Figure 15: Testbench for Mux4-2 in Datapath Result.....      | 7  |
| Figure 16: Control Unit Block .....                          | 7  |
| Figure17 : Control Unit Testbench Result .....               | 8  |
| Figure 18: Datapath for Multi-Cycle .....                    | 9  |
| Figure 19: Testbench for Datapath.....                       | 9  |
| Figure 20: Control Unit Truth Table 1 .....                  | 16 |
| Figure 21: Control Unit Truth Table 3 .....                  | 17 |
| Figure 22: Control Unit Truth Table 2 .....                  | 17 |
| Figure 23: K-map RegDst bit 2.....                           | 18 |
| Figure 24: K-map RegDst bit 1.....                           | 19 |
| Figure 25: K-map ReadRd bit 2 .....                          | 19 |
| Figure 26: K-map ReadRd bit 1.....                           | 19 |
| Figure 27: K-map RegWr .....                                 | 20 |
| Figure 28: K-map ExtOp .....                                 | 20 |
| Figure 29: K-map ALUSrc bit 2 .....                          | 21 |

|                                     |    |
|-------------------------------------|----|
| Figure 30: K-map ALUSrc bit 1 ..... | 21 |
| Figure 31: K-map MemRd.....         | 22 |
| Figure 32: K-map MemWr .....        | 22 |
| Figure 33: K-map WBdata bit 2.....  | 23 |
| Figure 34: K-map WBdata bit 1.....  | 23 |
| Figure 35: K-map PCSrc bit 2 .....  | 24 |
| Figure 36: K-map PCSrc bit 1 .....  | 24 |
| Figure 37: K-map DisablePC.....     | 25 |
| Figure 38: K-map ldw_sdw .....      | 25 |
| Figure 39: K-map Exception.....     | 26 |
| Figure 40: State Diagram .....      | 27 |

## Datapath Components:

### Program Counter (PC):

Input to the PC comes via a multiplexer that chooses between jump register (JR) values from Rs, branch target addresses computed from PC plus a sign-extended immediate, or PC+1 for sequential execution. In addition to forwarding the current instruction address to the instruction memory, the PC also calculates branch targets by adding the current PC to the sign-extended immediate value. And stores the return address for the CALL instruction. The next sequential instruction address is created by adding 1 to the current PC value using the PC Increment Adder (+1). Additionally, this PC+1 value is kept as the return address for the CALL instruction, which is written to register R14, and used by the multiplexer in the PC update logic.



Figure 1: PS Block



Figure 2: PC Testbench Result

## Instruction Memory:

This component outputs the corresponding 32-bit instruction word after receiving the PC address as input. The instruction is then separated into its fields: the 14-bit immediate value spans bits [13:0], the first source register Rs is found in bits [21:18], the second source register Rt is found in bits [17:14], the destination register Rd occupies bits [25:22], and the 6-bit opcode is found in bits [31:26]. The next steps are then carried out using these extracted fields.



Figure 3: Instruction Memory Block



Figure 4: Instruction Memory Testbench Result

## Register File:

The register file generates the data held in the two 4-bit addresses, Rs and Rt, that were taken from the instruction. Depending on the kind of instruction, a multiplexer then decides whether the second operand should originate from Rt or Rd, or Rd+1. Both Rs and Rt values are used as operands in OR, ADD, SUB, and CMP instructions. On the other hand, the immediate value takes the role of the Rt operand in ORI, ADDI, LW, and SW instructions, which only require the Rs data. Meanwhile, Rd and Rd+1 take the role of the Rt



Figure 5: Register File Block



Figure 6: Register File Testbench Result

operand in the SDW instruction for the first and second cycles. And in the destination register selection is handled by a different multiplexer, which selects between Rd and the fixed register R14, which is where CALL instructions store the return address. For LDW instruction, the destination multiplexer alternates between Rd (first cycle) and Rd+1 (second cycle) to access consecutive registers. The control unit ensures Rd contains an even register number, throwing an exception if odd.

## Sign/Zero Extension:

In order to process the 14-bit immediate field [13:0], the Sign/Zero Extension Unit expands it to a complete 32-bit value. For ORI instruction, it performs a zero extension by adding the upper 18 bits with zeros. For ALU and memory-related instructions, including ADDI, LW, SW, LDW, SDW, J, CLL, and branch operations, it performs sign extension by replicating the sign bit (bit 13) through bits [31:14]. The resulting 32-bit



Figure 7: Sign/Zero Extension Block

value is sent to an ALU input multiplexer, where the ALUSrc control signal determines whether to use this extended immediate, the data from the Rt register, or, in the case of the second cycle of LDW/SDW, the immediate value incremented by one.



Figure 8: Sign/Zero Extension Testbench Result

## ALU:

The ALUSrc control signal is used by the ALU Input 2 Multiplexer to choose the second operand for the ALU. It picks the sign- or zero-extended immediate value for ORI, ADDI, LW, and SW instructions, the immediate value + 1 for LDW/SDW instructions, 0 for BZ, BGZ, and BLZ instructions, and the Rt register value for OR, ADD, SUB, and CMP instructions. This multiplexer is necessary for differentiating between register-to-immediate and register-to-register operations. After receiving two 32-bit inputs from its input multiplexers, the ALU uses ALUOp control signals to carry out the necessary operation. It generates a zero, Negative, Positive flags, and a 32-bit result. For memory instructions like LDW/SDW, LW, and SW, it calculates the effective address. For CMP, it outputs 0, -1, or +1 based on the operand comparison.



Figure 9: ALU Block



Figure 10: ALU Testbench Result

## Data Memory:

The address of the data memory is obtained from the ALU result (effective address), the ldw\_sdw for LDW/SDW instruction, with the MemRead/MemWrite control signals, determines the operation. It sends data to the write-back stage for load instructions LW and LDW. The memory data input is used to receive data from a register to store instructions SW and SDW.



Figure 11: Data Memory Block



Figure 13: Data Memory Testbench Write on Memory Result

## Write-Back Data Multiplexer:

This multiplexer uses the WBdata control signal to choose which data should be written to the target register. It selects the ALU result for instructions that are arithmetic or logical, such as OR, ADD, ORI, and ADDI. For load instructions LW and LDW, it chooses the output of the memory data. For CALL instructions, it determines the PC+1 value to store as the return address. The selected data is written to the register specified by the destination register multiplexer.



Figure 14: Write-Back Data Multiplexer Block



Figure 15: Testbench for Mux4-2 in Datapath Result

## Control Unit:

The control unit generates the required control signals for Datapath operation by decoding the 6-bit opcode. Depending on the kind of instruction, it identifies the **ALUOp** signal and enables **RegWr** to control register file updates. **RegDst** is used in destination register selection to select the Rd field, Rd+1 during the second LDW cycle, or R14 for CALL return addresses. **ReadRd** controls whether the second source comes from the Rt for OR, ADD, SUB, and CMP instructions,



Figure 16: Control Unit Block

Rd for SW and SWD instructions, or Rd+1 for SWD second cycle instruction. While **ALUSrc** chooses between the Rt register data, immediate value, or immediate+1 value. The **ExtOp** signal controls whether the 14-bit immediate is extended to zero (for logical operations) or to sign (for arithmetic and memory operations). **MemRd/MemWr** signals are used to control memory operations for load and store instructions. **WBdata** controls the selection of write-back data, selecting either PC+1 for CALL instructions, memory data for load operations (LW, LDW), or ALU results for logical and arithmetic operations (like OR, ORI, ADD, ADDI, and CMP). **PCSrc** selects between PC+1, PC+immediate for branch targets, or jump register values by evaluating the zero, negative, and positive flags from ALU results, as well as the opcode. The **ldw\_sdw** signal enables double-word memory operations (64-bit accesses) for LDW and SDW instructions. When active (**ldw\_sdw** = 1), the memory module performs two sequential 32-bit accesses controlled by **second\_cycle**, either reading/writing two consecutive memory locations. This ensures correct handling of 64-bit data, where the first cycle accesses the base address and the second cycle accesses the next word (address + 1). If **ldw\_sdw** = 0, only single-word (32-bit) operations (LW/SW) are executed. The **Exception\_Flag** signal is raised when the control unit detects illegal instruction behavior, such as misaligned LDW/SDW (odd-numbered register access). Lastly, **DisablePC** manages the process stall mechanism, which stops fresh instructions from being fetched during the second LDW/SDW operation cycle to finish the double-word transfers.



Figure17 : Control Unit Testbench Result

## Datapath:



Figure 18: Datapath for Multi-Cycle



Figure 19: Testbench for Datapath

We test every component and verify it is working, but the datapath has an issue that the alu result doesn't print right, but it writes to the Register correctly.

## **RTL:**

**OR** Rd, Rs, Rt:

**Fetch Instruction:** Instruction  $\leftarrow$  MEM [PC]

**Fetch Operands:** data1  $\leftarrow$  Reg (Rs) , data2  $\leftarrow$  Reg (Rt)

**Execute Operation:** ALU\_Result  $\leftarrow$  data1 | data2

**Write ALU Result:** Reg (Rd)  $\leftarrow$  ALU\_Result

**Next PC Address:** PC  $\leftarrow$  PC + 1

**ADD** Rd, Rs, Rt:

**Fetch Instruction:** Instruction  $\leftarrow$  MEM [PC]

**Fetch Operands:** data1  $\leftarrow$  Reg (Rs) , data2  $\leftarrow$  Reg (Rt)

**Execute Operation:** ALU\_Result  $\leftarrow$  data1 + data2

**Write ALU Result:** Reg (Rd)  $\leftarrow$  ALU\_Result

**Next PC Address:** PC  $\leftarrow$  PC + 1

**SUB** Rd, Rs, Rt:

**Fetch Instruction:** Instruction  $\leftarrow$  MEM [PC]

**Fetch Operands:** data1  $\leftarrow$  Reg (Rs) , data2  $\leftarrow$  Reg (Rt)

**Execute Operation:** ALU\_Result  $\leftarrow$  data1 - data2

**Write ALU Result:** Reg (Rd)  $\leftarrow$  ALU\_Result

**Next PC Address:** PC  $\leftarrow$  PC + 1

**CMP** Rd, Rs, Rt:

**Fetch Instruction:** Instruction  $\leftarrow$  MEM [PC]

**Fetch Operands:** data1  $\leftarrow$  Reg (Rs) , data2  $\leftarrow$  Reg (Rt)

**Execute Operation:** ALU\_Result  $\leftarrow$  if data1 == data2  $\rightarrow$  Reg(Rd)  $\leftarrow$  0

else if data1 < data2  $\rightarrow$  Reg(Rd)  $\leftarrow$  -1

else  $\rightarrow$  Reg(Rd)  $\leftarrow$  1

**Write ALU Result:** Reg (Rd)  $\leftarrow$  ALU\_Result

**Next PC Address:** PC  $\leftarrow$  PC + 1

**ORI** Rd, Rs, Imm:

**Fetch Instruction:** Instruction  $\leftarrow$  MEM [PC]

**Fetch Operands:** data  $\leftarrow$  Reg (Rs) , Immediate  $\leftarrow$  Zero\_Extend (Imm)

**Execute Operation:** ALU\_Result  $\leftarrow$  data | Immediate

**Write ALU Result:** Reg (Rd)  $\leftarrow$  ALU\_Result

**Next PC Address:** PC  $\leftarrow$  PC + 1

**ADDI** Rd, Rs, Imm:

**Fetch Instruction:** Instruction  $\leftarrow$  MEM [PC]

**Fetch Operands:** data  $\leftarrow$  Reg (Rs) , Immediate  $\leftarrow$  Sign\_Extend (Imm)

**Execute Operation:** ALU\_Result  $\leftarrow$  data + Immediate

**Write ALU Result:** Reg (Rd)  $\leftarrow$  ALU\_Result

**Next PC Address:** PC  $\leftarrow$  PC + 1

**LW** Rd , Imm(Rs):

**Fetch Instruction:** Instruction  $\leftarrow$  MEM [PC]

**Fetch Register:** Base $\leftarrow$  Reg (Rs)

**Execute Operation:** ALU\_Result  $\leftarrow$  Base + Sign-Extend (Imm)

**Memory Access:** data $\leftarrow$  MEM[ALU\_Result]

**Write Register Rd:** Reg (Rd)  $\leftarrow$  data

**Next PC Address:** PC  $\leftarrow$  PC + 1

**SW** Rd , Imm(Rs):

**Fetch Instruction:** Instruction  $\leftarrow$  MEM [PC]

**Fetch Register:** Base $\leftarrow$  Reg (Rs), data $\leftarrow$  Reg(Rd)

**Execute Operation:** ALU\_Result  $\leftarrow$  Base + Sign-Extend (Imm)

**Write Register Rd:** MEM[ALU\_Result]  $\leftarrow$  data

**Next PC Address:** PC  $\leftarrow$  PC + 1

**LDW** Rd, Imm (Rs):

**Cycle one:**

**Fetch Instruction:** Instruction  $\leftarrow$  MEM[PC]

**Fetch Register:** Base  $\leftarrow$  Reg(Rs)

**Execute Operation:** ALU\_Result  $\leftarrow$  Base + Sign-Extend(Imm)

**Memory Access:** data  $\leftarrow$  MEM[ALU\_Result]

**Write Register:** Reg(Rd)  $\leftarrow$  data

**Next PC Address:** PC (no increment - hold current PC)

**Cycle two:**

**Fetch Instruction:** No new fetch (hold current instruction)

**Fetch Register:** Base  $\leftarrow$  Reg(Rs)

**Execute Operation:** ALU\_Result  $\leftarrow$  Base + Sign-Extend(Imm) + 1

**Memory Access:** data  $\leftarrow$  MEM[ALU\_Result]

**Write Register:** Reg(Rd+1)  $\leftarrow$  data

**Next PC Address:** PC  $\leftarrow$  PC + 1

**SDW** Rd , Imm(Rs):

**Cycle one:**

**Fetch Instruction:** Instruction  $\leftarrow$  MEM[PC]

**Fetch Register:** Base  $\leftarrow$  Reg(Rs), data  $\leftarrow$  Reg(Rd)

**Execute Operation:** ALU\_Result  $\leftarrow$  Base + Sign-Extend(Imm)

**Memory Write:** MEM[ALU\_Result]  $\leftarrow$  data

**Next PC Address:** PC (no increment - hold current PC)

**Cycle two:**

**Fetch Instruction:** No new fetch (hold current instruction)

**Fetch Register:** Base  $\leftarrow$  Reg(Rs), data  $\leftarrow$  Reg(Rd+1)

**Execute Operation:** ALU\_Result  $\leftarrow$  Base + Sign-Extend(Imm) + 1

**Memory Write:** MEM[ALU\_Result]  $\leftarrow$  data

**Next PC Address:** PC  $\leftarrow$  PC + 1

**BZ** Rs, Label:

**Fetch Instruction:** Instruction  $\leftarrow$  MEM[PC]

**Fetch Register:** data  $\leftarrow$  Reg(Rs)

**Execute Operation:** Imm  $\leftarrow$  Sign\_Extend (Imm)

**Write Register Rd:** Zero  $\leftarrow$  (data == 0)

**Next PC Address:** if Zero: PC  $\leftarrow$  PC + Imm

else: PC  $\leftarrow$  PC + 1

**BGZ** Rs, Label:

**Fetch Instruction:** Instruction  $\leftarrow$  MEM[PC]

**Fetch Register:** data  $\leftarrow$  Reg(Rs)

**Execute Operation:** Imm  $\leftarrow$  Sign\_Extend (Imm)

**Write Register Rd:** Positive  $\leftarrow$  (data > 0)

**Next PC Address:** if Positive: PC  $\leftarrow$  PC + Imm

else: PC  $\leftarrow$  PC + 1

**BLZ** Rs, Label:

**Fetch Instruction:** Instruction  $\leftarrow$  MEM[PC]

**Fetch Register:** data  $\leftarrow$  Reg(Rs)

**Execute Operation:** Imm  $\leftarrow$  Sign\_Extend (Imm)

**Write Register Rd:** Negative  $\leftarrow$  (data < 0)

**Next PC Address:** if Negative : PC  $\leftarrow$  PC + imm

else : PC  $\leftarrow$  PC + 1

**JR Rs:**

**Fetch Instruction:** Instruction:  $\leftarrow$  MEM [PC]

**Calculate Target Address:** target  $\leftarrow$  reg(R(s))

**Jump:** PC  $\leftarrow$  target

**J Label:**

**Fetch Instruction:** Instruction:  $\leftarrow$  MEM [PC]

**Calculate Target Address:** target  $\leftarrow$  sign\_extend(Imm)

**Jump:** PC  $\leftarrow$  PC + target

**CLL Label:**

**Fetch Instruction:** Instruction:  $\leftarrow$  MEM [PC]

**Calculate Target Address:** target  $\leftarrow$  sign\_extend(Imm)

**Save Return Address:** Reg(R14)  $\leftarrow$  PC + 1

**Jump:** PC  $\leftarrow$  PC + target

## Control Unit Truth Table:

\*We couldn't take one screenshot because the table is too big

|    | A      | B     | C     | D     | E     | F     | G        | H        | I    | J      | K     | L      | M     | N     | O     | P      | Q     | R |
|----|--------|-------|-------|-------|-------|-------|----------|----------|------|--------|-------|--------|-------|-------|-------|--------|-------|---|
| 1  | opcode |       |       |       |       | cycle | negative | positive | zero | RegDst |       | ReadRd |       | RegWr | ExtOp | ALUSrc |       |   |
| 2  | bit 6  | bit 5 | bit 4 | bit 3 | bit 2 | bit 1 |          |          |      | bit 2  | bit 1 | bit 2  | bit 1 | bit 1 | bit 1 | bit 2  | bit 1 |   |
| 3  | 0      | 0     | 0     | 0     | 0     | 0     | X        | X        | X    | 0      | 0     | 0      | 0     | 1     | X     | 0      | 0     |   |
| 4  | 0      | 0     | 0     | 0     | 0     | 1     | X        | X        | X    | 0      | 0     | 0      | 0     | 1     | X     | 0      | 0     |   |
| 5  | 0      | 0     | 0     | 0     | 1     | 0     | X        | X        | X    | 0      | 0     | 0      | 0     | 1     | X     | 0      | 0     |   |
| 6  | 0      | 0     | 0     | 0     | 1     | 1     | X        | X        | X    | 0      | 0     | 0      | 0     | 1     | X     | 0      | 0     |   |
| 7  | 0      | 0     | 0     | 1     | 0     | 0     | X        | X        | X    | 0      | 0     | X      | X     | 1     | 0     | 0      | 1     |   |
| 8  | 0      | 0     | 0     | 1     | 0     | 1     | X        | X        | X    | 0      | 0     | X      | X     | 1     | 1     | 0      | 1     |   |
| 9  | 0      | 0     | 0     | 1     | 1     | 0     | X        | X        | X    | 0      | 0     | X      | X     | 1     | 1     | 0      | 1     |   |
| 10 | 0      | 0     | 0     | 1     | 1     | 1     | X        | X        | X    | X      | X     | 0      | 1     | 0     | 1     | 0      | 1     |   |
| 11 | 0      | 0     | 1     | 0     | 0     | 0     | 0        | X        | X    | 0      | 0     | X      | X     | 1     | 1     | 0      | 1     |   |
| 12 | 0      | 0     | 1     | 0     | 0     | 0     | 1        | X        | X    | 0      | 1     | X      | X     | 1     | 1     | 1      | 0     |   |
| 13 | 0      | 0     | 1     | 0     | 0     | 1     | 0        | X        | X    | X      | X     | 0      | 1     | 0     | 1     | 0      | 1     |   |
| 14 | 0      | 0     | 1     | 0     | 0     | 1     | 1        | X        | X    | X      | X     | 1      | 0     | 0     | 1     | 1      | 0     |   |
| 15 | 0      | 0     | 1     | 0     | 1     | 0     | X        | X        | X    | X      | X     | X      | X     | 0     | 1     | X      | X     |   |
| 16 | 0      | 0     | 1     | 0     | 1     | 1     | X        | X        | X    | X      | X     | X      | X     | 0     | 1     | X      | X     |   |
| 17 | 0      | 0     | 1     | 1     | 0     | 0     | X        | X        | X    | X      | X     | X      | X     | 0     | 1     | X      | X     |   |
| 18 | 0      | 0     | 1     | 1     | 0     | 1     | X        | X        | X    | X      | X     | X      | X     | 0     | X     | X      | X     |   |
| 19 | 0      | 0     | 1     | 1     | 1     | 0     | X        | X        | X    | X      | X     | X      | X     | 0     | 1     | X      | X     |   |
| 20 | 0      | 0     | 1     | 1     | 1     | 1     | X        | X        | X    | 1      | 0     | X      | X     | 1     | 1     | 1      | 1     |   |

  

| S     | T     | U     | V     | W     | X     | Y      | Z     | AA        | AB      |
|-------|-------|-------|-------|-------|-------|--------|-------|-----------|---------|
| ALUOp |       |       |       | MemRd | MemWr | WBdata |       | DisablePC | ldw sdw |
| bit 4 | bit 3 | bit 2 | bit 1 | bit 1 | bit 1 | bit 2  | bit 1 | bit 1     | bit 1   |
| 0     | 0     | 0     | 0     | X     | X     | 0      | 0     | 0         | 0       |
| 0     | 0     | 0     | 1     | X     | X     | 0      | 0     | 0         | 0       |
| 0     | 0     | 1     | 0     | X     | X     | 0      | 0     | 0         | 0       |
| 0     | 0     | 1     | 1     | X     | X     | 0      | 0     | 0         | 0       |
| 0     | 1     | 0     | 0     | X     | X     | 0      | 0     | 0         | 0       |
| 0     | 1     | 0     | 1     | X     | X     | 0      | 0     | 0         | 0       |
| 0     | 1     | 1     | 0     | 1     | 0     | 0      | 1     | 0         | 0       |
| 0     | 1     | 1     | 1     | 0     | 1     | X      | X     | 0         | 0       |
| 1     | 0     | 0     | 0     | 1     | 0     | 0      | 1     | 1         | 1       |
| 1     | 0     | 0     | 0     | 1     | 0     | 0      | 1     | 0         | 0       |
| 1     | 0     | 0     | 1     | 0     | 1     | X      | X     | 1         | 1       |
| 1     | 0     | 0     | 1     | 0     | 1     | X      | X     | 0         | 0       |
| 1     | 0     | 1     | 0     | X     | X     | X      | X     | 0         | 0       |
| 1     | 0     | 1     | 1     | X     | X     | X      | X     | 0         | 0       |
| 1     | 1     | 0     | 0     | X     | X     | X      | X     | 0         | 0       |
| 1     | 1     | 0     | 1     | X     | X     | X      | X     | 0         | 0       |
| 1     | 1     | 1     | 0     | X     | X     | X      | X     | 0         | 0       |
| 1     | 1     | 1     | 1     | X     | X     | X      | X     | 0         | 0       |

Figure 20: Control Unit Truth Table 1

| 21 | opcode |       |       |       |       |       | cycle | negative | positive | zero | PCSrc |       |
|----|--------|-------|-------|-------|-------|-------|-------|----------|----------|------|-------|-------|
|    | bit 6  | bit 5 | bit 4 | bit 3 | bit 2 | bit 1 |       |          |          |      | bit 2 | bit 1 |
| 23 | 0      | 0     | 0     | 0     | 0     | 0     | X     | X        | X        | X    | 0     | 0     |
| 24 | 0      | 0     | 0     | 0     | 0     | 1     | X     | X        | X        | X    | 0     | 0     |
| 25 | 0      | 0     | 0     | 0     | 1     | 0     | X     | X        | X        | X    | 0     | 0     |
| 26 | 0      | 0     | 0     | 0     | 1     | 1     | X     | X        | X        | X    | 0     | 0     |
| 27 | 0      | 0     | 0     | 1     | 0     | 0     | X     | X        | X        | X    | 0     | 0     |
| 28 | 0      | 0     | 0     | 1     | 0     | 1     | X     | X        | X        | X    | 0     | 0     |
| 29 | 0      | 0     | 0     | 1     | 1     | 0     | X     | X        | X        | X    | 0     | 0     |
| 30 | 0      | 0     | 0     | 1     | 1     | 1     | X     | X        | X        | X    | 0     | 0     |
| 31 | 0      | 0     | 1     | 0     | 0     | 0     | 0     | X        | X        | X    | X     | X     |
| 32 | 0      | 0     | 1     | 0     | 0     | 0     | 1     | X        | X        | X    | 0     | 0     |
| 33 | 0      | 0     | 1     | 0     | 0     | 1     | 0     | X        | X        | X    | X     | X     |
| 34 | 0      | 0     | 1     | 0     | 0     | 1     | 1     | X        | X        | X    | 0     | 0     |
| 35 | 0      | 0     | 1     | 0     | 1     | 0     | X     | X        | X        | 0    | 0     | 0     |
| 36 | 0      | 0     | 1     | 0     | 1     | 0     | X     | 0        | 0        | 1    | 0     | 1     |
| 37 | 0      | 0     | 1     | 0     | 1     | 1     | X     | X        | 0        | X    | 0     | 0     |
| 38 | 0      | 0     | 1     | 0     | 1     | 1     | X     | 0        | 1        | 0    | 0     | 1     |
| 39 | 0      | 0     | 1     | 1     | 0     | 0     | X     | 0        | X        | X    | 0     | 0     |
| 40 | 0      | 0     | 1     | 1     | 0     | 0     | X     | 1        | 0        | 0    | 0     | 1     |
| 41 | 0      | 0     | 1     | 1     | 0     | 1     | X     | X        | X        | X    | 1     | 0     |
| 42 | 0      | 0     | 1     | 1     | 1     | 0     | X     | X        | X        | X    | 0     | 1     |
| 43 | 0      | 0     | 1     | 1     | 1     | 1     | X     | X        | X        | X    | 0     | 1     |

Figure 22: Control Unit Truth Table 2

| 52 | opcode |       |       |       |       |       | cycle | Odd Rd | Odd Rs | negative | positive | zero | Exception bit 1 |   |
|----|--------|-------|-------|-------|-------|-------|-------|--------|--------|----------|----------|------|-----------------|---|
|    | bit 6  | bit 5 | bit 4 | bit 3 | bit 2 | bit 1 |       |        |        |          |          |      |                 |   |
| 54 | 0      | 0     | 0     | 0     | 0     | 0     | X     | X      | X      | X        | X        | X    | X               | 0 |
| 55 | 0      | 0     | 0     | 0     | 0     | 1     | X     | X      | X      | X        | X        | X    | X               | 0 |
| 56 | 0      | 0     | 0     | 0     | 1     | 0     | X     | X      | X      | X        | X        | X    | X               | 0 |
| 57 | 0      | 0     | 0     | 0     | 1     | 1     | X     | X      | X      | X        | X        | X    | X               | 0 |
| 58 | 0      | 0     | 0     | 1     | 0     | 0     | X     | X      | X      | X        | X        | X    | X               | 0 |
| 59 | 0      | 0     | 0     | 1     | 0     | 1     | X     | X      | X      | X        | X        | X    | X               | 0 |
| 60 | 0      | 0     | 0     | 1     | 1     | 0     | X     | X      | X      | X        | X        | X    | X               | 0 |
| 61 | 0      | 0     | 0     | 1     | 1     | 1     | X     | X      | X      | X        | X        | X    | X               | 0 |
| 62 | 0      | 0     | 1     | 0     | 0     | 0     | 0     | 0      | X      | X        | X        | X    | 0               | 0 |
| 63 | 0      | 0     | 1     | 0     | 0     | 0     | 0     | 1      | X      | X        | X        | X    | 1               | 0 |
| 64 | 0      | 0     | 1     | 0     | 0     | 0     | 1     | X      | X      | X        | X        | X    | X               | 0 |
| 65 | 0      | 0     | 1     | 0     | 0     | 1     | 0     | X      | 0      | X        | X        | X    | X               | 0 |
| 66 | 0      | 0     | 1     | 0     | 0     | 1     | 0     | X      | 1      | X        | X        | X    | X               | 1 |
| 67 | 0      | 0     | 1     | 0     | 0     | 1     | 1     | X      | X      | X        | X        | X    | X               | 0 |
| 68 | 0      | 0     | 1     | 0     | 1     | 0     | X     | X      | X      | X        | X        | X    | X               | 0 |
| 69 | 0      | 0     | 1     | 0     | 1     | 1     | X     | X      | X      | X        | X        | X    | X               | 0 |
| 70 | 0      | 0     | 1     | 1     | 0     | 0     | X     | X      | X      | X        | X        | X    | X               | 0 |
| 71 | 0      | 0     | 1     | 1     | 0     | 1     | X     | X      | X      | X        | X        | X    | X               | 0 |
| 72 | 0      | 0     | 1     | 1     | 1     | 0     | X     | X      | X      | X        | X        | X    | X               | 0 |
| 73 | 0      | 0     | 1     | 1     | 1     | 1     | X     | X      | X      | X        | X        | X    | X               | 0 |

Figure 21: Control Unit Truth Table 3

\*Each table has the important input for a specific flag, and the rest of the input will be Don't Care.

## K-map and Boolean Equations:

\*Bits 5 and 6 in the opcode are always 0:

### RegDst bit 2:

$$F = (O3 \And O2 \And O1)$$



Figure 23: K-map RegDst bit 2

### RegDst bit 1:

$$F = (O4 \And \sim O3 \And C)$$



Figure 24: K-map RegDst bit 1

**ReadRd bit 2:**

$$F = (O4 \& C)$$



**ReadRd bit 1:**

$$F = (O3) | (O4 \& \sim C)$$



Figure 25: K-map ReadRd bit 2

**RegWr:**

$$F = (\sim O_4 \& \sim O_3) | (\sim O_4 \& \sim O_2) | (\sim O_4 \& \sim O_1) | (\sim O_3 \& \sim O_2 \& \sim O_1) | (O_4 \& O_3 \& O_2 \& O_1)$$



Figure 27: K-map RegWr

**ExtOp:**

$$F = (O_1) | (O_2) | (O_4)$$



Figure 28: K-map ExtOp

### ALUSrc bit 2:

$$F = (O4 \& C) | (O4 \& O2)$$



Figure 29: K-map ALUSrc bit 2

### ALUSrc bit 1:

$$F = (O3) | (O4 \& \sim C)$$



Figure 30: K-map ALUSrc bit 1

### ALUOp:

We can make it equal the last 4 bits from the opcode.

### MemRd:

$$F = (\sim O1)$$



Figure 31: K-map MemRd

### MemWr:

$$F = (O1)$$



Figure 32: K-map MemWr

### WBdata bit 2:

$$F = (O_3 \& O_2 \& O_1)$$



Figure 33: K-map WBdata bit 2

### WBdata bit 1:

$$F = (\sim O_4 \& O_3 \& O_2) \mid (O_4 \& \sim O_3)$$



Figure 34: K-map WBdata bit 1

### PCSrc bit 2:

$$F = (O_4 \& O_3 \& \sim O_2 \& O_1)$$



Figure 35: K-map PCSrc bit 2

### PCSrc bit 1:

$$F = (O_4 \& O_2 \& \sim O_1 \& \sim N \& \sim P \& Z) \mid (O_4 \& O_2 \& O_1 \& \sim N \& P \& \sim Z) \mid (O_4 \& O_3 \& \sim O_1 \& N \& \sim P \& \sim Z) \mid (O_4 \& O_3 \& O_2)$$



Figure 36: K-map PCSrc bit 1

### DisablePC:

$$F = (O_4 \& \sim O_3 \& \sim O_2 \& \sim C)$$



Figure 37: K-map DisablePC

### ldw\_sdw:

$$F = (O_4 \& \sim O_3 \& \sim O_2 \& \sim C)$$



Figure 38: K-map ldw\_sdw

**Exception:**

$$F = (O_4 \& \sim O_3 \& \sim O_2 \& \sim O_1 \& \sim C \& OR_d) | (O_4 \& \sim O_3 \& \sim O_2 \& O_1 \& \sim C \& OR_s)$$



Figure 39: K-map Exception

## State Diagram:

This state diagram represents a 6-state finite state machine that controls a multi-cycle RISC processor implementation. The processor cycles through FETCH, DECODE, EXECUTE, MEMORY, and WRITEBACK states for normal instruction execution, with each state enabling specific pipeline registers and control signals. The DECODE state performs exception detection for invalid opcodes and improper register usage in LDW/SDW instructions, transitioning to an EXCEPTION state when violations occur. Multi-cycle operations like LDW and SDW require two memory cycles, implemented through a self-loop in the MEMORY state with a cycle counter tracking progress. Different instruction types follow distinct paths through the state machine: ALU operations bypass the MEMORY state, branches and jumps return directly to FETCH after execution, while memory operations proceed through all states. The design ensures proper pipeline control by selectively enabling stage registers (if\_id\_enable, id\_ex\_enable, ex\_mem\_enable, mem\_wb\_enable) and managing PC updates through the disablePC signal, creating a robust control mechanism that handles the processor's instruction set architecture requirements, including exception handling and multi-cycle memory operations.



Figure 40: State Diagram

➤ **States:**

- ❖ **FETCH** (000): Instruction fetch
- ❖ **DECODE** (001): Instruction decode
- ❖ **EXECUTE** (010): ALU operation
- ❖ **MEMORY** (011): Memory access
- ❖ **WRITEBACK** (100): Register write
- ❖ **EXCEPTION** (101): Exception handling

➤ **Instruction Types:**

- ❖ ALU Reg: OR, ADD, SUB, CMP
- ❖ ALU Imm: ORI, ADDI, etc
- ❖ Memory: LW, SW, LDW, SDW
- ❖ Branch: BZ, BGZ, BLZ
- ❖ Jump: JR, J, CALL

➤ **Multi-cycle Operations:**

- ❖ LDW/SDW requires 2 memory cycles
- ❖ The cycle counter tracks progress
- ❖ Exception on odd register numbers

➤ **Control Signals by State:**

➤ **FETCH:**

- ❖ if\_id\_enable = 1
- ❖ PC increment enabled

➤ **DECODE:**

- ❖ id\_ex\_enable = 1
- ❖ disablePC = 1
- ❖ Exception Detection

➤ **EXECUTE:**

- ❖ ex\_mem\_enable = 1
- ❖ ALU operation setup
- ❖ Address calculation

➤ **MEMORY:**

- ❖ mem\_wb\_enable = 1
- ❖ memRead/memWr control
- ❖ Multi-cycle handling

➤ **WRITEBACK:**

- ❖ regWr = 1
- ❖ Register destination control
- ❖ Branch/Jump PC control

## **Conclusion:**

In this project, a 32-bit multi-cycle RISC processor is designed and implemented using Verilog HDL. A comprehensive set of 16 operations, including arithmetic, logic, memory access, and control flow, is supported by the processor. The processor divides instruction execution into five separate stages (fetch, decode, execute, memory access, and write-back) to optimize hardware resource usage through the adoption of a multi-cycle architecture. For effective data routing, the Datapath combines essential parts such as a program counter, instruction memory, a 16-register file, an ALU, data memory, and a multiplexer system. The control unit provides 13 control signals. Multi-cycle memory operations (LDW/SDW) are handled by special mechanisms such as DisablePC, which also detects illegal instructions. Additionally, the processor includes flag generation (zero, negative, positive) to enable precise conditional branching.

## **Teamwork:**



We work on everything together in the code and report, and in the Datapath Design.