# FPGA Application Week 10 Homework

# CYEE 10828241 Chen Da-Chuan

# May 1, 2023

# **Contents**

| 1  | Hon             | nework 10-1 Read Only Memory             | 2  |
|----|-----------------|------------------------------------------|----|
|    | 1.1             | Objective                                | 2  |
|    | 1.2             | Operation                                | 2  |
|    | 1.3             | Code                                     | 2  |
|    | 1.4             | Result                                   | 3  |
| 2  | Hon             | nework 10-2 Data Direct System           | 3  |
|    | 2.1             | Objective                                | 3  |
|    | 2.2             | Operation                                | 4  |
|    | 2.3             | Code                                     | 4  |
|    | 2.4             | Result                                   | 4  |
| 3  | Hon             | nework 10-3 Write Address Control System | 5  |
| •  | 3.1             | Objective                                | 5  |
|    | 3.2             | Operation                                | 5  |
|    | 3.3             | Code                                     | 5  |
|    | 3.4             | Result                                   | 6  |
|    | J. <del>T</del> | Nesuit                                   | U  |
| 4  | Hon             | nework 10-4 Full Data Pipeline           | 6  |
|    | 4.1             | Objective                                | 6  |
|    | 4.2             | Operation                                | 8  |
|    | 4.3             | Code                                     | 8  |
|    | 4.4             | Result                                   | 10 |
| 5  | Hon             | nework 10-5 Instruction Explanation      | 10 |
| 6  | Λnn             | pendix                                   | 11 |
| U  | 6.1             | ALU Operation Code                       |    |
|    | 6.2             | Instruction Format                       |    |
|    | 6.3             | Pipeline CPU Stages                      |    |
|    | 6.4             | CPU State Machine                        |    |
|    | 0.4             | CF O State Machine                       | 12 |
| Li | ist o           | f Figures                                |    |
|    |                 |                                          |    |
|    | 1               | Main file                                | 3  |
|    | 2               | ROM data                                 | 3  |
|    | 3               | Test file                                | 3  |
|    | 4               | Homework 10-1 Result                     | 3  |
|    | 5               | Main file                                | 4  |
|    | 6               | Test file                                | 4  |
|    | 7               | Homework 10-2 Result                     | 4  |
|    | 8               | Main file                                | 5  |
|    | 9               | Test file                                | 5  |
|    | 10              | Homework 10.3 Result                     | 6  |

| 11     | Homework 10-4 Data Pipeline    | 7  |
|--------|--------------------------------|----|
| 12     | Main file                      |    |
| 13     | Test file                      | 9  |
| 14     | Homework 10-4 Result           | 10 |
| 15     | CPU steps                      | 12 |
| List o | f Tables                       |    |
| 1      | Homework 10-1 Operation detail |    |
| 2      | Exercise 10-1 Truth Table      | 3  |
| 3      | Homework 10-2 Operation detail |    |
| 4      | Exercise 10-2 Truth Table      | 5  |
| 5      | Homework 10-3 Operation detail | 5  |
| 6      | Exercise 10-3 Truth Table      | 6  |
| 7      | Homework 10-4 Operation detail | 8  |
| 8      | Exercise 10-4 Truth Table      | 10 |
| 9      | ALU Operation                  | 11 |
| 10     | Instruction Format             | 11 |
| 11     | Pipeline CPU Stages            | 11 |

# 1 Homework 10-1 Read Only Memory

### 1.1 Objective

Create a ROM module storing 16-bit data.

### 1.2 Operation

Table 1: Homework 10-1 Operation detail

| type       | var  | operation                                |
|------------|------|------------------------------------------|
| input      | addr | Address of data stored in ROM to be read |
| input      | clk  | Clock signal                             |
| output reg | q    | Read ROM data                            |

#### 1.3 Code

- 1. Figure 1 Line13-13: Declare register to store ROM data.
- 2. Figure 1 Line23-26: Load data into ROM from file.
- 3. Figure 1 Line28-29: Output the specified data from ROM.
- 4. Figure 2 Line1-5: 5 instructions to be stored in ROM.
- 5. Figure 3 Line10-14: Set initial value of address and clock.
- 6. Figure 3 Line16-16: Add specified address by 1 every 100ns.
- 7. Figure 3 Line17-17: Alternate clock signal every 50ns.

```
// Quartus Prime Verilog Template
// Single Port ROM

module rom_v
#(parameter DATA_wIDTH=16, parameter ADDR_WIDTH=8)

| (input [(ADDR_WIDTH=1):0] addr, input clk, output reg [(DATA_WIDTH=1):0] q
| (input c
```

```
1 0000111100001111
2 0000111011110000
3 1010101010101010
4 1010101001010101
5 1010000011110000
```

#### Figure 2: ROM data

Figure 3: Test file

Figure 1: Main file

#### 1.4 Result



Figure 4: Homework 10-1 Result

Table 2: Exercise 10-1 Truth Table

| clk↑(ns)    | 50               | 150              | 250              | 350              |  |
|-------------|------------------|------------------|------------------|------------------|--|
| addr        | 00000000         | 0000001          | 00000010         | 00000011         |  |
| q           | 0000111100001111 | 0000111011110000 | 1010101010101010 | 1010101001010101 |  |
| description | q=rom[0]<br>pass | q=rom[1]<br>pass | q=rom[2]<br>pass | q=rom[3]<br>pass |  |

# 2 Homework 10-2 Data Direct System

### 2.1 Objective

Create a data direct system selecting data either from ROM or register.

### 2.2 Operation

Table 3: Homework 10-2 Operation detail

| type   | var   | operation                                           |  |  |  |  |  |
|--------|-------|-----------------------------------------------------|--|--|--|--|--|
| input  | DA    | Input data 1 from register                          |  |  |  |  |  |
| input  | DB    | Input data 2 from register                          |  |  |  |  |  |
| input  | ROMX  | Input data 2 from ROM                               |  |  |  |  |  |
| input  | clock | Clock signal                                        |  |  |  |  |  |
| input  | dir   | Data direction, selects either from register or ROM |  |  |  |  |  |
| output | DATAA | Output data 1                                       |  |  |  |  |  |
| output | DATAB | Output data 2                                       |  |  |  |  |  |

#### **2.3** Code

- 1. Figure 5 Line10-11: When triggered by "dir", "DB", or "ROMX", if "dir" is 1, select data from ROM.
- 2. Figure 5 Line12-13: When triggered by "dir", "DB", or "ROMX", if "dir" is 0, select data from register.
- 3. Figure 5 Line16-20: Output received and selected data.
- 4. Figure 6 Line9-17: Set initial values, and set "dir" as 1 at 500ns.
- 5. Figure 6 Line19-22: Alternate "clock" signal every 50ns, add "DA", "DB", "ROMX" by 1 every 100ns.

Figure 5: Main file

Figure 6: Test file

#### 2.4 Result



Figure 7: Homework 10-2 Result

Table 4: Exercise 10-2 Truth Table

| clk † (ns)  | 50                           | 150                          | 250                          | 350                           | 450                          | 550                            | 650                            | 750                            | 850                            | 950                            |
|-------------|------------------------------|------------------------------|------------------------------|-------------------------------|------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|
| DA (8'h)    | 86                           | 86                           | 88                           | 89                            | 8a                           | 8b                             | 8c                             | 8d                             | 8e                             | 8f                             |
| DB (8'h)    | 68                           | 69                           | 6a                           | 6b                            | 6c                           | 6d                             | 6e                             | 6f                             | 70                             | 71                             |
| ROMX (8'h)  | 49                           | 4a                           | 4b                           | 4c                            | 4d                           | 4e                             | 4f                             | 50                             | 51                             | 52                             |
| dir         | 0                            | 0                            | 0                            | 0                             | 0                            | 1                              | 1                              | 1                              | 1                              | 1                              |
| DATAA (8'h) | 86                           | 87                           | 88                           | 89                            | 8a                           | 8b                             | 8c                             | 8d                             | 8e                             | 8f                             |
| DATAB (8'h) | 68                           | 69                           | 6a                           | 6b                            | 6c                           | 4e                             | 4f                             | 50                             | 51                             | 52                             |
| description | DATAA=DA<br>DATAB=DB<br>pass | DATAA=DA<br>DATAB=DB<br>pass | DATAA=DA<br>DATAB=DB<br>pass | qDATAA=DA<br>DATAB=DB<br>pass | DATAA=DA<br>DATAB=DB<br>pass | DATAA=DA<br>DATAB=ROMX<br>pass | DATAA=DA<br>DATAB=ROMX<br>pass | DATAA=DA<br>DATAB=ROMX<br>pass | DATAA=DA<br>DATAB=ROMX<br>pass | DATAA=DA<br>DATAB=ROMX<br>pass |

# 3 Homework 10-3 Write Address Control System

### 3.1 Objective

Create a write address control system, which stores the writing address of the data processed by ALU.

### 3.2 Operation

Table 5: Homework 10-3 Operation detail

| type   | var   | operation                                         |
|--------|-------|---------------------------------------------------|
| input  | R3_0  | Address option 1                                  |
| input  | R11_8 | Address option 2                                  |
| input  | clk   | Clock signal                                      |
| input  | dir   | Direction signal, selecting either address 1 or 2 |
| output | addr  | Output/selected address                           |

#### 3.3 Code

- 1. Figure 8 Line6-12: When triggered by clock, if "dir" is 0, output "R3\_0", else output "R11\_8".
- 2. Figure 9 Line9-15: Set initial values.
- 3. Figure 9 Line17-20: Alternate clock signal every 50ns, and add 1 to "R3\_0", "R11\_8", "dir" every 100ns.

```
module writeaddr_v (R3_0, R11_8, clk, dir, addr);
input [3:0] R3_0, R11_8;
input clk, dir;
4 output reg [3:0] addr;

always@(posedge clk)

begin if (dir == 0)
addr = R3_0;
else addr = R11_8;
end

endmodule
```

Figure 8: Main file

```
itimescale ins/ins
module test_writeaddr;
reg [3:0] R3_0, R11_8;
reg clk, dir;
writeaddr_v DUT(.R3_0(R3_0), .R11_8(R11_8), .clk(clk), .dir(dir), .addr(addr));

initial
begin
R3_0 = 4'h6;
R11_8 = 4'h6;
R11_8 = 4'h6;
dir = 0;
end

always #100 R3_0 = R3_0 + 1;
always #100 R3_0 = R3_0 + 1;
always #100 R3_0 = R3_0 + 1;
always #100 R11_8 = R11_8 + 1;
always #100 dir = dir + 1;
endmodule
```

Figure 9: Test file

### 3.4 Result



Figure 10: Homework 10-3 Result

Table 6: Exercise 10-3 Truth Table

| clk↑(ns)    | 50                | 150                | 250               | 350                | 450               | 550                | 650               | 750                | 850               | 950                |
|-------------|-------------------|--------------------|-------------------|--------------------|-------------------|--------------------|-------------------|--------------------|-------------------|--------------------|
| R3_0 (8'h)  | 6                 | 7                  | 8                 | 9                  | a                 | b                  | С                 | d                  | e                 | f                  |
| R11_8 (8'h) | 3                 | 4                  | 5                 | 6                  | 7                 | 8                  | 9                 | a                  | b                 | С                  |
| dir         | 0                 | 1                  | 0                 | 1                  | 0                 | 1                  | 0                 | 1                  | 1                 | 1                  |
| addr (8'h)  | 6                 | 4                  | 8                 | 6                  | a                 | 8                  | c                 | a                  | e                 | С                  |
| description | addr=R3_0<br>pass | addr=R11_8<br>pass |

# 4 Homework 10-4 Full Data Pipeline

# 4.1 Objective

Fully combine all of the previous coded modules to create a full data pipeline. Beside this, the relating modules are modified to accommodate  $2^4 = 16$  8-bit data in register.



Figure 11: Homework 10-4 Data Pipeline

### 4.2 Operation

Table 7: Homework 10-4 Operation detail

| type   | var  | operation                                     |
|--------|------|-----------------------------------------------|
| input  | WE3  | write enable, which writes data into register |
| input  | PC   | Address of data stored in ROM to be read      |
| input  | clk  | Clock signal                                  |
| output | R0   | ROM output stage 0                            |
| output | R1   | ROM output stage 1                            |
| output | R2   | ROM output stage 2                            |
| output | B0   | RAM address 1                                 |
| output | B1   | RAM address 2                                 |
| output | B2   | RAM address 3                                 |
| output | B3   | RAM address 4                                 |
| output | B4   | RAM address 5                                 |
| output | B5   | RAM address 6                                 |
| output | В6   | RAM address 7                                 |
| output | B7   | RAM address 8                                 |
| output | B8   | RAM address 9                                 |
| output | В9   | RAM address 10                                |
| output | B10  | RAM address 11                                |
| output | B11  | RAM address 12                                |
| output | B12  | RAM address 13                                |
| output | B13  | RAM address 14                                |
| output | B14  | RAM address 15                                |
| output | B15  | RAM address 16                                |
| output | Da   | Register output data 1                        |
| output | Db   | Register output data 2                        |
| output | A    | ALU input data 1                              |
| output | В    | ALU input data 2                              |
| output | D    | ALU output data                               |
| output | addr | Where to write ALU output data                |

#### **4.3** Code

- 1. Figure 12 Line16-18: ROM, which stores commands by PC and outputs to register.
- 2. Figure 12 Line21-24: Data register & I/O system, which stores data and outputs to data driven system.
- 3. Figure 12 Line28-29: Command register, holds command from ROM for 1 clock cycle and outputs to next command register.
- 4. Figure 12 Line32-33: Data driven system, which receives data from data register & I/O system and command register, and outputs to ALU.
- 5. Figure 12 Line37-38: Command register, holds command from previous command register for 1 clock cycle and outputs to write address control system.
- 6. Figure 12 Line41-41: ALU, which receives data from data driven system and outputs to data register.
- 7. Figure 12 Line45-46: Data register, which receives data from ALU and outputs to data register & I/O system.
- 8. Figure 12 Line49-50: Write address control system, which receives command and outputs to address register.
- 9. Figure 12 Line54-55: Address register, which receives address from write address control system and outputs to data register & I/O system.
- 10. Figure 13 Line11-14: Include data pipeline module.

- 11. Figure 13 Line16-22: Initialize "WE3", "clk", "PC" signals. Which controls the data pipeline.
- 12. Figure 13 Line23-23: Alternate "clk" signal every 50ns.
- 13. Figure 13 Line24-24: Add 1 to "PC" every 100ns.
- 14. Figure 13 Line27-28: Set the tri-state gate to be open or closed when internal control is not yet activated.

```
| Impodule data_v (WE3,PC,clk,R0,B0,B1,B2,B3,B4,R1,R2,Da,Db,D,A,B,addr,B5,B6,B7,B8,B9,B10,B11,B12,B13,B14,B15);
 1
2
3
4
5
6
7
8
9
             Input WE3, clk;
input [7:0] PC;
input [7:0] B1, B2;
output [7:0] B0, B1, B2;
output [7:0] B0, B3, B4, B5, B6, B7, B8, B9, B10, B11, B12, B13, B14, B15;
output [7:0] B0, B3, B4, B5, B6, B7, B8, B9, B10, B11, B12, B13, B14, B15;
output [7:0] Da, Db, A, B,D;
10112345678901123456789011234444444444555555555555567890
             wire [8:0] ALU;
wire [3:0] addr0;
output [3:0] addr;
             rom0_v inst1(.addr(PC), .clk(clk), .q(R0));
defparam inst1.DATA_WIDTH=16;
defparam inst1.ADDR_WIDTH= 8;
                                                                                                                                                                                                   'timescale 1 ns/1 ns
module test;
reg WE3, Clk;
reg [7:0] PC;
wire [7:0] B1, B2;
wire [15:0] R0, R1, R2;
wire [7:0] B0, B3, B4, B5, B6, B7, B8, B9, B10, B11, B12, B13, B14, B15;
wire [7:0] Da, Db, A, B, D;
         □data_v DUT( .WE3(WE3), .c1k(c1k),.PC(Pc), .81(81), .82(82),.R0(R0),.R1(R1), .R2(R2), .80(80), .83(83),.84(84), .85(85),.86(86), .87(87), .88(88), .89(89), .810(810), .811(811), .812(812),.813(813), .814(814), .815(815), .Da(Da), .Db(Db), .A(A), .8(8), .D(D));
                                                                                                                                                                                                    initial
| begin
| wE3 = 1;
| clk = 0;
| PC = 0;
                                                                                                                                                                                                    end
always #50 clk = ~clk ;
always #100 PC = PC + 1 ;
                                                                                                                                                                                                    assign B1 = (B0[0]==1)? 8'bZZZZZZZZ : 8'h40;
assign B2 = (B0[1]==1)? 8'bZZZZZZZZ : 8'h88;
                                                                                                                                                                                                    endmodule
             lpmdff_v inst7(.d(ALU[7:0]),.clk(clk), .q(D));
defparam inst7.DATA_WIDTH=8;
                                                                                                                                                                                                                               Figure 13: Test file
          lpmdff_v inst9(.d(addr0), .clk(clk),.q(addr));
defparam inst9.DATA_WIDTH=4;
```

Figure 12: Main file

endmodule

#### 4.4 Result



Figure 14: Homework 10-4 Result

Table 8: Exercise 10-4 Truth Table

| clk↑(ns)    | 50                                                        | 150                                                       | 250                                                        | 350                                                               | 450                                                              | 550                                                             | 650                                                             | 750                                                             | 850                                                              | 950                                                               |
|-------------|-----------------------------------------------------------|-----------------------------------------------------------|------------------------------------------------------------|-------------------------------------------------------------------|------------------------------------------------------------------|-----------------------------------------------------------------|-----------------------------------------------------------------|-----------------------------------------------------------------|------------------------------------------------------------------|-------------------------------------------------------------------|
| PC (8'h)    | 00                                                        | 01                                                        | 02                                                         | 03                                                                | 04                                                               | 05                                                              | 06                                                              | 07                                                              | 08                                                               | 09                                                                |
| R0 (8'h)    | f007                                                      | e303                                                      | 8201                                                       | b303                                                              | a321                                                             | 9123                                                            | c318                                                            | e258                                                            | f106                                                             | 0000                                                              |
| R1 (8'h)    | 0000                                                      | f007                                                      | e303                                                       | 8201                                                              | b303                                                             | a321                                                            | 9123                                                            | c318                                                            | e258                                                             | f106                                                              |
| R2 (8'h)    | 0000                                                      | 0000                                                      | f007                                                       | e303                                                              | 8201                                                             | b303                                                            | a321                                                            | 9123                                                            | c318                                                             | e258                                                              |
| A (8'h)     | 00                                                        | 00                                                        | 00                                                         | 00                                                                | 00                                                               | 00                                                              | 00                                                              | 00                                                              | 07                                                               | 00                                                                |
| B (8'h)     | 00                                                        | 00                                                        | 07                                                         | 03                                                                | 00                                                               | 07                                                              | 00                                                              | 00                                                              | 18                                                               | 28                                                                |
| D (8'h)     | 00                                                        | 00                                                        | 00                                                         | 07                                                                | 00                                                               | 00                                                              | 07                                                              | 00                                                              | 00                                                               | 1f                                                                |
| B0 (8'h)    | 00                                                        | 00                                                        | 00                                                         | 00                                                                | 00                                                               | 07                                                              | 07                                                              | 07                                                              | 07                                                               | 07                                                                |
| description | S1 RCf007<br>S2 N/A<br>S3 N/A<br>S4 N/A<br>S5 N/A<br>pass | S1 RCe303<br>S2 RA0<br>S3 N/A<br>S4 N/A<br>S5 N/A<br>pass | S1 RC8201<br>S2 RA3<br>S3 PD07<br>S4 N/A<br>S5 N/A<br>pass | S1 RCb303<br>S2 RA2<br>S3 PD03<br>S4 A0 D07=D07<br>S5 N/A<br>pass | S1 RCa321<br>S2 RA3<br>S3 PA0<br>S4 A3&D03=D00<br>S5 WA0<br>pass | S1 RC9123<br>S2 RA3<br>S3 PA0<br>S4 A2+A0=D00<br>S5 WA3<br>pass | S1 RCc318<br>S2 RA1<br>S3 PA2<br>S4 A3 A0=D07<br>S5 WA1<br>pass | S1 RCe258<br>S2 RA3<br>S3 PA2<br>S4 A3&A2=D00<br>S5 WA3<br>pass | S1 RCf106<br>S2 RA2<br>S3 PD18<br>S4 A1-A2=D00<br>S5 WA1<br>pass | S1 RC0000<br>S2 RA1<br>S3 PD58<br>S4 A3+D18=D1f<br>S5 WA3<br>pass |
|             |                                                           |                                                           |                                                            |                                                                   |                                                                  |                                                                 |                                                                 |                                                                 |                                                                  |                                                                   |

<sup>&</sup>quot;S": stage, "R": read, "W": write, "P": pick/choose, "C": command, "A": address, "D": data, "N/A": not available, "+": add operation, "-": minus operation, "&": and operation, "|": or operation

# 5 Homework 10-5 Instruction Explanation

"A4'd0100" stands for 4-bit binary address, "D8'd0000\_1111" stands for 8-bit binary data.

- **16'hF40F** = 16'b1111\_0100\_0000\_1111 = 2'b11 + 2'b11 + 4'b0100 + 8'b0000\_1111 = Execute (A4'b0100)|(D8'b0000\_1111) Write in A4'b0100
- **16'hE300** = 16'b1110\_0011\_0000\_0000 = 2'b11 + 2'b10 + 4'b0011 + 8'b0000\_0000 = Execute (A4'b0011)&(D8'b0000\_0000) Write in A4'b0011
- 16'hF4FF = 16'b1111\_0100\_1111\_1111 = 2'b11 + 2'b11 + 4'b0100 + 8'b1111\_1111 = Execute (A4'b0100)|(D8'b1111\_1111) Write in A4'b0100
- 16'hF3FF = 16'b1111\_0011\_1111\_1111 = 2'b11 + 2'b11 + 4'b0011 + 8'b1111\_1111 = Execute (A4'b0011)|(D8'b1111\_1111) Write in A4'b0011
- $16'hD401 = 16'b1101\_0100\_0000\_0001 = 2'b11 + 2'b01 + 4'b0100 + 8'b0000\_0001 = Execute (A4'b0100) (D8'b0000\_0001) Write in A4'b0100$

# 6 Appendix

# **6.1** ALU Operation Code

Table 9: ALU Operation

| code | operation |
|------|-----------|
| 00   | D=A+B     |
| 01   | D=A-B     |
| 10   | D=A&B     |
| 11   | D=A B     |

"A": input data 1, "B": input data 2, "D": output 1

#### **6.2** Instruction Format

Table 10: Instruction Format

| register hex       | ro[15:12] |      |          |            | ro[11:08]                |        |         |      |      | ro[07:04] |         |      |      | ro[03:00] |         |      |
|--------------------|-----------|------|----------|------------|--------------------------|--------|---------|------|------|-----------|---------|------|------|-----------|---------|------|
| register bin       | ro15      | ro14 | ro13     | ro13 ro12  |                          | ro10   | ro09    | ro08 | ro07 | ro06      | ro05    | ro04 | ro03 | ro02      | ro01    | ro00 |
| instruction type A | 1         | 1    | ALU oper | ation code | read A / write D address |        |         |      |      |           | Вс      | ata  |      |           |         |      |
| instruction type B | 1         | 0    | ALU oper | ation code |                          | read A | address |      |      | read B    | address |      |      | write D   | address |      |

"A": input data 1, "B": input data 2, "D": output 1

# 6.3 Pipeline CPU Stages

Table 11: Pipeline CPU Stages

| clock cycle                 | 1    | 2    | 3    | 4    | 5    | 6    |
|-----------------------------|------|------|------|------|------|------|
| stage 1 Fetch Command       | F007 | E300 | F44F | F3FF | D401 | F007 |
| stage 2 Fetch Data          |      | F007 | E300 | F44F | F3FF | D401 |
| stage 3 Fetch ALU Operation |      |      | F007 | E300 | F44F | F3FF |
| stage 4 Execute             |      |      |      | F007 | E300 | F44F |
| stage 5 Write Back          |      |      |      |      | F007 | E300 |

#### 6.4 CPU State Machine





Figure 15: CPU steps