

# **Introduction to Verilog**

# **Exercise Manual**

Copyright © 2022 Intel Corporation.

This document is intended for personal use only. Unauthorized distribution, modification, public performance, public display, or copying of this material via any medium is strictly prohibited.

#### **Software Requirements:**

Intel® Quartus® Prime Standard Edition software v18.0

ModelSim®-Intel FPGA Edition simulation tool version 10.5b

### Link to lab files (for going through labs offline):

 $\frac{https://www.intel.com/content/www/us/en/programmable/customertraining/ilt/ihdl120/ihdl12}{0-lab-18-0-v3.zip}$ 

# Lab Overview

• Build a sequential 8 x 8 multiplier

The objective of the following exercises is to build an 8 x 8 multiplier. The input to the multiplier consists of two 8-bit multiplicands (dataa and datab) and the output from the multiplier is a 16-bit product (product8x8\_out). Additional outputs are a done bit (done\_flag) and seven signals to drive a seven-segment display (seg\_a, seg\_b, seg\_c, seg\_d, seg\_e, seg\_f, & seg\_g).

This 8 x 8 multiplier requires four clock cycles to perform the full multiplication. During each cycle, a pair of 4-bit portion of the multiplicands is multiplied by a  $4 \times 4$  multiplier. The multiplication result of these 4-bit slices is then accumulated. At the end of the four cycles (during the 5th cycle), the fully composed 16-bit product can be read at the output.

The following equations illustrate the mathematical principles supporting this implementation:

Figure 1 (below) illustrates the top-level block diagram of the 8 x 8 multiplier.



Figure 1 – 8 x 8 multiplier top level design block diagram

The labs are structured as a bottom-up design approach. In each of the first four exercises, you will use targeted features of the Verilog language to build the individual components of the 8 x 8 multiplier, compiling and simulating each component. Then, in Exercise 5 you will put everything together in a top-level design. You will then compile and simulate to verify the completeness of top-level design.

# Exercise 1a

- Build a 16-bit adder using the '+' operator
- Practice coding basic module structure

## Step A: Unzip the exercise files and open an Intel Quartus Prime Project

In a Windows Explorer window, navigate to the directory C:\fpga\_trn\VER. If you 1. see any subfolders already there, please delete them. They are from a prior class. Unzip the file named ihdl120-lab-18-0-v3.zip found in the C:\fpga trn\VER 2. directory. If you still cannot find this directory or file, ask your instructor for assistance. After double-clicking, in the WinZip dialog box, simply click **Unzip** to automatically extract the files into a newly created folder named IVER10 1. Close WinZip. In the Windows Start menu, go to the Intel FPGA 18.0.0.614 Standard Edition folder. Click **Quartus (Quartus Prime 18.0)** to start the software. Double-check from the Help menu (About Quartus Prime) that you are using the correct version of the tool. Open the adder project. From the File menu, choose Open Project (not Open which only opens a single file instead of a project). Browse to the directory where you unzipped the labs and then descend into the IVER10 1 subdirectory. This directory will be referred to as the <**Project Directory**> from now on. Navigate into the lab1a directory and select the file adder.qpf to open the project, 5. click Open.

The project opens and you are ready to start coding your adder block

# Step B: Write the code for a 16-bit adder



- \_\_ 1. Create a Verilog file using the Intel Quartus Prime text editor.
  - a. From the **File** menu, select **New** or click on the button.
  - b. The **New File** dialog box will appear; select **Verilog HDL File**.
  - c. Click OK.

| <br>_ 2.   | Write the source code for a 16-bit adder using the '+' operator. Use the following information as a guide:                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | a. Use the names in the adder diagram to name your block and its ports (all lower-case)                                                                                                                                                                                                                                                                                                                                                                                                       |
|            | <ul> <li>Do not worry about rollover with this adder. This adder is already wide<br/>enough to account for all the values it will be adding together.</li> </ul>                                                                                                                                                                                                                                                                                                                              |
|            | <ul> <li>If you would prefer using a different text editor, please feel free to do so.</li> <li>Just make sure you save your Verilog file in the project directory.</li> </ul>                                                                                                                                                                                                                                                                                                                |
| _ 3.       | Save the file as <b>adder.v</b> . From the <b>File</b> menu, select <b>Save</b> and save your Verilog file as <b>adder.v</b> . It should be located in the <i>Project Directory</i> <b>lab1a</b> directory.                                                                                                                                                                                                                                                                                   |
| <u>S</u> 1 | tep C: Synthesize the design & Check the code for correctness                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| _ 1.       | Synthesize the design. From the <b>Processing</b> menu, select <b>Start</b> ⇒ <b>Start Analysis</b> &                                                                                                                                                                                                                                                                                                                                                                                         |
|            | Synthesis OR click the button.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|            | This will perform checks on the source code to make sure it is using valid Verilog syntax as well as check the design for being synthesizable.                                                                                                                                                                                                                                                                                                                                                |
| <br>_ 2.   | Correct any warnings and errors. Check the <b>Messages</b> window for any warning or error messages. Correct as needed.                                                                                                                                                                                                                                                                                                                                                                       |
|            | Be aware that most error messages point to the line number that is causing the error or it could be the line above it. You may also <b>right-click</b> on the message itself and choose <b>Help</b> to access the online help for clues on how to fix your warning or error. Of course, ask your instructor if you are unsure how to fix a particular warning or message. Repeat synthesis and error checking until the tool reports that " <b>Analysis &amp; Synthesis was successful.</b> " |
| St         | tep D: Perform an RTL simulation                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|            | You will now use the <b>ModelSim-Intel FPGA Edition</b> simulation tool to verify the functionality of your design. A Verilog testbench file (adder_tb.v) has already been created for you to provide the test vectors for your RTL simulation.                                                                                                                                                                                                                                               |
| _ 1.       | Open the tool. In the Windows Start menu go to the Intel FPGA 18.0.0.614                                                                                                                                                                                                                                                                                                                                                                                                                      |
|            | <b>Standard Edition</b> folder. Click <b>ModelSim – Intel FPGA Edition 10.5b (Quartus Prime 18.0)</b> to start the program. Verify you are using the correct version of the tool.                                                                                                                                                                                                                                                                                                             |
| _ 2.       | Close the introductory window (if it appears).                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <br>_ 3.   | Set the project directory. From the <b>ModelSim File</b> menu, select <b>Change Directory</b> . <b>Browse</b> to the location <b><project directory="">\lab1a</project></b> .                                                                                                                                                                                                                                                                                                                 |

A ModelSim macro file called a .DO file has been created for you. This file named **adder\_tb.do** contains all of the steps to run the ModelSim tool and peform simulation. This includes:

- a. Creating a working library using the **vlib** command
- b. Compiling all of the Verilog files into the working library with the **vlog** command.
- c. Loading the simulator with the top-level testbench file using the **vsim** command.
- d. Opening the waveform window with the wave command.
- e. Adding target signals to the wave window (and formatting them) using the **add wave** command.
- f. Advancing simulation using the **run** command.

You may open the **adder\_tb.do** file in a text editor if you wish to view the specific commands used.

\_\_\_\_ 4. Execute the macro file. From the **ModelSim Tools** menu, select **Tcl**  $\Rightarrow$  **Execute Macro**. Select the file **adder\_tb.do** and click **Open**.

The **ModelSim** tool will now compile all of the Verilog files and start simulation. The waveform window will open (as a separate window) with the **dataa**, **datab**, and **sum** signals added so you can verify that your Verilog code is functioning correctly.

\_\_\_ 5. Check simulation results for correct functionality. Bring the **Wave** window to the foreground. Right-click on the waveform and select **Zoom** ⇒ **Zoom Full**. Your results should look similar to the image below



If your simulation does not match the above, edit your Verilog code as needed and then save it. Re-run the **adder\_tb.do** file (repeat #'s 4 and 5 above) to check your changes.

\_6. End your simulation. From the **ModelSim Simulate** menu, select **End Simulation** OR type quit -sim in the **ModelSim Transcript** window. You will notice that when you select commands from the Modelsim pull down menus, the command is displayed in the transcript window. You can also use the up/down arrows to select prior comands to execute.

## **Exercise Summary**

- Coded a 16-bit adder block in Verilog using the '+' operator
- Simulated the Verilog code in the ModelSim tool to verify correct functionality

### **END OF EXERCISE 1a**

(Please continue to Exercise 1b)

# Exercise 1b

- Build a 4x4 multiplier block using the '\*' operator
- Synthesize and verify its operation

### Step A: Open a different project

\_\_\_ 1. Open the multiplier project. Back in the Intel Quartus Prime software, go to the File menu and choose Open Project. Browse to the directory <Project Directory>\lab1b and select the file mult4x4.qpf.

The project opens and you are ready to start coding your 4x4 multiplier block

## Step B: Write the code for a 4x4 multiplier



- \_\_\_\_ 1. Create a Verilog file using the Quartus II text editor.
  - a. From the File menu select New or click on the button.
  - b. The New File dialog box will appear; select Verilog HDL File.
  - c. Click OK.
- \_\_\_\_ 2. Write the source code for a **4x4 multiplier** using the **'\*' operator**. Use the following information as a guide:
  - a. The multiplier has two 4-bit multiplicand inputs and an 8-bit product output.
  - b. Use the names in the diagram above to name your block and its ports (all lower-case)
- 3. Save the file as mult4x4.v. From the File menu, select Save and save your Verilog file as mult4x4.v. The file needs to be located in the project directory\lab1b directory.

# **Step 3: Synthesize the design & check the code for correctness**

- \_\_\_\_ 1. Synthesize the design. From the **Processing** menu, select **Start** ⇒ **Start Analysis** & **Synthesis** OR click the button.
- 2. Correct any warnings and errors. Check the **Messages** window for any warning or error messages. Correct as needed using the message itself, the online help, the

class manual, and your instructor. Repeat synthesis and error checking until the tool reports that "Analysis & Synthesis was successful."

## **Step 4: Perform an RTL simulation**

You will now use the **ModelSim-Intel FPGA Edition** simulation tool to verify the functionality of your design. A Verilog testbench file (**mult4x4\_tb.v**) has already been created for you to provide the test vectors for your RTL simulation.

\_ 1. Set the project directory. From the ModelSim File menu, select Change Directory. Browse to the location <Project Directory>\lab1b.

Again, a ModelSim macro file named **mult4x4\_tb.do** has been created for you to run the ModelSim tool and peform simulation.

2. Execute the macro file. From the **ModelSim Tools** menu, select **Tcl**  $\Rightarrow$  **Execute Macro**. Select the file **mult4x4\_tb.do** and click **Open**.

The **ModelSim** tool will now compile all of the Verilog files and start simulation. the waveform window will open (as a separate window) with the **dataa**, **datab**, and **product** signals added so you can verify that your Verilog code is functioning correctly.

\_\_\_\_ 3. Check simulation results for correct functionality. Bring the **Wave** window to the foreground. From the **View** menu, click **Zoom** ⇒ **Zoom Full**. Your results should look similar to the image below.



If your simulation does not match the above, edit your Verilog code as needed and then save it. Re-run the **mult4x4\_tb.do** file (repeat #'s 2 and 3 above) to check your changes.

\_\_\_ 4. End your simulation. From the **ModelSim Simulate** menu, select **End Simulation** OR type quit -sim in the **ModelSim Transcript** window.

## **Exercise Summary**

- Coded a 4x4 multiplier block in Verilog using the '\*' operator
- Simulated the Verilog code in the ModelSim tool to verify correct functionality

#### **END OF EXERCISE 1b**

# Exercise 2a

- Build a 4-bit 2:1 multiplexer using the if-else statement
- Synthesize and verify its operation

## **Step A: Open the Project**

\_\_ 1. Open the multiplexer project. In the Intel Quartus Prime software, go to the File menu and choose Open Project. Browse to the directory < Project Directory > \lab2a and select the file mux4.qpf.

The project opens and you are ready to start coding your 2-1 multiplexer block.

## Step B: Write the code for a 2:1 multiplexer



- \_\_\_\_ 1. Create a Verilog file using the text editor:
  - a. From the **File** menu select **New** or click the Dutton.
  - b. The New File dialog box will appear; select Verilog HDL File.
  - c. Click OK.
- \_\_\_ 2. Write the source code for a 4-bit 2:1 multiplexer using the if-else behavioral statement. Use the following information as a guide:
  - a. The multiplexer has two 4-bit data inputs, a select line and a 4-bit output.
  - b. Describe the following behavior: if mux\_sel is 0, then choose mux\_in\_a for mux\_out. if mux\_sel is 1, then choose mux\_in\_b for mux\_out.
  - c. Use the names in the diagram above to name your block and its ports (all lower-case)
  - d. Coding with behavioral statements requires using a procedural (e.g. always) block.
  - e. All inputs to the procedural block (anything on the right-hand side (RHS) of an assignment operator within) should be listed in the procedural block's sensitivity list. The reasoning will be discussed later.

Save the file as **mux4.v**. From the **File** menu, select **Save** and save your Verilog file 3. as mux4.v. It should be located in the <Project Directory>\lab2a directory. Step C: Synthesize the design & check the code for correctness Synthesize the design. From the **Processing** menu, select **Start** ⇒ **Start Analysis** & **Synthesis** OR click on the button. Correct any warnings and errors. Check the Messages window for any warning or 2. error messages. Correct as needed using the message itself, the online help, the class manual, and your instructor. Repeat synthesis and error checking until the tool reports that "Analysis & Synthesis was successful." Step D: Perform an RTL simulation You will now use the ModelSim-Intel FPGA Edition simulation tool to verify the functionality of your design. A Verilog testbench file (mux4 tb.v) has already been created for you to provide the test vectors for your RTL simulation. Set the project directory. From the **ModelSim File** menu, select **Change Directory**. Browse to the location < Project Directory > \lab2a. Use the ModelSim macro file named **mux4 tb.do**, created for you, to run the ModelSim tool and peform simulation. Execute the macro file. From the **ModelSim Tools** menu, select  $Tcl \Rightarrow Execute$ 2. **Macro**. Select the file **mux4\_tb.do** and click **Open**. The **ModelSim** tool will now compile all of the Verilog files and start simulation. The waveform window will open (as a separate window) with the **mux in a**, mux in b, mux sel, and mux out signals added so you can verify that your Verilog code is functioning correctly. Check simulation results for correct functionality. Bring the Wave window to the 3. foreground. From the **View** menu, click **Zoom** ⇒ **Zoom Full**. Your results should



If your simulation does not match the above, edit your Verilog code as needed and then save it. Re-run the **mux4\_tb.do** file (repeat #'s 2 and 3 above) to check your changes.

\_\_\_\_\_4. End your simulation. From the **ModelSim Simulate** menu, select **End Simulation**OR type quit -sim in the **ModelSim Transcript** window.

## **Exercise Summary**

- Coded a 4-bit 2:1 multiplexer block in Verilog using the if-then behavioral statement
- Simulated the Verilog code in the ModelSim tool to verify correct functionality

#### **END OF EXERCISE 2a**

(Please continue to Exercise 2b)

# Exercise 2b

- Build an 8-bit to 16-bit left shifter using the if-else statement
- Synthesize and verify its operation

### **Step A: Open the Project**

\_\_\_\_ 1. Open the shifter project. In the Intel Quartus Prime software, go to the File menu and choose Open Project. Browse to the directory <Project Directory>\lab2b and select the file shifter.qpf.

The project opens and you are ready to start coding your 8-to-16 left shifter block.

## Step B: Write the code for an 8-bit to 16-bit left shifter



- \_\_\_\_ 1. Create a Verilog file using the text editor:
  - a. From the **File** menu select **New** or click the Dutton.
  - b. The New File dialog box will appear; select Verilog HDL File.
  - c. Click OK.
- 2. Write the source code for an 8-bit to 16-bit left shifter using the if-else behavioral statement. Use the following information as a guide:
  - a. The multiplexer has one 8-bit data input, a control line, and a 16-bit output.
  - b. Describe the following behavior:
    - i. When shift\_cntrl is 0 or 3, then no shift (i.e. shift\_out[7:0] equals input[7:0]; all other bits '0').
    - ii. When shift\_cntrl is 1, then shift input to the left by 4 bits within shift\_out (i.e. shift\_out[11:4] equals input[7:0]; all other bits '0').
    - iii. When **shift\_cntrl** is **2**, then shift **input** to the left by <u>8 bits</u> within **shift out** (i.e. **shift out[15:8] equals input[7:0]**; all other bits '0').
  - c. When **shift\_cntrl** is **2**, then shift **input** to the left by <u>8 bits</u> within **shift\_out** (i.e. **shift\_out[15:8] equals input[7:0]**; all other bits '0'). Use the names in the diagram above to name your block and its ports (all lower-case)
  - d. Coding with behavioral statements requires using a procedural (e.g. always) block.

- e. All <u>inputs</u> to the procedural block (anything on the RHS of an assignment operator within) should be listed in the procedural block's sensitivity list. The reasoning will be discussed later.
- f. Try to simplify choices when possible, recognize similarities between choices.
- 3. Save the file as shifter.v. From the File menu, select Save and save your Verilog file as shifter.v. It should be located in the <Project Directory>\lab2b directory.

## Step C: Synthesize the design & check the code for correctness

- \_\_\_\_ 1. Synthesize the design. From the **Processing** menu, select **Start** ⇒ **Start Analysis** & **Synthesis** OR click the button.
- 2. Correct any warnings and errors. Check the Messages window for any warning or error messages. Correct as needed using the message itself, the online help, the class manual, and your instructor. Repeat synthesis and error checking until the tool reports that "Analysis & Synthesis was successful."

## **Step D: Perform an RTL simulation**

Use the **ModelSim-Intel FPGA Edition** simulation tool to verify the functionality of your design. A Verilog testbench file (**shifter\_tb.v**) has been created for you to provide the test vectors for your RTL simulation.

- Set the project directory. From the ModelSim File menu, select Change Directory.
   Browse to the location <Project Directory>\lab2b.
  - Use the ModelSim macro file named **shifter\_tb.do**, created for you, to run the ModelSim tool and peform simulation.
- 2. Execute the macro file. From the **ModelSim Tools** menu, select **Tcl**  $\Rightarrow$  **Execute Macro**. Select the file **shifter\_tb.do** and click **Open**.

The **ModelSim** tool will now compile all of the Verilog files and start simulation. The waveform window will open (as a separate window) with the **shift\_cntrl**, **input**, and **shift\_out** signals added so you can verify that your Verilog code is functioning correctly.

\_\_\_\_ 3. Check simulation results for correct functionality. Bring the Wave window to the foreground. From the View menu, click Zoom ⇒ Zoom Full. Your results should look similar to the image below.



If your simulation does not match the above, edit your Verilog code as needed and then save it. Re-run the **shifter\_tb.do** file (repeat #'s 2 and 3 above) to check your changes.

\_\_\_\_\_4. End your simulation. From the **ModelSim Simulate** menu, select **End Simulation**OR type quit -sim in the **ModelSim Transcript** window.

### **Exercise Summary**

- Coded an 8-bit to 16-bit left shifter block in Verilog using the if-then behavioral statement
- Simulated the Verilog code in the ModelSim tool to verify correct functionality

### **END OF EXERCISE 2b**

# Exercise 3

- Build a 7-segment LED display controller using the case statement
- Synthesize and verify its operation

### **Step A: Open the Project**

1. Open the 7-segment LED display controller project. Back in the Intel Quartus Prime software, go to the File menu and choose Open Project. Browse to the directory <Project Directory>\lab3 and select the file seven\_segment\_cntrl.qpf.

The project opens and you are ready to start coding your 7-segment LED display control block.

Step B: Write the code for a 7-segment LED display controller



- \_\_\_\_ 1. Create a Verilog file using the text editor:
  - a. From the File menu select New or click Dutton.
  - b. The New File dialog box will appear; select Verilog HDL File.
  - c. Click OK.
- 2. Write the source code for a **7-segment LED display controller** using the **case behavioral statement**. Use the following information as a guide:
  - a. The controller has one 3-bit data input and 7 single-bit outputs each controlling different segments of the 7-segment display
  - b. Describe the behavior as shown in the following table:

| Inputs           | Outputs |       |       |       |       |       |       | 1.50           |
|------------------|---------|-------|-------|-------|-------|-------|-------|----------------|
| inp<br>[2:0]     | seg_a   | seg_b | seg_c | seg_d | seg_e | seg_f | seg_g | LED<br>Display |
| 000              | 1       | 1     | 1     | 1     | 1     | 1     | 0     | 0              |
| 001              | 0       | 1     | 1     | 0     | 0     | 0     | 0     | 1              |
| 010              | 1       | 1     | 0     | 1     | 1     | 0     | 1     | 2              |
| 011              | 1       | 1     | 1     | 1     | 0     | 0     | 1     | 3              |
| All other values | 1       | 0     | 0     | 1     | 1     | 1     | 1     | E              |

- c. Use the names in the diagram above to name your block and its ports (all lower-case).
- d. Use the concatenation operator {} with the outputs to make assigning the output values easier.
- e. Coding with behavioral statements requires using a procedural (e.g. always) block.
- f. All inputs to the procedural block (anything on the RHS of an assignment operator within) should be listed in the procedural block's sensitivity list. The reasoning will be discussed later.

# **Step C: Synthesize the design & check the code for correctness**

| 1. | Synthesize the design.  | From the <b>Processing</b> menu, select <b>Start</b> ⇒ <b>Start Analysis</b> & |
|----|-------------------------|--------------------------------------------------------------------------------|
|    | Synthesis OR click on t | :he 🍾 button.                                                                  |

2. Correct any warnings and errors. Check the Messages window for any warning or error messages. Correct as needed using the message itself, the online help, the class manual, and your instructor. Repeat synthesis and error checking until the tool reports that "Analysis & Synthesis was successful."

## **Step D: Perform an RTL simulation**

Use the ModelSim-Intel FPGA Edition simulation tool (or similar) to verify the functionality of your design. A Verilog testbench file (seven\_segment\_cntrl\_tb.v) has been created for you to provide the test vectors for your RTL simulation.

- Set the project directory. From the ModelSim File menu, select Change Directory.
   Browse to the location <Project Directory>\lab3.
  - Use the ModelSim macro file named **seven\_segment\_cntrl\_tb.do**, created for you, to run the ModelSim tool and peform simulation.
  - \_\_ 2. Execute the macro file. From the **ModelSim Tools** menu, select **Tcl**  $\Rightarrow$  **Execute Macro**. Select the file **seven\_segment\_cntrl\_tb.do** and click **Open**.

The **ModelSim** tool will now compile all of the Verilog files and start simulation. The waveform window will open (as a separate window) with the **input**, **seg\_a**, **seg\_b**, **seg\_c**, **seg\_d**, **seg\_e**, **seg\_f**, and **seg\_g** signals added so you can verify that your Verilog code is functioning correctly.

\_ 3. Check simulation results for correct functionality. Bring the **Wave** window to the foreground. From the **View** menu, click **Zoom** ⇒ **Zoom Full**. Your results should look similar to the image below.



If your simulation does not match the above, edit your Verilog code as needed and then save it. Re-run the **seven\_segment\_cntrl\_tb.do** file (repeat #'s 2 and 3 above) to check your changes.

\_\_ 4. End your simulation. From the **ModelSim Simulate** menu, select **End Simulation**OR type **quit -sim** in the **ModelSim Transcript** window.

## **Exercise Summary**

- Coded a 7-segment LED display controller in Verilog using the case behavioral statement
- Simulated the Verilog code in the ModelSim tool to verify correct functionality

#### **END OF EXERCISE 4**

# Exercise 4

- Build a 16-bit register with synchronous control
- Synthesize and verify its operation

### **Step A: Open the Project**

Open the register project. In the Intel Quartus Prime software, go to the File menu and choose Open Project. Browse to the directory < Project Directory > \lab4a and select the file reg16.qpf.

The project opens and you are ready to start coding your 16-bit register block.

### **Step B:** Write the code for a 16-bit register with synchronous control



- \_\_\_\_ 1. Create a Verilog file using the text editor:
  - a. From the **File** menu select **New** or click the Dutton.
  - b. The New File dialog box will appear; select Verilog HDL File.
  - c. Click OK.
- 2. Write the source code for a **16-bit register with synchronous control** using a **sequential process**. Use the following information as a guide:
  - a. The register has a clock, a 16-bit data input, a synchronous clear, a synchronous clock enable, and a 16-bit data output.
  - b. Describe the following behavior:
    - i. All transactions occur on the rising edge of a  ${f clk}.$
    - ii. After a rising edge **clk** is detected, check to see if **clk\_ena** is <u>high</u>.
    - If clk\_ena is high, check to see if sclr\_n is low. If so, then the register outputs are cleared.
    - iv. If **clk\_ena** is <u>high</u> and **sclr\_n** is <u>not low</u>, then the register outputs are set equal to the register inputs.
    - v. If **clk\_ena** is low, do nothing.
  - c. Use the names in the diagram above to name your block and its ports (all lower-case)

- d. Synchronous controls are not included in the sensitivity list.
- e. Unless explicitly changed, outputs to a procedural will retain their value from the previous execution.
- \_\_\_\_ 3. Save the file as **reg16.v**. From the **File** menu, select **Save** and save your Verilog file as **reg16.v**. It should be located in the **<Project Directory>\lab4a** directory.

## Step D: Perform an RTL simulation

Use the **ModelSim-Intel FPGA Edition** simulation tool to verify the functionality of your design. A Verilog testbench file (**reg16\_tb.v**) has been created for you to provide the test vectors for your RTL simulation.

\_ 1. Set the project directory. From the ModelSim File menu, select Change Directory. Browse to the location <Project Directory>\lab4a.

Use the ModelSim macro file named **reg16\_tb.do**, created for you, to run the ModelSim tool and perform simulation.

2. Execute the macro file. From the **ModelSim Tools** menu, select **Tcl**  $\Rightarrow$  **Execute Macro**. Select the file **reg16\_tb.do** and click **Open**.

The **ModelSim** tool will now compile all of the Verilog files and start simulation. The waveform window will open (as a separate window) with the **clk**, **sclr\_n**, **clk\_ena**, **datain**, and **reg\_out** signals added so you can verify that your Verilog code is functioning correctly.

\_ 3. Check simulation results for correct functionality. Bring the **Wave** window to the foreground. From the **View** menu, click **Zoom** ⇒ **Zoom Full**. Your results should look similar to the image below.



If your simulation does not match the above, edit your Verilog code as needed and then save it. Re-run the **reg16\_tb.do** file (repeat #'s 2 and 3 above) to check your changes.

4. End your simulation. From the **ModelSim Simulate** menu, select **End Simulation** OR type **quit -sim** in the **ModelSim Transcript** window.

## **Exercise Summary**

- Coded a 16-bit register with synchronous controls in Verilog using a sequential procedural block.
- Simulated the Verilog code in the ModelSim tool to verify correct functionality

### **END OF EXERCISE 4a**

(Please continue to Exercise 4b)

# Exercise 4b

- Build a 2-bit counter with asynchronous control
- Synthesize and verify its operation

### **Step A: Open the Project**

\_\_\_\_ 1. Open the counter project. Back in the Intel Quartus Prime software, go to the File menu and choose Open Project. Browse to the directory < Project Directory > \lab4b and select the file counter.qpf.

The project opens and you are ready to start coding your 16-bit register block.

### Step B: Write the code for a 2-bit counter with asynchronous control



- \_\_\_\_ 1. Create a Verilog file using the text editor:
  - a. From the **File** menu select **New** or click the button.
  - b. The New File dialog box will appear; select Verilog HDL File.
  - c. Click **OK**.
- 2. Write the source code for a 2-bit counter with asynchronous control using a sequential process. Use the following information as a guide:
  - a. The register has a clock, an asynchronous clear, and a 2-bit data output.
  - b. Describe the following behavior:
    - i. The output of the counter goes to 00 immediately when **aclr\_n** is <u>low</u>.
    - ii. If **aclr\_n** is <u>not low</u>, then the output of the counter increments by 1 on every rising edge of **clk**.
  - c. Use the names in the diagram above to name your block and its ports (all lower-case)
  - d. Checking of asynchronous register control signals occurs <u>first</u> in a sequential procedural block.
  - e. Asynchronous controls are included in the sensitivity list.
- 3. Save the file as counter.v. From the File menu, select Save and save your Verilog file as counter.v. It should be located in the <Project Directory>\lab4b directory.

## Step C: Synthesize the design & check the code for correctness





## **Step D: Perform an RTL simulation**

Use the **ModelSim-Intel FPGA Edition** simulation tool to verify the functionality of your design. A Verilog testbench file (**counter\_tb.v**) has been created for you to provide the test vectors for your RTL simulation.

\_ 1. Set the project directory. From the ModelSim File menu, select Change Directory. Browse to the location <Project Directory>\lab4b.

Use the ModelSim macro file named **counter\_tb.do**, created for you, to run the ModelSim tool and perform simulation.

2. Execute the macro file. From the **ModelSim Tools** menu, select **Tcl**  $\Rightarrow$  **Execute Macro**. Select the file **counter\_tb.do** and click **Open**.

The **ModelSim** tool will now compile all of the Verilog files and start simulation. The waveform window will open (as a separate window) with the **clk**, **aclr\_n**, and **count\_out** signals added so you can verify that your Verilog code is functioning correctly.

\_ 3. Check simulation results for correct functionality. Bring the **Wave** window to the foreground. From the **View** menu, click **Zoom** ⇒ **Zoom Full**. Your results should look similar to the image below.



If your simulation does not match the above, edit your Verilog code as needed and then save it. Re-run the **counter\_tb.do** file (repeat #'s 2 and 3 above) to check your changes.

\_\_\_\_ 4. End your simulation. From the **ModelSim Simulate** menu, select **End Simulation** OR type **quit -sim** in the **ModelSim Transcript** window.

## **Exercise Summary**

- Coded a 2-bit register with asynchronous control in Verilog using a sequential procedural block.
- Simulated the Verilog code in the ModelSim tool to verify correct functionality

### **END OF EXERCISE 4b**

(Please continue to Exercise 4b)

# Exercise 5a

Examine a state machine implementation (no coding)



You have now completed building all the components necessary to build the 8x8 multiplier, except for the controlling state machine.

The project is in the lab5a folder called **mult\_control**.

In this lab you are more on your own, there are no step-by-step instructions. The **mult\_control.v** file contains the top level entity along with some other structures.

This state machine will manage all the operations that occur within the 8x8 multiplier using 6 defined states: **idle, lsb, mid, msb, calc\_done**, and **err**. See the state diagram in Figure 5-1 for more definition of its behavior.

The state machine in the **LSB** state multiplies the lowest 4 bits of the two 8-bit multiplicands ( $(a[3..0] * b[3..0]) * 2^0$ ). This intermediate result is saved in an accumulator.

The state machine in the **MID** state performs cross multiplication ((a[3..0] \* b[7..4]) \* 2^4) and ((a[7..4] \* b[3..0]) \* 2^4). This is done in successive clock cycles. The products of both multiply operations are added to the content of the accumulator as they are completed and clocked back into the accumulator.

The state machine in the **MSB** state multiplies the highest 4 bits of the two 8-bit multiplicands ( $(a[7..4] * b[7..4]) * 2^8$ ). This product is added with the content of the accumulator and clocked back into the accumulator.

This result is the final product:

result[15..0] = 
$$a[7..0] * b[7..0]$$
  
=  $((a[7..4] * b[7..4]) * 2^8)$   
+  $((a[7..4] * b[3..0]) * 2^4)$   
+  $((a[3..0] * b[7..4]) * 2^4)$   
+  $((a[3..0] * b[3..0]) * 2^0)$ 

The state machine in the **CALC\_DONE** state asserts the **done\_flag** output to indicate the final product has been calculated and is ready for reading by downstream logic.

The state machine in the **ERR** state indicates incorrect inputs have been received.

There are two inputs to the state machine: **start** and **count**. The **start** signal is asserted for once clock cycle to begin an 8x8 multiply operation on the next clock cycle. The **start** signal must only be asserted for one clock cycle. The **count** signal is used by the state machine to track the multiplication cycles.

The outputs of **mult\_control** state machine control the other blocks in the design from the prior labs.



Figure 5-1: mult control state machine state diagram

#### **END OF EXERCISE 5a**

(Please continue to Exercise 5b)

# Exercise 5b

- Complete the code to implement the 8x8 multiplier using Verilog structural modeling and instantiations
- Synthesize and verify its operation

You now have all the building blocks necessary to complete the 8x8 multiplier.

Making use of the knowledge you have gained up to this point, you must now instantiate each component in a top-level design and connect all signals as shown in Figure 5-2. Once your design compiles and simulates successfully, you have completed the labs for the Introduction to Verilog class.



Figure 5-2 - 8 x 8 multiplier top level design block diagram

| <u>St</u> | ep A: Open a Project                                                                                                                                                                                                                                                       |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.        | Open the 8x8 multiplier project. In the Intel Quartus Prime software, go to the <b>File</b> menu and choose <b>Open Project</b> . Browse to the directory <b><project< b=""> <b>Directory&gt;\lab5b</b> and select the file <b>mult8x8.qpf</b>.</project<></b>             |
|           | The project opens and you can finish coding the 8x8 multiplier.                                                                                                                                                                                                            |
| <u>St</u> | ep B: Finish the code for an 8x8 multiplier                                                                                                                                                                                                                                |
| 1.        | Create a Verilog file using the text editor:                                                                                                                                                                                                                               |
|           | a. From the <b>File</b> menu select <b>New</b> or click the $\square$ button.                                                                                                                                                                                              |
|           | b. The <b>New File</b> dialog box will appear; select <b>Verilog HDL File</b> .                                                                                                                                                                                            |
|           | c. Click <b>OK</b> .                                                                                                                                                                                                                                                       |
| 2.        | Write the source code to connect the <b>8x8 multiplier</b> using <b>Verilog structural instantiations</b> . Use the following information as a guide:                                                                                                                      |
|           | <ul> <li>Declare a top-level module named mult8x8 with the top-level ports as<br/>shown in Figure 5-2.</li> </ul>                                                                                                                                                          |
|           | b. Create instantiations for mux4 (2 copies), mult4x4, shifter, counter, mult_control, reg16, adder, and seven_segment_cntrl based on the connections shown in Figure 5-2. Use u6 as the instance name for mult_control. For other modules use any instance name you wish. |
|           | c. This will require declaring new internal wires for connecting the blocks. Use the names from Figure 5-2.                                                                                                                                                                |
| 3.        | Save the file as mult8x8.v. From the Quartus II File menu, select Save and save your Verilog file as mult8x8.v. It should be located in the <project directory="">\lab5b directory.</project>                                                                              |
| St        | ep C: Synthesize the design & check the code for correctness                                                                                                                                                                                                               |
|           | Since the other source files are in different directories, before synthesizing, you must directly add these other source files to this project.                                                                                                                            |
| 1.        | Add the source files from the other projects. From the <b>Project</b> menu, select                                                                                                                                                                                         |
|           | Add/Remove Files in Project. Click on the button and browse to each of the subdirectories used for Exercises 1-5a to add each of the Verilog design files to this project. This includes:                                                                                  |
|           | a. adder.v (lab1a),                                                                                                                                                                                                                                                        |
|           | b. mult4x4.v (lab1b),                                                                                                                                                                                                                                                      |

|          | c. <b>mux4.v</b> (lab2a),                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | d. shifter.v (lab2b),                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|          | e. seven_segment_cntrl.v (lab3),                                                                                                                                                                                                                                                                                                                                                                                                                                |
|          | f. reg16.v (lab4a),                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|          | g. counter.v (lab4b),                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|          | h. mult_control.v (lab5a).                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|          | MAKE SURE to click on the <b>Add</b> button each time so that the file appears in the <b>File name</b> list.                                                                                                                                                                                                                                                                                                                                                    |
| 2.       | Synthesize the design. From the <b>Processing</b> menu, select <b>Start</b> ⇒ <b>Start Analysis</b> &                                                                                                                                                                                                                                                                                                                                                           |
|          | Synthesis OR click on the 🏂 button.                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 3.       | Correct any warnings and errors. Check the <b>Messages</b> window for any warning or error messages. Correct as needed using the message itself, the online help, the class manual, and your instructor. Repeat synthesis and error checking until the tool reports that " <b>Analysis &amp; Synthesis was successful</b> ."                                                                                                                                    |
| <u>S</u> | tep D: Perform an RTL simulation                                                                                                                                                                                                                                                                                                                                                                                                                                |
|          | Use the <b>ModelSim-Intel FPGA Edition</b> simulation tool to verify the functionality of your design. A Verilog testbench file ( <b>mult8x8_tb.v</b> ) has been created for you to provide the test vectors for your RTL simulation.                                                                                                                                                                                                                           |
| 1.       | Set the project directory. From the <b>ModelSim File</b> menu, select Change Directory. Browse to the location <b><project directory="">\lab5b</project></b> .                                                                                                                                                                                                                                                                                                  |
|          | Use the ModelSim macro file named <b>mult8x8_tb.do</b> , created for you, to run the ModelSim tool and perform simulation.                                                                                                                                                                                                                                                                                                                                      |
| 2.       | Execute the macro file. From the <b>ModelSim Tools</b> menu, select $Tcl \Rightarrow Execute$ <b>Macro</b> . Select the file <b>mult8x8_tb.do</b> and click <b>Open</b> .                                                                                                                                                                                                                                                                                       |
|          | The <b>ModelSim</b> tool will now compile all of the Verilog files and start simulation. The waveform window will open (as a separate window) with all of the multiplier input and output signals added so you can verify that your Verilog code is functioning correctly. Dividers are used to separate different types of signals.                                                                                                                            |
| 3.       | Check simulation results for correct functionality. Bring the <b>Wave</b> window to the foreground. Use the Zoom In tool to zoom until you can see the product output calculations. Your results should look similar to Figure 5-3 below. Note that each time <b>done_flag</b> goes high, the design is returning the product of the current inputs. Note that each time <b>done_flag</b> goes high, the design is returning the product of the current inputs. |

If your simulation does not match the above, edit your Verilog code as needed and then save it. Re-run the **mult8x8\_tb.do** file (repeat #'s 2 and 3 above) to check your changes.



Figure 5-3: 8x8 multiplier simulation rsults (1st 900ns shown)

\_\_\_\_\_4. End your simulation. From the **ModelSim Simulate** menu, select **End Simulation** OR type **quit** -sim in the **ModelSim Transcript** window.

## **Exercise Summary**

- Finished coding the top-level 8x8 design by using structural modeling and component instantiations.
- Simulated the Verilog code in the ModelSim tool to verify correct functionality

#### **END OF EXERCISE 5b**