



**FACULTY OF ELECTRONIC ENGINEERING &  
TECHNOLOGY**

**NMJ31804**

**PRINCIPLES OF COMPUTER ARCHITECTURE**

**16-BIT CENTRAL PROCESSING UNIT**

**PROJECT REPORT**

**by**

YEANAT HOSSAIN NELOY

(211020050-5)

## TABLE OF CONTENT

| NO.                                          | CONTENT                                   | PAGE  |
|----------------------------------------------|-------------------------------------------|-------|
| 1.0                                          | INTRODUCTION                              | 3     |
| 2.0                                          | FUNCTIONAL STRUCTURE OF 16-BIT CPU        |       |
|                                              | 2.1 Register Transfer Level Diagram       | 4     |
|                                              | 2.2 Block Diagram of CPU                  | 4     |
| 2.3 Specifications of CPU Components/Modules | 5-9                                       |       |
| 3.0                                          | EXPLAINATION OF THE FETCH-EXECUTION CYCLE | 10-11 |
|                                              | 3.1 Instruction Set Architecture          | 12    |
| 4.0                                          | RESULT AND DISCUSSION                     | 13    |
| 5.0                                          | VERILOG CODE                              |       |
|                                              | 5.1 Verilog Code for CPU                  | 14    |
|                                              | 5.2 Verilog Code for ALU                  | 15    |
|                                              | 5.3 Verilog Code for Control Unit         | 16    |
|                                              | 5.4 Verilog Code for RAM                  | 17    |
|                                              | 5.5 Verilog Code for ROM                  | 17    |

## **1.0 INTRODUCTION**

We designed a simple 16-bit CPU that consists of Datapath unit and Control unit in our project. The data path is the collection of functional units such as multiplexers and arithmetic logic units. To carry out data processing tasks, the data path is necessary. Control Unit which we have known as Computer's central processing unit (CPU) which directs to the operation of the processor.

The control unit is an essential component inside the CPU that guides inputs and signals to the correct paths and components for their intended functions. It generates signals and coordinates the movement of data between different units within the processor. The control unit interprets instructions and controls the flow of data, converting external commands into control signals. It manages various execution units like the ALU, data buffers, and registers. Ultimately, the control unit ensures that the CPU responds correctly to instructions by directing signals to the appropriate components.

For our CPU's instruction set, it allows for data transfer between registers, performing arithmetic operations such as addition, subtraction, and multiplication, and executing logical operations for comparisons and bit manipulation. The addressing modes implemented are register addressing, enabling direct data transfer between registers, and immediate addressing, allowing for immediate loading of data into registers. These features provide flexibility and efficiency in data processing and manipulation within our CPU design.

By combining the Datapath unit, Control unit, ROM, and RAM, our CPU design enabled data processing, instruction execution, and storage functionalities. ROMs are the devices that used to store the information permanently while the RAM is the memory cells that are used to store or retrieve data. Thus, in our design, we included ROM and RAM to store the instruction set or the opcode and to store the data respectively.

## 2.0 FUNCTIONAL STRUCTURE OF 16-BIT CPU

### 2.1 Register Transfer Level Diagram



Figure 2.1: RTL Diagram

### 2.2 Block Diagram of CPU



Figure 1.2: Block Diagram of CPU

## 2.3 Specifications of CPU Components/Modules

### 6) Central Processing Unit (CPU)

|                      |                                                                 |
|----------------------|-----------------------------------------------------------------|
| <b>Module Name</b>   | CPU                                                             |
| <b>Inputs</b>        | CLK, rst, A                                                     |
| <b>Outputs</b>       | B, tOPcode, RESULT, OUT_A, OUT_B                                |
| <b>Functionality</b> | Implements a CPU with control, memory and arithmetic components |

The CPU module acts as the central processing unit of a computer system, carrying out important tasks such as fetching instructions, accessing memory, and completing computations. The CPU interacts with many crucial components, such as a control unit, ROM, RAM, and ALU. Together, these units work harmoniously to enable instruction execution, memory operations, and arithmetic/logical operations.

| Signal      | Direction | Bit Width | Description                         |
|-------------|-----------|-----------|-------------------------------------|
| CLK         | Input     | 1         | Clock input                         |
| rst         | Input     | 1         | Reset input                         |
| A           | Input     | 6         | Input bus                           |
| Opcode      | Internal  | 4         | Register for opcode                 |
| MAR1        | Internal  | 6         | Register for memory address         |
| PC          | Internal  | 6         | Program Counter (PC)                |
| instruction | Internal  | 16        | Instruction from ROM                |
| MBR1        | Internal  | 6         | Memory Buffer Register (MBR)        |
| Res         | Internal  | 6         | ALU result                          |
| OUTPUTA     | Internal  | 6         | Output from ALU (A)                 |
| OUTPUTB     | Internal  | 6         | Output from ALU (B)                 |
| C_ROM       | Internal  | 1         | Control signal for reading from ROM |
| C_RAM       | Internal  | 1         | Control signal for reading from RAM |
| B           | Output    | 6         | Output register (B)                 |
| tOPcode     | Output    | 4         | Output register (Opcode)            |
| RESULT      | Output    | 6         | Output register (Result)            |
| OUT_A       | Output    | 6         | Output register (OUT_A)             |
| OUT_B       | Output    | 6         | Output register (OUT_B)             |

## b) Arithmetic Logic Unit (ALU)

|                      |                                                                |
|----------------------|----------------------------------------------------------------|
| <b>Module Name</b>   | ALU                                                            |
| <b>Inputs</b>        | A, B, clk, opcode                                              |
| <b>Outputs</b>       | Result, A_out, B_out                                           |
| <b>Functionality</b> | Performs arithmetic and logical operations based on the opcode |

The ALU is a crucial component of a CPU responsible for performing arithmetic and logical operations on data. This ALU able to create a basic ALU capable of executing operations such as addition, subtraction, multiplication, bitwise AND, bitwise OR,, and data movement.

The module requires the inputs A and B as well as an opcode designating the intended operation. With an output of a result, it runs on a clock signal (clk). During each clock cycle, the ALU executes the operation specified by the opcode and updates the result accordingly.

The ALU utilizes a case statement to determine the operation to be performed based on the opcode value. For example, if the opcode is 4'h1, the ALU performs addition by adding values A and B. Similarly, different cases handle subtraction, multiplication, AND, OR, and NOT operations. The ALU also includes cases for moving the result to B\_out or moving the value of B to A\_out.

| Signal  | Direction | Bit Width | Description            |
|---------|-----------|-----------|------------------------|
| A       | Input     | 6         | Input bus              |
| B       | Input     | 6         | Input bus              |
| Clk     | Input     | 1         | Clock input            |
| opcode  | Input     | 4         | Operation code input   |
| result  | Output    | 6         | Result output register |
| OutputA | Output    | 6         | Output register (A)    |
| OutputB | Output    | 6         | Output register (B)    |

### c) Control Unit

|                         |                                                                        |
|-------------------------|------------------------------------------------------------------------|
| <b>Module Name</b>      | Control Unit                                                           |
| <b>Inputs</b>           | clock, reset                                                           |
| <b>Outputs</b>          | Address, Read_ROM, Read_RAM                                            |
| <b>Internal Signals</b> | y_present, y_next                                                      |
| <b>Constants</b>        | s1, s2, s3, s4, s5, s6, s7, s8, s9, s10, s11, s12, s13, s14, s15, s16  |
| <b>Registers</b>        | Address, Read_ROM, Read_RAM                                            |
| <b>Functionality</b>    | Controls the sequencing and control signals for ROM and RAM operations |

To coordinate the actions of other CPU modules, the control unit generates control signals. This control unit may be used to build a basic control system that can manage the retrieval of data from RAM and instructions from ROM.

| Signal       | Direction | Bit Width | Description               |
|--------------|-----------|-----------|---------------------------|
| clock        | Input     | 1         | Clock input               |
| reset        | Input     | 1         | Reset input               |
| Address      | Output    | 6         | Address output bus        |
| Read_ROM     | Output    | 1         | ROM read control signal   |
| Read_RAM     | Output    | 1         | RAM read control signal   |
| y_present    | Internal  | 4         | Present state register    |
| y_next       | Internal  | 4         | Next state register       |
| s1,s2,...s16 | Constants | 4         | State values              |
| Address      | Register  | 6         | Address register          |
| Read_ROM     | Register  | 1         | ROM read control register |
| Read_RAM     | Register  | 1         | RAM read control register |

The control unit operates based on a clock signal and a reset input. To control the actions of the CPU, it has a state machine that switches between several states. Each state corresponds to a certain operation, such as accessing information in RAM or reading instructions from ROM. For the ROM and RAM modules to communicate with each other properly, the control unit establishes the necessary control signals, such as the address and read signals. The present state and control signal generated are shown in table below:

| state | address | Read rom | Read ram | operation           |
|-------|---------|----------|----------|---------------------|
| S1    | 000000  | 1        | 0        | Read data from rom. |
| S2    | 000000  | 0        | 1        | Read data from ram. |
| S3    | 000001  | 1        | 0        | Read data from rom. |
| S4    | 000001  | 0        | 1        | Read data from ram. |
| S5    | 000010  | 1        | 0        | Read data from rom. |
| S6    | 000010  | 0        | 1        | Read data from ram. |
| S7    | 000011  | 1        | 0        | Read data from rom. |
| S8    | 000011  | 0        | 1        | Read data from ram. |
| S9    | 000100  | 1        | 0        | Read data from rom. |
| S10   | 000100  | 0        | 1        | Read data from ram. |
| S11   | 000101  | 1        | 0        | Read data from rom. |
| S12   | 000101  | 0        | 1        | Read data from ram. |
| S13   | 000110  | 1        | 0        | Read data from rom. |
| S14   | 000110  | 0        | 1        | Read data from ram. |
| S15   | 000111  | 1        | 0        | Read data from rom. |
| S16   | 000111  | 0        | 1        | Read data from ram. |

#### d) Random Access Memory (RAM)

|                      |                                          |
|----------------------|------------------------------------------|
| <b>Module Name</b>   | RAM                                      |
| <b>Inputs</b>        | Clock, write, Read, Addr                 |
| <b>Outputs</b>       | Data_Out                                 |
| <b>Functionality</b> | Implements a RAM module for data storage |

RAM (Random Access Memory) operates based on clock signals and control inputs for read and write operations. The module accepts a memory address as input and, if the read control signal is active, during a positive clock edge, extracts the associated data from the RAM. The module verifies the memory address when a read activity is detected and assigns the recovered data to the output port. The module keeps the output data in an undefinable state during write operations. This RAM module may be customised and extended to suit more advanced read-write RAM designs.

| Signal   | Direction | Bit Width | Description                |
|----------|-----------|-----------|----------------------------|
| Clock    | Input     | 1         | Clock input                |
| write    | Input     | 1         | Write control signal input |
| Read     | Input     | 1         | Read control signal input  |
| Addr     | Input     | 6         | Address input bus          |
| Data_Out | Output    | 6         | Data output register       |

### e) Read-Only Memory (ROM)

|               |                                          |
|---------------|------------------------------------------|
| Module Name   | ROM                                      |
| Inputs        | Clock, read, addr                        |
| Outputs       | Data                                     |
| Functionality | Reads data from ROM based on the address |

The ROM stores pre-defined data and retrieves it based on the given memory address when the read control signal is active. The module runs on a clock signal and accepts inputs for read control and memory address before generating the data that was retrieved. If the read control signal is on at each positive clock edge, the module uses a case statement to examine the memory address. The correct information will be assigned to the output port based on the address value. When a read control signal is not active, the output data is set to an undefinable state. This ROM module offers fundamental read-only memory capability and may be extended as necessary with extra information and addresses.

| Signal | Direction | Bit Width | Description               |
|--------|-----------|-----------|---------------------------|
| Clock  | Input     | 1         | Clock input               |
| read   | Input     | 1         | Read control signal input |
| addr   | Input     | 6         | Address input bus         |
| Data   | Output    | 16        | Data output bus           |

### **3.0 EXPLANATION OF THE FETCH-EXECUTION CYCLE**

The instruction cycle, also known as the fetch-execute cycle, is the process that the central processing unit (CPU) follows from booting up until the computer shuts down in order to process instructions.

#### **Fetch Cycle:**

This cycle begins when the reset signal is high. The reset input in the control unit is active low, meaning that if it is low, the entire process will be reset. Therefore, when the reset signal is high, the system starts working by sending the address and activating the Read\_ROM signal. This allows the system to fetch the instruction from the specified address of the ROM.

#### **Decoding the instruction:**

The fetched 16-bit instruction is decoded into three parts as follows:

1. Opcode: These are the first four most significant bits, which are stored in a four-bit register called "opcode." The opcode is then used to select the operation of the Arithmetic Logic Unit.
2. Ignored bits: The six bits following the opcode are ignored.
3. Address of value B: The last six least significant bits are stored in a six-bit register called "MAR1". The address in MAR1 is then used to fetch data B from the RAM.

#### **Execution Cycle:**

In the second state, which occurs after fetching the instruction, the control unit activates the Read\_RAM signal. The address stored in MAR1 is sent to the RAM, and the data in that address is sent to Register B. The data in Register B is used as one operand in the Arithmetic Logic Unit (ALU), while the second operand (A) is received as an immediate input. Additionally, the opcode is sent to the ALU to determine the operation to be performed on the given operands. Finally, the result is stored in a register with the same name. Two additional registers, Out\_A and Out\_B, are used to store the results of data transfer operations.

This fetch-execution cycle is repeated with different addresses using two states: one to fetch the instruction and another to fetch the data of value B, until the reset signal is low.

### 3.1 Instruction Set Architecture

| ALU Selection | ALU Operation                                                                           |
|---------------|-----------------------------------------------------------------------------------------|
| <b>0001</b>   | Addition ( <b>Arithmetic</b> ), stored in reg A.                                        |
| <b>0010</b>   | Subtraction ( <b>Arithmetic</b> ), stored in result                                     |
| <b>0011</b>   | Multiplication ( <b>Arithmetic</b> ), stored in result                                  |
| <b>0100</b>   | AND gate ( <b>Logic</b> ), stored in result                                             |
| <b>0101</b>   | OR gate ( <b>Logic</b> ), stored in result                                              |
| <b>0110</b>   | Move result to B_out                                                                    |
| <b>0111</b>   | Move value in register B to Register A ( <b>Register Addressing</b> )                   |
| <b>1000</b>   | Move value in register B directly from RAM to Register A ( <b>Register Addressing</b> ) |

TABLE 3.1.1: List of instruction set based on opcode

The system employs a table that defines various operations, such as addition, subtraction, multiplication, AND gate, OR gate, and NOT gate, based on their corresponding opcode values. Some of these operations involve the interaction between the user-provided value A and the value B obtained from the RAM, which is stored in the "Result" register. Other operations are performed on the contents of the register A\_out, which represents the value of A displayed in waveform format. Additionally, the system includes instructions for data movement between registers. This can be achieved by transferring the value from the "Result" register to register B using register addressing, or by copying the value from register B to register A. Moreover, one of the operations directly moves the value of register B to the A\_out register.

## 4.0 RESULTS AND DISCUSSION



Figure 4.1: Waveform Result

The presented system comprises three input signals, namely clock (clk), reset (rst), and A, along with five output signals, including trace opcode (tOPcode), B, RESULT, OUT\_A, and OUT\_B. To activate the system, it is imperative to ensure that the active low reset signal (rst) remains inactive by maintaining a high state. Initialization of the system commences with opcode 0, which is deliberately devoid of any operations to prevent undesirable outcomes. For illustrative purposes, both operands, A and B, are fixed at specific values: A = 0001002 (410) and B = 0011002 (1210).

To execute the first opcode, the system necessitates three clock cycles for fetching, with each fetchexecution cycle spanning two clock cycles. Each clock cycle corresponds to the completion of one state within the control unit.

The initial three opcodes are designed to perform arithmetic operations. The first opcode, 00012, facilitates an addition process, resulting in  $4 + 12 = 16 = 0100002$ , which is subsequently stored in register A. Subsequently, the second opcode, 00102, initiates a subtraction process, yielding  $4 - 12 = -8 = 1110002$  in two's complement form. Lastly, the third opcode, 00112, triggers a multiplication process, leading to  $4 \times 12 = 48 = 1100002$ .

The subsequent two opcodes are dedicated to logical operations. The fourth opcode, 01002, enables the system to perform an 'AND' operation, resulting in the output 0001002 through the bitwise operation 0001002 & 0011002. On the other hand, the fifth opcode, 01012, facilitates an 'OR' operation, generating the output 0011002 through the bitwise operation 0001002 | 0011002.

The final three opcodes are associated with data transfer operations. The sixth opcode, 01102, allows the system to transfer data from the result register to the B\_out register, denoted as  $B_{out} \leftarrow RESULT$ . Subsequently, the seventh opcode, 01112, enables the transfer of data from the B\_out register to the A\_out register. Lastly, the last opcode, 10002, permits the system to receive immediate data from the RAM and transfer it to the A\_out register, represented as  $A_{out} \leftarrow B$ .

## 5.0 VERILOG CODE

### 5.1 Verilog Code for CPU

```
1 module CPU(CLK,rst,A,B,tOPcode,RESULT,OUT_A,OUT_B);
2   input CLK;
3   input [5:0]A;
4   input rst;
5
6   reg [3:0]OPcode;
7   reg [5:0]MAR1;
8   wire [5:0]PC;
9   wire [15:0]instruction;
10  wire [5:0]NBR1;
11  wire [5:0]Res;
12  wire [5:0]OUTPUTA,OUTPUTB;
13  wire C_ROM,C_RAM;
14
15  output reg [5:0]B;
16  output reg [3:0]tOPcode;
17  output reg [5:0] RESULT;
18  output reg [5:0] OUT_A,OUT_B;
19
20 Control_unit CU1(
21   .clock(CLK),
22   .reset(rst),
23   .Address(PC),
24   .Read_ROM(C_ROM),
25   .Read_RAM(C_RAM)
26 );
27
28 ROM ROM1(
29   .clock(CLK),
30   .read(C_ROM),
31   .addr(PC),
32   .data(instruction)
33 );
34
35 always @ (posedge CLK)
36 begin
37   OPcode = instruction[15:12];
38   MAR1= instruction[5:0];
39 end
40
41 RAM RAM1(
42   .Clock(CLK),
43   .write(cw),
44   .Read(C_RAM),
45   .Addr(MAR1),
46   .Data_Out(NBR1)
47 );
48
49 always @ (posedge CLK)
50 begin
51   B= NBR1;
52   tOPcode= OPcode;
53 end
54
55 ALU ALU1(
56   .A(A),
57   .B(B),
58   .clk(CLK),
59   .opcode(OPcode),
60   .result(Res),
61   .OutputA(OUTPUTA),
62   .OutputB(OUTPUTB)
63 );
64
65 always @ (posedge CLK)
66 begin
67   RESULT= Res;
68   OUT_A= OUTPUTA;
69   OUT_B= OUTPUTB;
70 end
71 endmodule
```

### 5.2 Verilog Code for ALU

```
7   input clk;
8   output Carry_out;
9   output reg [5:0] result,A_out,B_out;
10
11  always @ (posedge clk) begin
12    case (opcode)
13      4'h1: begin // Addition (Register addressing mode)
14        A_out = A + B;
15      end
16      4'h2: begin // Subtraction
17        result = A - B;
18      end
19      4'h3: begin // Multiplication
20        result = A * B;
21      end
22      4'h4: begin // And gate
23        result = A & B;
24      end
25      4'h5: begin // Or gate
26        result = A | B;
27      end
28      4'h6: begin
29        B_out = result;
30      end
31      4'h7:begin
32        A_out = B_out;
33      end // (Register addressing mode)
34      4'h8:begin
35        A_out <= B;
36      end
37
38      default: // (No Operation)
39        result = 6'h0;
40    endcase
41  end
42
43 endmodule
```

## Verilog Code for Control Unit

```
1 module Control_unit (clock, reset, Address, Read_ROM, Read_RAM);
2   input clock, reset;
3   output [5:0] Address;
4   output Read_ROM, Read_RAM;
5   parameter [3:0] s1 = 4'b0000, s2 = 4'b0001, s3 = 4'b0010, s4 = 4'b0011,
6     s5 = 4'b0100, s6 = 4'b0101, s7 = 4'b0110, s8 = 4'b0111, s9 = 4'b1000, s10 = 4'b1001, s11 =
7     4'b1010, s12 = 4'b1011,
8     s13 = 4'b1100, s14 = 4'b1101, s15 = 4'b1110, s16 = 4'b1111;
9   reg [3:0] y_present, y_next;
10  reg [5:0] Address;
11  reg Read_ROM, Read_RAM;
12
13  always@(y_present)
14    begin
15      case (y_present)
16        s1: begin
17          y_next <= s2;
18          Address <= 6'b000000;
19          Read_ROM<= 1'b1;
20          Read_RAM <= 1'b0;
21        end
22        s2: begin
23          y_next <= s3;
24          Address <= 6'b000000;
25          Read_ROM <= 1'b0;
26          Read_RAM <= 1'b1;
27        end
28        s3: begin
29          y_next <= s4;
30          Address <= 6'b000001;
31          Read_ROM <= 1'b1;
32          Read_RAM <= 1'b0;
33        end
34        s4: begin
35          y_next <= s5;
36          Address <= 6'b000001;
37          Read_ROM <= 1'b0;
38          Read_RAM <= 1'b1;
39        end
40        s5: begin
41          y_next <= s6;
42          Address <= 6'b000010;
43          Read_ROM <= 1'b1;
44          Read_RAM <= 1'b0;
45        end
46        s6: begin
47          y_next <= s7;
48          Address <= 6'b000010;
49          Read_ROM <= 1'b0;
50          Read_RAM <= 1'b1;
51        end
52        s7: begin
53          y_next <= s8;
54          Address <= 6'b000011;
55          Read_ROM <= 1'b1;
56          Read_RAM <= 1'b0;
57        end
58        s8: begin
59          y_next <= s9;
60          Address <= 6'b000011;
61          Read_ROM <= 1'b0;
62          Read_RAM <= 1'b1;
63        end
64        s9: begin
65          y_next <= s10;
66          Address <= 6'b000100;
67          Read_ROM <= 1'b1;
68          Read_RAM <= 1'b0;
69        end
70    end
71  end
```

## 5.3 Verilog Code for RAM

```
1 module RAM (Clock, write, Read, Addr, Data_Out);
2   input [5:0] Addr;
3   input Clock, Read, write;
4   output reg [5 :0] Data_Out;
5
6   always @ (posedge Clock)
7     if (Read)
8       begin
9         case(Addr)
10           6'b000001: Data_Out <- 6'b000100;
11           endcase
12         end
13       else
14         Data_Out <- 6'bx;
15   endmodule
```

## 5.4 Verilog Code for ROM

```
1 module ROM(clock,read, addr , data);
2   input clock,read;
3   input [5:0] addr;
4   output reg [15:0] data;
5
6   always @(posedge clock)
7     if (read)
8       begin
9         case(addr)
10           6'b000000 : data <= 16'h1001;
11           6'b000001 : data <= 16'h2001;
12           6'b000010 : data <= 16'h3001;
13           6'b000011 : data <= 16'h4001;
14           6'b000100 : data <= 16'h5001;
15           6'b000101 : data <= 16'h6001;
16           6'b000110 : data <= 16'h7001;
17           6'b000111 : data <= 16'h8001;
18
19       endcase
20     end
21   else
22     data <= 16'bz;
23 endmodule
```