| Lab Week3, 20 points                                                                             | Name:                        |                                                                         |
|--------------------------------------------------------------------------------------------------|------------------------------|-------------------------------------------------------------------------|
| Due: Wednesday, Septemb                                                                          | er 16 <sup>th</sup> , 5:20pm |                                                                         |
| The purpose of this lab is to fam project interfaces to the board.                               | iliarize you with the DE1    | 0-Lite board, and how a Quartus based                                   |
| A separate answer sheet is inclu for this lab. All files reference a                             |                              | Please submit only the answer sheet 3.zip file.                         |
| Part 1. (4 points) The purpose of board. Open the user's manual following questions from Section | for the DE10-Lite board.     | you with the details of your DE10-Lite<br>Using this manual, answer the |
| a) What logic level (logic 0 or logoressed and held?                                             | gic 1) will be seen at the   | FPGA input pins when a pushbutton is                                    |
| Answer sheet                                                                                     | <del>_</del>                 | -                                                                       |
| b) What logic level will be seen the center of the board?                                        | at the FPGA input pins v     | vhen a slide switch is pushed toward                                    |
| Answer sheet                                                                                     |                              | -                                                                       |
| c) What logic level turns on the                                                                 | LEDRs?                       |                                                                         |
| Answer sheet                                                                                     |                              | -                                                                       |
| c) What logic level turns on the                                                                 | segments of the 7-segm       | ent displays?                                                           |
| Answer sheet_                                                                                    |                              |                                                                         |
|                                                                                                  |                              |                                                                         |
| Part 2. (2 points) Open the Lab<br>Answer the following questions:                               |                              | being careful to not modify this file.                                  |
| a) How many total FPGA pins ar                                                                   | e used to connect to the     | e 6 7-segment displays?                                                 |
| Answer sheet                                                                                     |                              |                                                                         |
|                                                                                                  |                              |                                                                         |

b) What input/output voltage is used for all the signals defined in the .qsf file?

| Answer sheet |  |
|--------------|--|
|              |  |

The inputs and outputs in your top level Verilog file are the signals that Quartus will connect to the MAX10 FPGA pins. The top level module input and output names must exactly match the names used in the .qsf file. A top level input or output signal that does not have a corresponding entry in the .qsf file will be assigned to a random FPGA pin by the Quartus software. Random pin assignments will guarantee that your design will not operate correctly on the DE10-Lite board.

Part 3. (6 points) Open your text editor and create a new file called Start.v

- a) The inputs to the Verilog module will be a, b, c, and d.
- b) The output from this module will be x.
- c) The truth table that defines output x is

| а | b | С | d | х |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 | 0 |
| 0 | 0 | 1 | 0 | 0 |
| 0 | 0 | 1 | 1 | 0 |
| 0 | 1 | 0 | 0 | 0 |
| 0 | 1 | 0 | 1 | 1 |
| 0 | 1 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 | 0 |
| 1 | 0 | 0 | 0 | 0 |
| 1 | 0 | 0 | 1 | 0 |
| 1 | 0 | 1 | 0 | 0 |
| 1 | 0 | 1 | 1 | 1 |
| 1 | 1 | 0 | 0 | 0 |
| 1 | 1 | 0 | 1 | 1 |
| 1 | 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 1 | 0 |

- d) Complete your Start.v file by coding the sum of products equation to match the truth table.
- Hint 1: Refer to Appendix A in the text for Verilog syntax.
- Hint 2: You must use the Verilog keyword assign at the beginning of each equation.

- Hint 3: If you want to create intermediate values, you must declare these signals using the keyword wire. For this assignment, intermediate values are not required, but you are free to use them if it is helpful.
- e) Open tb\_Start.v in a text editor. On line 21, <u>replace the words Simulation complete with your name</u>, and save the file.
- f) Simulate your Start.v file using the tb\_Start.v testbench. Correct any mistakes in your Start.v file so that the simulation completes without errors. <u>Attach a screenshot of the simulation</u> result when you submit this lab.
- Part 4. (6 points) Open the Lab3 Quartus project using the files in Lab3.zip. Add Lab3.v as a source to your Quartus project.
- a) Paste the equations you created in Part3 into Lab3.v.
- b) Change the values a, b, c, and d to SW[3], SW[2], SW[1], and SW[0]. This change will connect the 4 switches on the DE10-Lite board so that these switches values will now be used as inputs to your design.
- c) Change the value x to LEDR[0]. This will connect the output of your design to the LED on your board.
- d) Compile your design in Quartus.
- e) When your design has compiled with 0 errors, verify that your design has the correct pinout.
- i) Click the purple triangle toward the bottom right of the Quartus screen. Any messages that show up when you click the purple triangle are called critical warnings. It is a good idea to always look at critical warnings after compiling a project. You can return to viewing all messages and warnings by clicking the All button.

You should not see any messages stating that unassigned pins exist.



ii) In the Table of Contents, go to Fitter > Resource Section > All Package Pins as shown below. Click on the User Assignment Heading to sort the results so that you see values in the User Assignment column. Verify that the first 70 rows show a Y in the User Assignment column. This indicates that all pins received location assignments from the project .qsf file.



e) Download the design to your DE10-Lite board. Using the switches defined in Lab3.v, does your design work correctly?

| Answer | sheet |
|--------|-------|
|        |       |