



# COMPUTER SYSTEM ARCHITECTURE

## LAB REPORT #03

### "Custom Processor"

**Prepared by:**  
SHAZIL 532263

**Presented To:**  
LE USAMA SHAUKAT

 NUST CEME  
DEPT. COMPUTER ENGINEERING

## TABLE OF CONTENT

- 1) Introduction
- 2) Objectives
- 3) Software or Equipments
- 4) Lab tasks
- 5) Outputs
- 6) Conclusion

## Lab#2 Custom Processor Design (Part 2)

### Objective

The purpose of this lab is to sequentially design and implement a custom microprocessor.

### Tools Required

- System Verilog
- Xilinx Vivado

### Lab Task Guidelines

- The implementation must follow a **modular approach**. Each task should be written as a **separate module** and instantiated in the top-level file.
- The design must be **parameterized**, with all parameters defined and passed from the top-level module (top.sv). The required parameters are listed below:

| Parameter Name (SystemVerilog) | Default Value | Description                   |
|--------------------------------|---------------|-------------------------------|
| IMEM_DEPTH                     | 4 words       | Depth of Instruction Memory   |
| REGF_WIDTH                     | 16 bits       | Width of Register File        |
| ALU_WIDTH                      | 16 bits       | Width of ALU                  |
| PROG_VALUE                     | 3             | Maximum Program Counter Value |

## Introduction to Processor Design

To design a simple microprocessor, the most essential foundation is the **Instruction Set Architecture (ISA)**. An ISA defines the collection of instructions that a processor can interpret and execute. In simple terms, it serves as the agreement between **software** (programs) and **hardware** (the processor).

## Core Components of a Processor

- **Register File**  
Registers provide very fast data access but can only store a limited amount of information. They act as temporary storage locations, holding values the processor needs immediately for ongoing operations.
- **Control Unit (CU)**  
The control unit acts like the **orchestrator** of the processor. It fetches instructions from memory, decodes them to determine the required action, and then coordinates other units (such as the ALU) to carry out the operation.
- **Arithmetic Logic Unit (ALU)**  
The ALU is the computational powerhouse of the processor. It performs arithmetic tasks (like addition or subtraction) and logical operations (such as AND, OR, NOT, and comparisons). All calculations directed by the control unit are executed here.
- **Memory**  
While technically external to the processor, memory (e.g., RAM or storage) is essential for its functioning. Instructions and data are fetched from memory, processed within the registers and ALU, and the results may be written back to memory afterward.

## Softwares used:

- System Verilog
- Xilinx Vivado

## Lab Task 5:

**Implement the Top Module while instantiating all the modules which we had made in last lab and do test them through testbench.**

### Code:

```
20 //////////////////////////////////////////////////////////////////
21 module Top#(
22     parameter A = 2,
23     parameter B = 4,
24     parameter E = 16,
25     parameter D = 2,
26     parameter NUM_REG = 4,
27     parameter G = 2,
28     parameter H = 16
29 ) (
30     input  logic clk,
31     input  logic reset,
32     output logic [E-1:0] f_result
33 );
34
35     logic [A-1:0] pc_out;
36     logic [E-1:0] instruction;
37
38     logic we;
39     logic [G-1:0] rsadd1, rsadd2, rdadd, opcode;
40     logic [E-1:0] wdata, reg_result1, reg_result2, alu_result;
41
42
43     PC #(A) pc_inst (
44         .clk(clk),
45         .reset(reset),
46         .add(pc_out)
47     );
48
49
50     InsMemory #(B, E, D) insmemory_inst (
51         .add(pc_out),
52         .Ins(instruction)
53     );
54
```

```
53      );
54
55
56      assign rdadd  = instruction[E-1      : E-G];
57      assign rsadd2 = instruction[E-G-1      : E-2*G];
58      assign rsadd1 = instruction[E-2*G-1 : E-3*G];
59      assign opcode = instruction[E-3*G-1 : E-4*G];
60      assign we     = instruction[0];
61
62
63      Reg_file #(E, NUM_REG, G) regfile_inst (
64          .clk(clk),
65          .we(we),
66          .rsadd1(rsadd1),
67          .rsadd2(rsadd2),
68          .rdadd(rdadd),
69          .wdata(wdata),
70          .result1(reg_result1),
71          .result2(reg_result2)
72      );
73
74
75      ALU #(H) alu_inst (
76          .A(reg_result1),
77          .B(reg_result2),
78          .opcode(opcode),
79          .result(alu_result)
80      );
81
82      assign wdata = alu_result;
83      assign f_result = alu_result;
84
85 endmodule
```

## TESTBENCH CODE:

```
21  
22  
23 module Top_tb;  
24  
25     logic clk;  
26     logic reset;  
27     logic [15:0]f_result;  
28  
29     Top dut (  
30         .clk(clk),  
31         .reset(reset),  
32         .f_result(f_result)  
33     );  
34  
35     always #5 clk = ~clk;  
36  
37 initial begin  
38     clk = 0;  
39     reset = 1;  
40  
41     #15 reset = 0;  
42  
43     #200;  
44  
45     $finish;  
46 end  
47  
48 endmodule  
49
```

## SCHEMATICS:



## SIMULATIONS:



## CONCLUSION:

The top module was successfully implemented by instantiating all previously designed modules. The integration verified correct connectivity between ALU, register memory, instruction memory, and program counter. The testbench confirmed that data flow and control signals worked as expected. The modular approach simplified debugging and ensured reusability of individual components. This task demonstrated the importance of hierarchical design in building complex digital systems. It also reinforced practical skills in Verilog coding, simulation, and verification using testbenches.