# EE 331 Digital Systems with HDL Oregon Tech, Wilsonville, Winter 2014

Lab (Homework) Assignment, due Week 3 (January 21)

Before starting the assignment you must install the software as described in the document Software\_Installation.pdf. This should be completed either during the first class session or by the second session so if you have any problems they can be resolved before the due date of the lab.

The Nexys board has 8 slide switches and 8 LEDs connected to the Xilinx FPGA. You are to create the logic for the FPGA and assign the FPGA pins so that if the right-most two switches are turned on the right-most LED will be turned on, otherwise it will be off. The process is to be repeated for each pair of switches up to if the left-most two switches are on the seventh LED will be turned on. Finally, if the left- and right-most switches are on the left-most LED will be turned on. Based on the labeling in the schematic, we can say:

LD0 is on if and only if SW0 and SW1 are both on.

LD1 is on if and only if SW1 and SW2 are both on.

LD2 is on if and only if SW2 and SW3 are both on.

LD3 is on if and only if SW3 and SW4 are both on.

LD4 is on if and only if SW4 and SW5 are both on.

LD5 is on if and only if SW5 and SW6 are both on.

LD6 is on if and only if SW6 and SW7 are both on.

LD7 is on if and only if SW7 and SW0 are both on.

This assignment has three parts. In the first part you will create a project for the assignment and simulate operation using the provided test bench. In the second part you will synthesize the working design from the first part and execute it on your Nexys board. In the third part you will use PlanAhead to do the FPGA pin assignments.

### Part 1 — Simulation

Start the Xilinx ISE program and create a new project (File->New Project...). The project name and path should contain no space characters. Make sure the Top-level source type is "HDL".

| _                        | Concession of the local division of the loca | Page 1 Mar | -      |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--------|
| Mew Project              | Wizard                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Hadah Room | 140.00 |
| Create New Pro           | ject                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |            |        |
| Specify project location | n and type.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |            |        |
| Enter a name, locati     | ons, and comment for the project –                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |            |        |
| Name:                    | Lab1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |            |        |
| Location:                | C:\XilinxProjects\Lab1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |            |        |
| Working Directory:       | C:\XilinxProjects\Lab1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |            |        |
| Description:             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            |        |
|                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            |        |
|                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            |        |
|                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            |        |
|                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            |        |
|                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            |        |
|                          | pp-level source for the project                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            |        |
| Top-level source typ     | )e:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |            |        |
|                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            | 1      |
|                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            |        |

Click on "Next." The Project Settings page should be set to look like the following:

| New Project Wizard                                                                   |                     | Contraction of the second |                          |
|--------------------------------------------------------------------------------------|---------------------|---------------------------|--------------------------|
| New Hojeet Wizard                                                                    |                     | Photo: Norma              | Contraction of the other |
| Project Settings                                                                     |                     |                           |                          |
|                                                                                      |                     |                           |                          |
| pecify device and project properties.<br>elect the device and design flow for the pr | roject              |                           |                          |
| Property Name                                                                        | Value               |                           |                          |
| Product Category                                                                     | All                 |                           |                          |
| Family                                                                               | Spartan6            |                           |                          |
| Device                                                                               | XC6SLX16            |                           |                          |
| Package                                                                              | CSG324              |                           |                          |
| Speed                                                                                | -3                  |                           |                          |
| Speed                                                                                |                     |                           |                          |
| Top-Level Source Type                                                                | HDL                 |                           |                          |
| Synthesis Tool                                                                       | XST (VHDL/Verilog)  |                           |                          |
| Simulator                                                                            | ISim (VHDL/Verilog) |                           |                          |
| Preferred Language                                                                   | VHDL                |                           |                          |
| Property Specification in Project File                                               | Store all values    |                           |                          |
| Manual Compile Order                                                                 |                     |                           |                          |
| VHDL Source Analysis Standard                                                        | VHDL-93             |                           |                          |
| Enable Message Filtering                                                             |                     |                           |                          |
| enoble message ritering                                                              |                     |                           |                          |
|                                                                                      |                     |                           |                          |

You should verify the settings for each project you make, although Xilinx ISE remembers the last settings for new designs. Now click on "Next" and then "Finished".

The design has no modules. Create a top-level module that will contain all the logic for your design. Go to Project->New Source... select "VHDL Module" and give it a name. Call it "top\_level". When you name your own modules you may use underscores in the name but do not use any spaces.

| New Source Wizard                                                                                                                                                                                                                                                                                                                    | X                                                               |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|
| Select Source Type<br>Select source type, file name and its location.<br>Select source type, file name and its location.<br>P (CORE Generator & Architecture Wizard)<br>Schematic<br>User Document<br>Verilog Module<br>Verilog Test Fixture<br>VHDL Module<br>VHDL Library<br>VHDL Package<br>VHDL Test Bench<br>Embedded Processor | File name:<br>top_level<br>Location:<br>C:\/\ilinxProjects\Lab1 |
| More Info                                                                                                                                                                                                                                                                                                                            | Next Cancel                                                     |

When you click "Next" you will be given the opportunity to describe the ports connecting the module to the outside, either the simulation or the FPGA pins. Because the 8 switches and 8 LEDs are easily described as 8-wire busses, we will describe them as busses. In the image below I've filled in the first line for the 8 switches. You will need to also add a line for the 8 LEDs, which are outputs and must be named Led. Why "must?" Well, the connections have already been named elsewhere for you, and the names must match just like the name of the module.

In this course we will standardize bit numbering with the least significant bit being bit 0. To access sw0, we use sw(0). To access sw1, we use sw(1), and so forth.

| Define Modu       | le         |      |       |     |     |     |   |
|-------------------|------------|------|-------|-----|-----|-----|---|
| Specify ports for | module.    |      |       |     |     |     |   |
| Entity name       |            |      |       |     |     |     | _ |
| Architecture name | Behavioral |      |       |     |     |     | _ |
|                   | Port Name  | Dire | ction | Bus | MSB | LSB |   |
| sw                |            | in   | -     | V   | 7   | 0   |   |
|                   |            | in   | -     |     |     |     |   |
|                   |            | in   | -     |     |     |     |   |
|                   |            | in   | -     |     |     |     |   |
|                   |            | in   | -     |     |     |     |   |
|                   |            | in   | -     |     |     |     |   |
|                   |            | in   | -     |     | 100 |     |   |
|                   |            | in   | -     |     |     |     |   |
|                   |            | in   | -     |     |     |     |   |
|                   |            | in   | -     |     |     |     |   |

When you finish the New Source Wizard you will have a top\_level.vhd file containing the skeleton for a module named top\_level with the correct ports already declared. You need to fill it in with the correct logic for the problem. With the top\_level module selected in the Hierarchy pane (upper left) you can use the "Check Syntax" process under Synthesize-XST to check your design syntax before proceeding to simulation.

A simulation test bench file has been provided for you to use. The file, lab1\_test\_bench.vhd is provided on the distribution. You need to add it to your project using Project->Add Copy of Source... Associate the file with Simulation:

|  | - | Simulation  |                 | -       |
|--|---|-------------|-----------------|---------|
|  |   | Jinnulation | _test_bench.vhd | 🕗 lab1_ |
|  |   |             |                 |         |
|  |   |             |                 |         |
|  |   |             |                 |         |
|  |   |             |                 |         |
|  |   |             |                 |         |
|  |   |             |                 |         |
|  |   |             |                 |         |
|  |   |             |                 |         |
|  |   |             |                 |         |
|  |   |             |                 |         |
|  |   |             |                 |         |
|  |   |             |                 |         |
|  |   |             |                 |         |
|  |   |             |                 |         |
|  |   |             |                 |         |
|  |   |             |                 |         |
|  |   |             |                 |         |

Go to the Simulation View and select the test bench:

Right click on the process "Simulate Behavioral Model" and select "Process Properties...". Then change the Simulation Run Time to 2700 ns. Then click on Simulate Behavioral Model to run the simulation. You will get error messages if the port or module names do not match. The Console area at the bottom of the simulator window will indicate if your design did not work properly. You can also pan and zoom in the waveform display to observe operation. The test bench tries every combination of switch inputs and verifies that the LED are lighting properly.



| ISim (M.81d) - [Default.wcfg]                              | n Window Layout H                      | lele.                      |                       |             |                            |                   |                    | - 5         |
|------------------------------------------------------------|----------------------------------------|----------------------------|-----------------------|-------------|----------------------------|-------------------|--------------------|-------------|
|                                                            |                                        |                            |                       |             |                            |                   |                    | - 0         |
| 🗋 ờ 🗐 🕹 🛛 🖧 🗅 🕼                                            | × ® B B B A                            | 🖌 1 🖸 🔁 🖪                  |                       | <b>K?</b>   |                            | · ^ / * / * / * / | * 🚺 🕨 🔀 1.00us 🔽 🐙 |             |
| Instances and Processes                                    | ⇔⊡₽×                                   | Objects                    | ++□₽>                 | < 🏓         |                            |                   |                    | 2.700000 us |
|                                                            |                                        | Simulation Objects for la  | ab1_test_bench        |             |                            |                   |                    |             |
|                                                            |                                        |                            | 16 🔛                  |             | ame                        | Value             | 0 us 1 us          | 2 us        |
| Instance and Process Name                                  | Design Unit Blo                        | Object Name                | Value                 | i 🍒 🕨       | <b>sw</b> [7:0]            | 11111111          | P                  |             |
| lab1_test_bench<br>std_logic 1164                          | lab1_test_be VHD<br>std logic 1164 VHD | -                          | 11111111              | - E         | Ned[7:0]                   | 11111111          |                    |             |
| std_logic_arith                                            | std_logic_arith VHD                    |                            | 11111111              |             | L clock_period             | 10000 ps          | 10000              | ps          |
| Jugic_untri                                                | sta_logic_antin vito                   | L clock_period             | 10000 ps              | 3           |                            |                   |                    |             |
|                                                            |                                        |                            |                       | 14          |                            |                   |                    |             |
|                                                            |                                        |                            |                       | <b>P</b>    |                            |                   |                    |             |
|                                                            |                                        |                            |                       | _           |                            |                   | X1: 2.700000 us    |             |
| •                                                          | •                                      |                            |                       | * ∢         |                            | F 4               | ×                  | +           |
| 🟯 Instances and Processes 🛛 🗎                              | Memory 📔 Source Files                  | •                          | •                     | ANA         | Defaul                     | t.wcfg            |                    |             |
| Console                                                    |                                        |                            |                       |             |                            |                   |                    | ↔□₽         |
| WARNING: Please use Xilinx License C                       | onfiguration Manager to chec           | k out a full ISim license. |                       |             |                            |                   |                    |             |
| WARNING: ISim will run in Lite mode. P                     |                                        |                            | ation on the differer | ices betwee | n the Lite and the Full ve | rsion.            |                    |             |
| This is a Lite version of ISim.<br>Time resolution is 1 ps |                                        |                            |                       |             |                            |                   |                    |             |
| Simulator is doing circuit initialization pr               | ocess.                                 |                            |                       |             |                            |                   |                    |             |
| inished circuit initialization process.                    |                                        |                            |                       |             |                            |                   |                    |             |
| Console  Breakpoints                                       | Find in Files Results                  | Search Results             |                       |             |                            |                   |                    |             |
|                                                            |                                        |                            |                       |             |                            |                   |                    |             |

#### Part 2 — Synthesis

To synthesize the design we need to assign the signals to pins on the FPGA. This is done using a "User Constraint File". Digilent provides one for the Nexys 3 board named Nexys3\_Master.ucf which is provided with the course materials. You need to add that file to the project, as was done for the test bench, this time specifying that it is for the Implementation and not the Simulation. Locate the file in the hierarchy pane and double-click to open the file. You need to uncomment (remove the leading hash character) the lines that define the pins you are using. In this case it is the Net lines for the Leds and the Switches. Save the file, select the top\_level file in the hierarchy, and then right-click on Generate Programming File in Processes and select Process Properties... Under Startup Options, change the FPGA Start-Up Clock to JTAG Clock. Click OK.

Now double-click on Generate Program File and sit back as the design is synthesized, placed, and routed for the FPGA.

When it says the process has completed successfully, attach the Nexys 3 board to the computer. This will cause the installation of Digilent Adept to complete. Start the Adept program. It should show that it was able to find the FPGA on the Nexys 3 board. Click on Browse and locate the file top\_level.bit in the project folder. Click on Program and your design should now be running on your Nexys 3 board!

#### Part 3 — Using the PlanAhead program for pin assignments

In this part you will use the PlanAhead program instead of the Nexys3\_Master.ucf file to do the pin assignments. First you will need to select the Nexys3\_Master.ucf file again, right-click and Remove from the project. You have just undone most of your work for part 2!

Now with the top\_level file selected in the hierarchy, click on the process under User Constraints named "I/O Pin Planning (PlanAhead — Post-Synthesis)." When the

program has started, enlarge the window on the upper left and select the pane titled I/O Ports.

| File Edit View Tool    |        | ct Layout Help |      |      |                                       |        |                    |           |           |                     |
|------------------------|--------|----------------|------|------|---------------------------------------|--------|--------------------|-----------|-----------|---------------------|
| Netlist Design - top_l |        |                |      |      | · · · · · · · · · · · · · · · · · · · | . J.   | · ····             |           | 144       | <u> </u>            |
| I/O Ports              |        |                |      |      |                                       |        |                    |           |           | _ & a ×             |
| ९ 🔀 🖨 陸 対 🗷            |        |                |      |      |                                       |        |                    |           |           |                     |
| Name                   | Dir    | Neg Diff Pair  | Site | Bank | I/O Std                               | Vcco V | ref Drive Strength | Slew Type | Pull Type | Off-Chip Terminatio |
| 🖃 🗁 All ports (16)     |        |                |      |      |                                       |        |                    |           |           |                     |
| 🖻 🖓 Led (8)            | Output |                |      |      | LVCMOS25                              | 2.500  | 1                  | 2 SLOW    |           | FP_VTT_50           |
|                        | Output |                |      |      | LVCMOS25                              | 2.500  | 1                  | 2 SLOW    |           | FP_VTT_50           |
|                        | Output |                |      |      | LVCMOS25                              | 2.500  | 1                  | 2 SLOW    |           | FP_VTT_50           |
|                        | Output |                |      |      | LVCMOS25                              | 2.500  | 1                  | 2 SLOW    |           | FP_VTT_50           |
|                        | Output |                |      |      | LVCMOS25                              | 2.500  | 1                  | 2 SLOW    |           | FP_VTT_50           |
|                        | Output |                |      |      | LVCMOS25                              | 2.500  | 1                  | 2 SLOW    |           | FP_VTT_50           |
|                        | Output |                |      |      | LVCMOS25                              | 2.500  | 1                  | 2 SLOW    |           | FP_VTT_50           |
|                        | Output |                |      |      | LVCMOS25                              | 2.500  | 1                  | 2 SLOW    |           | FP_VTT_50           |
| Led[7]                 | Output |                |      |      | LVCMOS25                              | 2.500  | 1                  | 2 SLOW    |           | FP_VTT_50           |
| 🖶 📴 sw (8)             | Input  |                |      |      | LVCMOS25                              |        | 1                  | 2 SLOW    |           | NONE                |
|                        | Input  |                |      |      | LVCMOS25                              |        | 1                  | 2 SLOW    |           | NONE                |
| [1]                    | Input  |                |      |      | LVCMOS25                              |        | 1                  | 2 SLOW    |           | NONE                |
| [2]                    | Input  |                |      |      | LVCMOS25                              |        | 1                  | 2 SLOW    |           | NONE                |
| D+ sw[3]               | Input  |                |      |      | LVCMOS25                              |        | 1                  | 2 SLOW    |           | NONE                |
|                        | Input  |                |      |      | LVCMOS25                              |        | 1                  | 2 SLOW    |           | NONE                |
|                        | Input  |                |      |      | LVCMOS25                              |        | 1                  | 2 SLOW    |           | NONE                |
|                        | Input  |                |      |      | LVCMOS25                              |        | 1                  | 2 SLOW    |           | NONE                |
|                        | Input  |                |      |      | LVCMOS25                              |        | 1                  | 2 SLOW    |           | NONE                |
| Galar ports (0)        |        |                |      |      |                                       |        |                    |           |           |                     |
| (                      |        |                | _    |      |                                       |        |                    |           |           | F.                  |

This shows all the ports and will allow you to assign pins to each of them. Select the row Led(8), and change the I/O Std to LVCMOS33. Press Enter and all the LED rows will change. Do the same for the sw row. Now click on the site for Led[0] and type in U16, the pin name for LD0. Repeat the process for all the LED and switch pins. You can find the assignments in the Nexys 3 users manual, the silkscreen on the Nexys 3 itself, or the Nexys3\_Master.ucf file! When you are done, close PlanAhead.

Repeat the synthesis process you did in part 2, and observe operation of the board.

## To Turn In:

- 1. A couple of paragraphs discussing what you did, in a Word (or OpenOffice or Pages or PDF) document.
- 2. The top level VHDL file, incorporated into the document. Make sure it is in Courier or some other mono-spaced font.
- 3. Snapshot showing the simulation result (like I did in this assignment sheet). Incorporate into the document.
- 4. Snapshot of the filled in PlanAhead screen, like the (not filled in) one above. Incorporate into the document.
- 5. Design summary (for either part 2 or 3). To do this click on Design Summary among the listed files, Make sure the Design Overview Summary is showing. Right click and select "View Report as HTML". When the HTML summary appears, do a File-->Save As and save the HTML file. It is not easy to incorporate this in a document, but if you can manage, go ahead!