# **Using Fundamental Gates Lab**

## **Overview:**

In this lab you will learn how to model simple gates using Verilog HDL and use them to create a more complex design. You will use fundamental gates using language supported primitive gates. After building the basic models you will create a hierarchical design.

# **Outcome:**

You will understand how to use Verilog primitive gates. You will learn how to create a model using ISE Create Project wizard. You will instantiate lower-level models to create a bigger model. You will use ISE simulator to simulate the design. You will add user constraint file (ucf) to assign pins so the design can be targeted to National Instruments (NI) Digital Electronics FPGA Board. You will implement the design and create a bitstream file using ISE's implementation tools. Once bitstream is created, you will download using ISE's iMPACT program and verify the design functionality.

# **Background:**

Verilog HDL is a hardware description language that can be used to model a digital system at many levels of abstraction ranging from algorithmic- to the gate- to the switch-level. The complexity of the digital system being modeled could vary from a simple gate to a complete system. Various levels of abstractions can be used in modeling the digital system based on its functionality and complexity. The language supports constructs and means to model the digital system in a hierarchical fashion. It also allows designer to describe timing explicitly. The richness of the language constructs is exploited by using same language constructs to test the system.

A system- from a simple gate to a complex circuit- typically will have some input signals and some output signals to interact with either other digital devices or external board, and will have some functionality for which it has been designed. The basic unit of description in Verilog is the module. A module describes the functionality of a design and also describes the ports through which it communicates. The basic syntax of the module is:

module module\_name (port\_list);

Declarations Statements endmodule

The Verilog language is case sensitive. In the above example **module** and **endmodule** are keywords describing beginning of a module definition and ending of the module definition. You <u>can not</u> have nested module definitions, i.e. you can not have another module keyword within a module-endmodule pair. In the language, a statement is delimited by a semicolon. You can have multiple statements on a given line. The declarations in the above example can be definition of data types such as wire and reg, can be parameter definition, ports direction, functions, and tasks to name few. The Statements can be initial, always, and continuous assignment statements as well as module, gate, UDP (User Defined Primitives) instantiations. The Statements describe the

actual functionality of the module. The identifiers must be defined using Declarations before they ca be used.

The language defines three fundamental modeling styles. In a given module all or subset of these styles can be used. The three modeling styles are: Structural, Dataflow, and Behavioral. This lab exercise uses Structural style modeling. Structure can be described in Verilog using Built-in gate primitives, Switch-level primitives, User-Defined Primitives (UDP), and module instances. The Switch-level primitives are used to model fundamental gate functionality or a system built with switches or transistors. The UDP are used to define a unit as a black-box with providing functionality in truth-table form and explicit timing relationships between input and output ports. In this lab exercise you will use gate primitives and module instantiations. The language defines the following gates:

| Gate Types                 |                                | Component                                   |
|----------------------------|--------------------------------|---------------------------------------------|
| Gates                      | Allows<br>strengths            | and, nand, or,<br>nor,xor, xnor<br>buf, not |
| Three State<br>Drivers     | Allows<br>strengths            | buif0,bufif1<br>notif0,notif1               |
| MOS<br>Switches            | No strengths                   | nmos,pmos,cmos,<br>rnmos,rpmos,rcmos        |
| Bi-directional<br>switches | No strengths,<br>non resistive | tran, tranif0,<br>tranif1                   |
|                            | No strengths,<br>resistive     | rtran,rtranif0,<br>rtranif1                 |
|                            | Allows<br>strengths            | pullup<br>pulldown                          |

[Verilog Quick Reference]

Here is an example of instantiating a nor gate:

nor X1 (S1, A, B);

where X1 is the instance name. It is optional for the gate- or switch-level instantiation. The instance name is required for a module instantiation. S1 is output, and A and B are input.

#### **References:**

- 1. National Instruments' Digital Electronics FPGA Board user manual
- Verilog HDL books
   Stephen Brown, Zvonko G. Vranesic, "Fundamentals of Digital Logic with Verilog Design", 2002
   Zainalabedin Navabi, "Verilog Digital Systems Design: RT Level Synthesis, Testbench, and
   Verification", 2005
   Samir Paltinkar, "Verilog HDL: A Guide to Digital Design and Synthesis", 2003
   Joseph Cavanagh, "Verilog HDL: Digital Design and Modeling", 2007
   Michael D. Ciletti, "Modeling, Synthesis, and Rapid Prototyping with Verilog HDL", 2003
   Douglas J. Smith, "HDL Chip Design: A Practical Guide for Designing, Synthesizing and Simulating ASICs and FPGAs using VHDL or Verilog", 1996

   On-line references:
   Verilog HDL Reference Card: <a href="http://www.stanford.edu/class/ee183/">http://www.stanford.edu/class/ee183/</a>
   handouts win2003/VerilogQuickRef.pdf

Verilog Quick Reference: <u>http://frank.harvard.edu/~howard/pulsenet/docs/</u> verilog\_quikref.pdf Tutorial on Verilog: <u>http://faculty.kfupm.edu.sa/COE/abouh/</u> COE%20202%20Verilog%20Guidelines.pdf

#### **Problem Statement:**

Design a minority gate that has three inputs and one output. The output is logic 1 whenever the numbers of inputs which are logic 1 are zero or less than half of the input (i.e. 1 in this case).

# **Implementation:**

The circuit to be designed consists of three inputs and one output. Typically such circuit can be implemented using a combinational network. A truth table is created and then some Boolean minimization technique (e.g. K-Map) may be used to reduce the number of logic gates used. The truth table for the design at hand is shown next along with K-Map and minimized Boolean expression.

| Inputs | Output |
|--------|--------|
| ABC    | F      |
| 0 0 0  | 1      |
| 0 0 1  | 1      |
| 0 1 0  | 1      |
| 0 1 1  | 0      |
| 1 0 0  | 1      |
| 1 0 1  | 0      |
| 1 1 0  | 0      |
| 1 1 1  | 0      |



$$F = \overline{A} \overline{C} + \overline{B} \overline{C} + \overline{A} \overline{B}$$
$$F = (\overline{A} + \overline{C}) * (\overline{B} + \overline{C}) * (\overline{A} + \overline{B})$$

The two expressions are equivalent. We will use the  $2^{nd}$  expression in this design.

#### **Procedure:**

### 1. Create a ISE project

- Launch ISE: Select Start  $\rightarrow$  Programs  $\rightarrow$  Xilinx ISE Design Suite 10.1  $\rightarrow$  ISE  $\rightarrow$  Project Navigator
- In the Project Navigator, select File → New Project. The New Project Wizard opens
- For Project Location, use the "..." button to browse to C:\NI\Verilog\_labs, and then click **OK**
- For Project Name, type *minoritygate\_lab*
- Click Next
- Select the following options and click Next
  - ✓ Device Family: **Spartan3E**
  - ✓ Device: xc3s500E
  - ✓ Package: ft256
  - ✓ Speed Grade: -5
  - ✓ Synthesis Tool: XST (VHDL/Verilog)
  - ✓ Simulator: ISE Simulator (VHDL/Verilog)
  - ✓ Preferred Language: Verilog

| Property Name                  | Value                        |   |
|--------------------------------|------------------------------|---|
| Product Category               | All                          | * |
| Family                         | Spartan3E                    | Y |
| Device                         | ×C3S500E                     | Y |
| Package                        | FT256                        | Y |
| Speed                          | -5                           | Y |
|                                |                              |   |
| Top-Level Source Type          | HDL                          | V |
| Synthesis Tool                 | XST (VHDL/Verilog)           | ¥ |
| Simulator                      | ISE Simulator (VHDL/Verilog) | ¥ |
| Preferred Language             | Verilog                      | ¥ |
|                                |                              |   |
| Enable Enhanced Design Summary |                              |   |
| Enable Message Filtering       |                              |   |
| Display Incremental Messages   |                              |   |
|                                |                              |   |

- The **Create New Source** dialog will appear. You can use this dialog to create a new HDL source file by defining the module name and ports. You will do this once to get experience. Subsequent files creation will be done using a text file rather than using the dialog. Click **New Source** button
- A new source wizard will appear. Select *Verilog Module* as a source type and enter **my\_2or** in the *File name* field and click **Next**

| 🚾 New Source Wizard - Select Source Type                                                                                                                                                                                                                                                                                                    |                                                                                |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|
| <ul> <li>IP (CORE Generator &amp; Architecture Wizard)</li> <li>Schematic</li> <li>State Diagram</li> <li>Test Bench Waveform</li> <li>User Document</li> <li>Verilog Module</li> <li>Verilog Test Fixture</li> <li>VHDL Module</li> <li>VHDL Library</li> <li>VHDL Package</li> <li>VHDL Test Bench</li> <li>Embedded Processor</li> </ul> | File name:<br>my_2or.v<br>Location:<br>C:\NI\Verilog_Labs\minoritygate_lab<br> |
| More Info                                                                                                                                                                                                                                                                                                                                   | < Back Next > Cancel                                                           |

A *Define Module* form will appear. Enter **in1**, **in2** as the *input* in *Port Name* field and **out1** as the *output*. Change the input Direction to output by clicking and drop-down button and selection output as the direction. Click **Next** and then **OK** to create the file

•

| 🔤 New Source Wizar | rd - Define Module |     |       |           | ×        |
|--------------------|--------------------|-----|-------|-----------|----------|
| Module name my_2   | 2or                |     |       |           |          |
| Port Name          | Direction          | Bus | MSB   | LSB       | ^        |
| in1                | input              | ▼   |       |           |          |
| in2                | input              | × 🗌 |       |           |          |
| out1               | output             | × 🗌 |       |           |          |
|                    | input              | ▼   |       |           |          |
|                    | input              | ▼   |       |           |          |
|                    | input              | ▼   |       |           |          |
|                    | input              | ▼   |       |           |          |
|                    | input              | ✓   |       |           |          |
|                    | input              | × 🗌 |       |           |          |
|                    | input              | × 🗌 |       |           |          |
|                    | input              | × 🗌 |       |           |          |
|                    | i                  |     |       |           | <b>~</b> |
| More Info          |                    |     | < Bac | ck Next > | Cancel   |

- Click **Next** and *Add Existing Sources* form will be displayed. Click **Finish** as we do not have anything to add
- Click **Finish**. A project will be created and *my\_or2.v* file be created and added to the project. The file will be opened and displayed in the editor

window. You can enter related information regarding project name, target devices, etc. You will also see a module and endmodule statements are created. The only thing that is needed is to add the functionality

```
`timescale 1ns / 1ps
1
   2
3
   // Company:
4
   // Engineer:
5
   17
6
   // Create Date:
                  00:26:32 01/11/2009
7
  // Design Name:
8
   // Module Name:
                 my 2or
9
  // Project Name:
10
   // Target Devices:
11
  // Tool versions:
12
  // Description:
13
  17
14 // Dependencies:
15 //
16 // Revision:
   // Revision 0.01 - File Created
17
18
   // Additional Comments:
19
   17
   20
21
  module my 2or(
22
      input in1,
      input in2,
23
24
      output out1
25
      );
26
27
28
   endmodule
29
```

You will notice that the project hierarchy view window showing the part information as well as my\_2or as the top-level model



• Enter a gate-level instantiation statement that uses primitive gate to perform *or* function on the two inputs and output the result with 2 *ns* delay

```
module my 2or(
21
22
         input in1,
23
         input in2,
24
         output out1
25
        );
26
       or #2 01 (out1, in1, in2);
27
28
29
    endmodule
30
```

Save and close the file



- Click *New* button (. New \_ \_ \_ ) and select *text file* and click **OK**
- Enter the **module**, **endmodule**, and gate-level instantiation statement to model 2-input *and* function using the port names as **in1**, **in2**, and **out1**

```
1
     module my_2and(
 2
        input in1,
 3
        input in2,
 4
        output out1
 5
        );
 6
 7
        and #2 A1 (out1, in1, in2);
 8
 9
     endmodule
10
```

- Save and close the file, giving **my\_2and.v** as the filename
- Similarly, create a new model for the minority gate functionality (3 inputs [in1, in2, and in3] and one output [out1]), instantiating *my\_2or* and *my\_2and* models, and using necessary number of fundamental gates instantiations and having 2 ns as the delay. Use named-mapped port convention. The named-port convention requires a port name of the parent module be listed first preceded with "." followed by a net name that is connecting that port in the current module. In the below figure, .in1 is the port name of my\_or2 mdoule (parent module) where as in1\_n is the net name connecting to that port. In named-port mapping convention, one need not mention all the ports of the parent module. The unlisted parent module ports are drive logic 0 if they input and left unconnected if they are output.

```
module minoritygate( input in1, input in2, input in3, output out1);
 1
 2
 3
    wire in1_n, in2_n, in3_n, net1, net2, net3, net4;
 4
 5
     not #2 N1 (in1 n, in1);
     not #2 N2 (in2 n, in2);
 6
 7
     not #2 N3 (in3_n,in3);
 8
 9
     my 2or U1(
10
       .in1(in1 n),
                         Named Port
11
        .in2(in2_n),
                         Association
12
       .out1(net1)
13
       );
14
15
     my 2or U2 (
16
        .in1(in1_n),
17
        .in2(in3 n),
18
        .out1(net2)
19
        );
20
21
     my_2or_U3(
22
        .in1(in2_n),
        .in2(in3 n),
23
24
        .out1(net3)
25
       );
26
27
     my_2and U4(
28
       .in1(net1),
29
        .in2(net2),
30
        .out1(net4)
31
        );
32
33
     my 2and U5(
34
       .in1(net3),
35
        .in2(net4),
36
        .out1(out1)
37
        );
38
39
    endmodule
40
```



| Sources      |                   |          |                    | <u> </u> |
|--------------|-------------------|----------|--------------------|----------|
| Sources for: | Implementation    |          |                    | ~        |
| 🚽 😇 minoi    | ritygate_lab      |          |                    |          |
| 😑 🛄 xc3s!    | 500e-5ft256       |          |                    |          |
|              | my_2or (my_2or.)  | <u>.</u> |                    | ,        |
|              | miny_zor (ny_zor. | Ē        | New Source         |          |
|              |                   |          | Add Source         |          |
|              |                   |          | Add Copy of Source |          |
|              |                   | 2        | Open               |          |
|              |                   |          | Set as Top Module  |          |
|              |                   |          | SmartGuide         |          |

| • | Select minoritygate.v | and my_2and.v | files and | click O | pen   |
|---|-----------------------|---------------|-----------|---------|-------|
|   | Select minority gater |               | mes and   | enen o  | P • • |

| Add Existing Source               | es                                                                     | ? 🔀    |
|-----------------------------------|------------------------------------------------------------------------|--------|
| Look in:                          | 🔁 minoritygate_lab 💽 🖛 🗈 📸 📰 🗸                                         |        |
| My Recent<br>Documents<br>Desktop | <pre></pre>                                                            |        |
| My Documents                      |                                                                        |        |
| My Computer                       |                                                                        |        |
| My Network                        | File name: "my_2and.v" "minoritygate.v"                                | Open   |
| Places                            | Files of type:     Sources( *.txt *.vhd *.vhdl *.v *.abl *.abv *.xco * | Cancel |

• Click **OK** to finish the addition

# 2. Simulate the design using ISIM

Right-click on the minoritygate entry in *Sources* window and select New Source

| Sources      |                              |           | ×                  |
|--------------|------------------------------|-----------|--------------------|
| Sources for: | Implementation               |           | ~                  |
| - 🧃 minor    | itygate_lab                  |           |                    |
| 🖃 🛄 xc3s5    | 500e-5ft256                  |           |                    |
| ė- V.        | minoritygate (minoritygate.) | 5<br>(=#) |                    |
|              | V U1 - my_2or (my_2or.v)     | <u>I</u>  | New Source         |
|              | V U2 - my_2or (my_2or.v)     |           | Add Source         |
|              | V U3 - my_2or (my_2or.v)     |           | Add Copy of Source |
|              | V U4 - my_2and (my_2and.     | 2         | Open               |
| i            | V U5 - my_2and (my_2and.     |           | Set as Top Module  |
|              |                              |           | SmartGuide         |

 Select Test Bench Waveform as the source type and enter minoritygate\_tb in the File name field. Click Next

| 🚾 New Source Wizard - Select Source Type                                                                                                                                                                                                                                                                                                                                                                                                                                   | $\mathbf{X}$                                                                          |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|
| <ul> <li>BMM File</li> <li>ChipScope Definition and Connection File</li> <li>IP (CORE Generator &amp; Architecture Wizard)</li> <li>MEM File</li> <li>Implementation Constraints File</li> <li>Schematic</li> <li>State Diagram</li> <li>Test Bench Waveform</li> <li>User Document</li> <li>Verilog Module</li> <li>Verilog Test Fixture</li> <li>VHDL Module</li> <li>VHDL Library</li> <li>VHDL Package</li> <li>WHDL Test Bench</li> <li>Embedded Processor</li> </ul> | File name:<br>minoritygate_tb<br>Location:<br>C:\NI\Verilog_Labs\minoritygate_lab<br> |
| More Info                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | < Back Next > Cancel                                                                  |

- Select **minoritygate** as the UUT to associate the testbench to the source model and click **Next** followed by clicking **Finish** button
- Select combinatorial (internal clock) and click **Finish** to display the input and output signals. Click appropriately in the waveform window to generate input stimulus as shown below

| End Time:<br>1000 ns |   | 950.0 ns<br>0 ns 100 ns 200 ns 300 ns 400 ns 500 ns 600 ns 700 ns 800 ns 900 ns 1000 |  |
|----------------------|---|--------------------------------------------------------------------------------------|--|
| 🛺 in1                | 1 |                                                                                      |  |
| 🕕 in2                | 1 |                                                                                      |  |
| 🚺 in3                | 1 |                                                                                      |  |
| <b>}∏</b> out1       | 0 |                                                                                      |  |
|                      |   |                                                                                      |  |

- Save the file
- Select *Sources* tab and then click **minoritygate** in *Sources* window, and click on the drop-down button of the **Sources for** window and select **Behavioral Simulation**

| Sources      |                            |    | × |
|--------------|----------------------------|----|---|
| Sources for: | Implementation             |    | ¥ |
| 🦳 😇 minor    | Implementation             |    |   |
| 🖃 🌐 xc3s     | Behavioral Simulation      | N  |   |
| <u> </u>     | Post-Route Simulation      | W3 |   |
|              | VU1 - my_2or (my_2or.v)    |    |   |
|              | 💟 U2 - my_2or (my_2or.v)   |    |   |
|              | 💟 U3 - my_2or (my_2or.v)   |    |   |
|              | 🔽 U4 - my_2and (my_2and.v) |    |   |
| I            | 💟 U5 - my_2and (my_2and.v) |    |   |

• Select **minoritygate\_tb** in *Sources* tab, expand its entry to see UUT. Select *Processes* tab, expand **Xilinx USE Simulator**, and double-click on **Simulate Behavioral Model** entry to run the simulator

| Sources                                                                       |                                                                                  | ×                     |
|-------------------------------------------------------------------------------|----------------------------------------------------------------------------------|-----------------------|
| Sources for: Behavi                                                           | oral Simulation                                                                  | ~                     |
| 🦳 😇 minoritygate_l                                                            | lab                                                                              |                       |
| 🖃 🛄 xc3s500e-5ft2                                                             | 256                                                                              |                       |
| 😑 🔤 minorityga                                                                | ate_tb (minoritygate_tb.                                                         | tbw)                  |
| 🖻 🛛 💟 UUT                                                                     | <ul> <li>minoritygate (minority)</li> </ul>                                      | gate.v)               |
|                                                                               |                                                                                  |                       |
|                                                                               |                                                                                  |                       |
|                                                                               |                                                                                  |                       |
|                                                                               |                                                                                  |                       |
|                                                                               |                                                                                  |                       |
|                                                                               |                                                                                  |                       |
|                                                                               |                                                                                  |                       |
|                                                                               |                                                                                  |                       |
|                                                                               |                                                                                  |                       |
|                                                                               |                                                                                  |                       |
| 💵 Sources 👔 Files                                                             | 🔹 📸 Snapsh 👔 L                                                                   | ibrarie: 🚾 Sim Instar |
|                                                                               |                                                                                  |                       |
| Draganaa                                                                      |                                                                                  |                       |
| Processes                                                                     |                                                                                  | ×                     |
| Processes for: minori                                                         | tygate_tb                                                                        | ×                     |
| Processes for: minori<br>Add Existi                                           | ng Source                                                                        | ×                     |
| Processes for: minori<br>Add Existi                                           | ng Source<br>w Source                                                            |                       |
| Processes for: minori<br>Add Existin<br>Create Ne                             | ng Source<br>w Source<br>erated Test Bench As H                                  |                       |
| Processes for: minori<br>Add Existin<br>Create Ne<br>View Gen<br>Add Test     | ng Source<br>w Source<br>erated Test Bench As H<br>Bench To Project              |                       |
| Processes for: minori<br>Add Existii<br>Create Ne<br>E View Gen<br>Add Test I | ng Source<br>w Source<br>erated Test Bench As H<br>Bench To Project<br>Simulator |                       |
| Processes for: minori<br>Add Existii<br>Create Ne<br>E View Gen<br>Add Test I | ng Source<br>w Source<br>erated Test Bench As H<br>Bench To Project              |                       |
| Processes for: minori<br>Add Existii<br>Create Ne<br>E View Gen<br>Add Test I | ng Source<br>w Source<br>erated Test Bench As H<br>Bench To Project<br>Simulator |                       |
| Processes for: minori<br>Add Existii<br>Create Ne<br>E View Gen<br>Add Test I | ng Source<br>w Source<br>erated Test Bench As H<br>Bench To Project<br>Simulator |                       |
| Processes for: minori<br>Add Existii<br>Create Ne<br>E View Gen<br>Add Test I | ng Source<br>w Source<br>erated Test Bench As H<br>Bench To Project<br>Simulator |                       |
| Processes for: minori<br>Add Existii<br>Create Ne<br>E View Gen<br>Add Test I | ng Source<br>w Source<br>erated Test Bench As H<br>Bench To Project<br>Simulator |                       |
| Processes for: minori<br>Add Existii<br>Create Ne<br>E View Gen<br>Add Test I | ng Source<br>w Source<br>erated Test Bench As H<br>Bench To Project<br>Simulator |                       |
| Processes for: minori<br>Add Existii<br>Create Ne<br>E View Gen<br>Add Test I | ng Source<br>w Source<br>erated Test Bench As H<br>Bench To Project<br>Simulator |                       |
| Processes for: minori<br>Add Existii<br>Create Ne<br>E View Gen<br>Add Test I | ng Source<br>w Source<br>erated Test Bench As H<br>Bench To Project<br>Simulator |                       |
| Processes for: minori<br>Add Existii<br>Create Ne<br>E View Gen<br>Add Test I | ng Source<br>w Source<br>erated Test Bench As H<br>Bench To Project<br>Simulator |                       |
| Processes for: minori<br>Add Existii<br>Create Ne<br>E View Gen<br>Add Test I | ng Source<br>w Source<br>erated Test Bench As H<br>Bench To Project<br>Simulator |                       |

• The source files will be compiled and the executable file (minoritygate\_tb\_ism\_beh.exe) be generated which is then run, displaying the result in a waveform window

| Constant Circulation                |   |        |     |    |    |      |       |    |     |     |        |     |     |       |    |        |   |
|-------------------------------------|---|--------|-----|----|----|------|-------|----|-----|-----|--------|-----|-----|-------|----|--------|---|
| Current Simulation<br>Time: 1000 ns |   | 200 ns | 300 | ns | 41 | DQns | 500 i | ns | 600 | ļns | 700 ns | 800 | ļns | 900 I | ns | 1000 n | s |
|                                     |   |        |     |    |    |      |       |    |     |     |        |     |     |       |    |        |   |
| 👌 🛛 out1                            | 0 |        |     |    |    |      |       |    |     |     |        |     |     |       |    |        |   |
| 👌 🛛 in 1                            | 1 |        |     |    |    |      |       |    |     |     |        |     |     |       |    |        | l |
| all in2                             | 1 |        |     |    |    |      |       |    |     |     |        |     |     |       |    |        | l |
| 🎝 👖 in 3                            | 1 |        |     |    |    |      |       |    |     |     |        |     |     |       |    |        |   |
|                                     |   |        |     |    |    |      |       |    |     |     |        |     |     |       |    |        | l |
|                                     |   |        |     |    |    |      |       |    |     |     |        |     |     |       |    |        |   |
|                                     |   |        |     |    |    |      |       |    |     |     |        |     |     |       |    |        |   |

• You can view lower-level signals by selecting *Sim Insulator* tab in **Sources** window, expanding hierarchy, selecting a particular instance, then clicking *Sim Objects* in tab in **Processes** window, and then selecting and dragging a desired signal(s) in the waveform window

|                                         |                          |                      | _×   |
|-----------------------------------------|--------------------------|----------------------|------|
| Instance                                | Design Unit              | Туре                 |      |
|                                         | glbl                     | 1.000                |      |
| 🖃 💽 minoritygat.                        | -                        |                      |      |
| 🖻 🔁 UUT                                 | minoritygate             |                      |      |
| - 🔁 U1                                  |                          |                      |      |
| <b></b> : U2                            |                          |                      |      |
| <b>1</b> 03                             |                          |                      |      |
|                                         |                          |                      |      |
| <b></b>                                 | 5 my_2and                |                      |      |
|                                         |                          |                      |      |
|                                         |                          |                      |      |
|                                         |                          |                      |      |
|                                         |                          |                      |      |
|                                         |                          |                      |      |
| 📭 Source: 👔 File                        | a an Spapak              | 🗅 Librarie: 🔤 Sim In | etar |
|                                         | s 🛃 Suahat 🕅             |                      | star |
| Processes                               |                          |                      | ×    |
| 110003303                               |                          |                      |      |
| Type: All                               |                          |                      |      |
|                                         | Туре                     | Value                |      |
| Type: All                               | Type<br>Input Port       | Value<br>St0         |      |
| Type: All<br>Name                       |                          |                      |      |
| Type: All<br>Name<br>In in 1<br>In in 2 | Input Port               | StO                  |      |
| Type: All<br>Name<br>Mane               | Input Port<br>Input Port | StO<br>StO           |      |
| Type: All<br>Name<br>In in 1<br>In in 2 | Input Port<br>Input Port | StO<br>StO           | ~    |
| Type: All<br>Name<br>In in 1<br>In in 2 | Input Port<br>Input Port | StO<br>StO           |      |
| Type: All<br>Name<br>In in 1<br>In in 2 | Input Port<br>Input Port | StO<br>StO           | × <  |
| Type: All<br>Name<br>In in 1<br>In in 2 | Input Port<br>Input Port | StO<br>StO           |      |
| Type: All<br>Name<br>In in 1<br>In in 2 | Input Port<br>Input Port | StO<br>StO           |      |
| Type: All<br>Name<br>In in 1<br>In in 2 | Input Port<br>Input Port | StO<br>StO           |      |
| Type: All<br>Name<br>In in 1<br>In in 2 | Input Port<br>Input Port | StO<br>StO           |      |
| Type: All<br>Name<br>In in 1<br>In in 2 | Input Port<br>Input Port | StO<br>StO           |      |
| Type: All<br>Name<br>In in 1<br>In in 2 | Input Port<br>Input Port | StO<br>StO           |      |

- You can zoom-in or zoom-out the waveform window by clicking on appropriate buttons (
- You can *restart* by clicking on (
   button and re-run by clicking on *run for the specified time* (
- You can change the run-time by typing in the *new time* field
   (1000 ns ), clicking *restart* button, and then clicking on *run for the specified time* button

• Close the simulator by closing the waveform window and click OK to close the active simulator

# 3. Implement the design

- Select implementation in Sources for window
- Select minoritygate module in *Sources* window
- Expand User Constraints processes in *Processes* window
- Double-click on Floorplan IO Pre-Synthesis to open PACE program

| Processe | s 🗙 🗙                                            |
|----------|--------------------------------------------------|
| Processe | es for: minoritygate                             |
|          | Add Existing Source                              |
|          | Create New Source                                |
| ···· Σ   | View Design Summary                              |
| 🗄 🎾      | Design Utilities                                 |
| 🖻 🎾      | User Constraints                                 |
|          | Create Timing Constraints                        |
|          | 🗜 🛛 Floorplan IO - Pre-Synthesis                 |
| - (      | 🔢 🛛 Floorplan Area / 10 🎖 Logic - Post-Synthesis |
| E 🔁      | Synthesize - XST                                 |
| E 🔁      | Implement Design                                 |
| E 🔁      | Generate Programming File                        |
| E 🔁      | Configure Target Device                          |
| ···· 🕑   | Update Bitstream with Processor Data             |
| . еп     | Analyze Design Using Chipscope                   |

- Click **OK** and then **Yes** to add ucf file
  - In PACE window assign pin locations and I/O Std as shown below

| i i i | Design Obje | ct List - 1/0 Pins |     |      |          |       | ×           |
|-------|-------------|--------------------|-----|------|----------|-------|-------------|
| Γ     | 1/O Name    | 1/O Direction      | Loc | Bank | 1/0 Std. | Vref  | Vcc         |
|       | in1         | Input              | J11 | BANK | LVCMOS33 | N/A   | 3.30        |
|       | in2         | Input              | J12 | BANK | LVCMOS33 | N/A   | 3.30        |
|       | in3         | Input              | H16 | BANK | LVCMOS33 | N/A   | 3.30        |
| L,    | out1        | Output             | C11 | BANK | LVCMOS33 | 💌 N/A | <u>3.30</u> |
| [     |             |                    |     |      |          |       |             |

- Click Save button
- A dialog box will appear. Choose **XST Default:** <> option and click **OK** as we are using XST synthesis tools

| Bu | s Delimiter 🛛 🔀                                                                             |
|----|---------------------------------------------------------------------------------------------|
| Γ  | Select IO Bus Delimiter                                                                     |
|    |                                                                                             |
|    | C XST Optional {}                                                                           |
|    | Synplify Verilog Default: []                                                                |
|    | Synplify VHDL / Exemplar Default: ( )                                                       |
|    | Don't show this dialog again     (can be set through preferences dialog)     OK Cancel Help |
|    |                                                                                             |

- Close the *PACE* program using **File**  $\rightarrow$  **Close**
- A **minoritygate.ucf** file will be added to the project. Open that file and see how the constraints are written
- Close the file
- Select **minoritygate** in *Sources* window and double-click on **Implement Design** process in *Processes* window. This will go through Synthesis, and Implementation stages
- Expand Synthesis processes and double click on View RTL Schematic and View Technology Schematic processes to get different views



level





• When the implementation is completed, expand Implement Design process to view the Place & Route report



- Double-click on the **Place & Route Report** to view the report. Look at the resource utilization and note that **1** slice is being used
- You can see similar information by clicking on Design Summary tab and looking at the various information

| Map Messages     Place and Route Messages                     |                      |                           |                               |              |                   |                |
|---------------------------------------------------------------|----------------------|---------------------------|-------------------------------|--------------|-------------------|----------------|
| iming Messages                                                |                      |                           | Device Utilization Summa      | ary          |                   | E              |
| 📑 Bitgen Messages                                             | Logic Utilization    |                           | Used                          | Available    | Utilization       | Note(s)        |
| 📄 All Current Messages                                        | Number of 4 input L  | UTs                       | (1)                           | 9,312        | 1%                |                |
| Detailed Reports                                              | Logic Distribution   | n                         |                               |              |                   |                |
| Translation Report                                            | Number of occupied   | Slices                    | 1                             | 4,656        | 1%                |                |
| Map Report                                                    | Number of Slices     | containing only related I | ogic 1                        | 1            | 100%              |                |
| Place and Route Report                                        | Number of Slices     | containing unrelated log  | jic O                         | 1            | 0%                |                |
| 🔤 Static Timing Report                                        | Total Number of      | 4 input LUTs              | 1                             | 9,312        | 1%                |                |
| 🚬 🛄 Bitgen Report 📃 💌                                         | Number of bonded     | <u>OBs</u>                | (4)                           | 190          | 2%                |                |
| pject Properties                                              | <u> </u>             |                           |                               | 1            |                   | 1              |
| 🗹 Enable Enhanced Design Summar<br>🔲 Enable Message Filtering | IY                   |                           | Performance Summary           |              |                   | Ð              |
| Display Incremental Messages                                  | Final Timing Sco     | re:                       | 0                             | Pinout Data: |                   | Pinout Report  |
| nhanced Design Summary Contents                               | Routing Results:     |                           | All Signals Completely Routed | Clock Data:  |                   | Clock Report   |
| Show Partition Data Show Errors                               | Timing Constrain     | ts:                       |                               |              |                   |                |
| - Show Endis                                                  |                      |                           |                               |              |                   |                |
| 🔲 Show Failing Constraints                                    |                      |                           | Detailed Reports              |              |                   | E              |
| - 🛛 Show Clock Report                                         | Report Name          | Status                    | Generated                     | Errors       | Warnings          | Infos          |
|                                                               | Synthesis Report     | Current                   | Sun Jan 11 08:56:50 200       | 9 0          | <u>5 Warnings</u> | 0              |
|                                                               | Translation Report   | Current                   | Sun Jan 11 08:57:04 200       | 9 0          | 0                 | 0              |
|                                                               | Map Report           | Current                   | Sun Jan 11 08:57:22 200       | 9 0          | 0                 | <u>2 Infos</u> |
|                                                               | Place and Route Re   | eport Current             | Sun Jan 11 08:57:42 200       | 9 0          | <u>1 Warning</u>  | <u>1 Info</u>  |
|                                                               | Static Timing Report | Current                   | Sun Jan 11 08:57:47 200       | 9 0          | 0                 | <u>3 Infos</u> |
|                                                               |                      |                           |                               |              |                   |                |

# 4. Verify the design in hardware

• Select **minoritygate** in *Sources* window and double-click on **Generate Programming File** process to generate the bit file for the design

| Processe | es 🔰                                 | ۲ |
|----------|--------------------------------------|---|
| Process  | es for: minoritygate                 |   |
|          | Add Existing Source                  |   |
|          | Create New Source                    |   |
| ···· Σ   | View Design Summary                  |   |
| E 🎾      | Design Utilities                     |   |
| E 🎾      | User Constraints                     |   |
| 🗉 🔁      | 🚺 Synthesize - XST                   |   |
| ⊕ ₹2/    | 🚺 Implement Design                   |   |
| ֥ ()     | Generate Programming File 📐          |   |
| € 6      | Configure Target Device 🏼 🖄          |   |
| ···· 🕑   | Update Bitstream with Processor Data |   |
|          |                                      |   |

• Expand Configure Target Device process and double-click on Manage Configuration Project (iMPACT) process

| Processe | is X                                        |
|----------|---------------------------------------------|
| Processe | es for: minoritygate                        |
|          | Add Existing Source                         |
|          | Create New Source                           |
| <b>D</b> | View Design Summary                         |
| 🗉 🎾      | Design Utilities                            |
| 🗉 🎾      | User Constraints                            |
| 🖻 🔁 🦉    | Synthesize - XST                            |
| 🖻 🔁 🦉    | Implement Design                            |
| 🖻 🗈 🔇    | Generate Programming File                   |
| 6 C2     | Configure Target Device                     |
|          | Generate Target PROM/ACE File               |
|          | limit Manage Configuration Project (iMPACT) |
| ···· 🕑   | Update Bitstream with Processor Data 🛛 🗟    |
| Cor      | nnect the board with the USB-JTAG cable     |

- Power ON the board
- Click Finish to use the JTAG chain
- Select *minoritygate.bit* file to be assigned to xc3s500e device and click **Open**

| TDI<br>xc3s500e xcf04s<br>file ? file ?                                                                                                                                                                                         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Assign New Configuration File                                                                                                                                                                                                   |
| igurati     Look in: C:/NI/Verilog_Labs/minoritygate_lab/                                                                                                                                                                     < |
| <ul> <li>None</li> </ul>                                                                                                                                                                                                        |
| Enable Programming of SPI Flash Device Attached to this FPGA                                                                                                                                                                    |
| C Enable Programming of BPI Flash Device Attached to this FPGA                                                                                                                                                                  |
| <ul> <li>Click Bypass button for <i>xcf04s</i> and then OK to use FPGA device programming</li> </ul>                                                                                                                            |

• Right-click on the FPGA and select **Program** 



• This will program the FPGA and DONE light will lit on the board

- Once programmed successfully, verify the functionality by using SW0 thru SW2 and monitoring LD0 output. Verify that when more than one switch is turned ON, LD0 turns OFF
- Once confirmed the functionality, power down the board and close ISE saving project changes

## **Conclusion:**

In this lab exercise you learned how to design a hierarchical system. You also learned how to model a circuit using gate-level as well as module-instantiations. You were able to simulate the design at each level and then verify the complete design in hardware board.