# ISE Simulator (ISim) In-Depth Tutorial

UG682 (v 12.3) September 21, 2010





Xilinx is disclosing this user guide, manual, release note, and/or specification (the "Documentation") to you solely for use in the development of designs to operate with Xilinx hardware devices. You may not reproduce, distribute, republish, download, display, post, or transmit the Documentation in any form or by any means including, but not limited to, electronic, mechanical, photocopying, recording, or otherwise, without the prior written consent of Xilinx. Xilinx expressly disclaims any liability arising out of your use of the Documentation. Xilinx reserves the right, at its sole discretion, to change the Documentation without notice at any time. Xilinx assumes no obligation to correct any errors contained in the Documentation, or to advise you of any corrections or updates. Xilinx expressly disclaims any liability in connection with technical support or assistance that may be provided to you in connection with the Information.

THE DOCUMENTATION IS DISCLOSED TO YOU "AS-IS" WITH NO WARRANTY OF ANY KIND. XILINX MAKES NO OTHER WARRANTIES, WHETHER EXPRESS, IMPLIED, OR STATUTORY, REGARDING THE DOCUMENTATION, INCLUDING ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NONINFRINGEMENT OF THIRD-PARTY RIGHTS. IN NO EVENT WILL XILINX BE LIABLE FOR ANY CONSEQUENTIAL, INDIRECT, EXEMPLARY, SPECIAL, OR INCIDENTAL DAMAGES, INCLUDING ANY LOSS OF DATA OR LOST PROFITS, ARISING FROM YOUR USE OF THE DOCUMENTATION.

© 2010 Xilinx, Inc. XILINX, the Xilinx logo, Virtex, Spartan, ISE, and other designated brands included herein are trademarks of Xilinx in the United States and other countries. All other trademarks are the property of their respective owners.

# Table of Contents

| Preface: About This Tutorial                                       |    |
|--------------------------------------------------------------------|----|
| About the ISE Simulator (ISim) In-Depth Tutorial                   | 7  |
| Tutorial Contents                                                  |    |
| Tutorial Flows                                                     |    |
| Using ISim from ISE Project Navigator                              |    |
| Using ISim Standalone                                              |    |
| Additional Resources                                               |    |
| Auditional Resources                                               | 0  |
| Chapter 1: Overview of the ISE Simulator (ISim)                    |    |
| Overview of ISim                                                   | 9  |
| vhpcomp, vlogcomp                                                  |    |
| fuse                                                               |    |
| Simulation Executable                                              |    |
| isimgui.exe                                                        | 10 |
| Chapter 2: Running ISim from ISE Project Navigator                 |    |
| Overview of ISE Simulator (ISim)-Project Navigator Integrated Flow | 11 |
| Getting Started                                                    | 11 |
| Software Requirements                                              |    |
| Installing the Tutorial Design Files                               | 11 |
| Design Description                                                 | 12 |
| Functional Blocks                                                  | 12 |
| drp_dcm (drp_dcm.vhd)                                              |    |
| drp_stmach (drp_stmach.vhd)                                        |    |
| drp_demo (drp_demo.vhd)                                            |    |
| drp_demo_tb (drp_demo_tb.vhd)                                      |    |
| Design Self-Checking Test Bench                                    |    |
| Simulating the Design                                              |    |
| Creating a Project in ISE Project Navigator                        |    |
| Launching Project Navigator and Using New Project Wizard           |    |
| Creating VHDL Library                                              |    |
| Moving VHDL files to a Library                                     |    |
| Launching a Behavioral Simulation                                  |    |
| Setting Behavioral Simulation Properties                           |    |
| Launching Behavioral Simulation                                    |    |
| What's Next?                                                       | 24 |
| Chapter 3: Running ISim Standalone                                 |    |
| Overview of ISE Simulator (ISim) Standalone Flow                   | 25 |
| Getting Started                                                    |    |
| Software Requirements                                              |    |
| Installing the Tutorial Design Files                               | 25 |

| 0           | Description                                             |    |
|-------------|---------------------------------------------------------|----|
| Fu          | nctional Blocks                                         |    |
|             | drp_dcm (drp_dcm.vhd)                                   |    |
|             | drp_stmach (drp_stmach.vhd)                             |    |
|             | drp_demo (drp_demo.vhd)                                 |    |
|             | drp_demo_tb (drp_demo_tb.vhd)                           | 27 |
| De          | sign Self-Checking Test Bench                           | 27 |
| Prepari     | ing the Simulation                                      | 27 |
|             | eating an ISim Project File                             |    |
|             | ilding the Simulation Executable                        |    |
|             | Using fuse                                              |    |
| Sin         | nulating the Design                                     |    |
|             | Running the Simulation Executable                       |    |
| Wł          | nat's Next?                                             |    |
|             |                                                         |    |
| Chapter 4:  | Using the ISim Graphical User Interface                 |    |
| -           | -                                                       |    |
|             | ew of the ISE Simulator (ISim) Graphical User Interface |    |
| Exj         | ploring the User Interface                              |    |
|             | Main Toolbar                                            |    |
|             | Instances and Processes Panel.                          |    |
|             | Source Files Panel                                      |    |
|             | Objects Panel                                           |    |
|             | Wave Window                                             |    |
|             | Text Editor                                             |    |
|             | Breakpoints Panel                                       | 35 |
|             | Console Panel                                           | 36 |
| Examir      | ning the Design                                         | 36 |
|             | ding Signals                                            |    |
|             | nning the Simulation for a Specified Time               |    |
|             | starting the Simulation                                 |    |
|             | ding Groups                                             |    |
|             | ding Dividers                                           |    |
|             | ding Signals from Sub-Modules                           |    |
| Ch          | anging Signal and Wave Window Properties                | 45 |
|             | Changing the Signal Name Format                         |    |
|             | Changing the Signal Radix Format                        |    |
|             | Changing the Signal Color                               |    |
|             | Floating the Wave Window                                |    |
| Say         | ring the Wave Window Configuration                      |    |
|             | nulation the Design                                     |    |
|             | ing Markers                                             |    |
|             | ing Cursors                                             |    |
| <b>C</b> 9. | Zooming In                                              |    |
|             | Measuring Time                                          |    |
| Us          | ing Multiple Wave Configurations                        |    |
|             |                                                         |    |
|             | ging the Design                                         |    |
|             | ewing Source Code                                       |    |
| US          | ing Breakpoints and Stepping                            |    |
|             | Setting Breakpoints.                                    |    |
| T7•         | Stepping through Source Code                            |    |
|             | ing Bugs in the Design                                  | 61 |
| 1/0         | CITVIDG DUG HIV                                         | n/ |







## About This Tutorial

## About the ISE Simulator (ISim) In-Depth Tutorial

The ISim In-Depth Tutorial provides Xilinx PLD designers with a detailed introduction of the ISE Simulator (ISim) software. After you have completed the tutorial, you will have a thorough understanding of how to analyze and debug your design via HDL simulation using ISim.

This tutorial is designed for running the ISim software on a Windows environment. Some modifications may be required to run certain steps successfully in other operating systems.

## **Tutorial Contents**

This tutorial covers the following topics:

Chapter 1, Overview of the ISE Simulator (ISim), introduces the ISim software environment, including the ISim compilers, linker, simulation executable and Graphical User Interface (GUI).

Chapter 2, Running ISim from ISE Project Navigator, explains how to launch a functional simulation through the ISE Project Navigator software.

Chapter 3, Running ISim Standalone, guides you through a typical procedure for launching a functional simulation using the ISim compiler, linker and simulation executable outside of the ISE Project Navigator environment.

Chapter 4, Using the ISim Graphical User Interface, introduces you to the ISim GUI by examining, debugging, and verifying a functional simulation.

## **Tutorial Flows**

This tutorial presents two flows in which ISim can be used for performing a functional (behavioral) simulation.

## Using ISim from ISE Project Navigator

In this flow, you will launch ISim via one of the simulation processes available in ISE Project Navigator. This flow works best when an ISE Project Navigator project is created in order to implement the design in a Xilinx® FPGA or CPLD. This flow is intended for designs that contain sources that are not HDL, such as schematics and cores, which require Project Navigator to properly convert these sources to HDL source files which ISim can compile.



Follow these chapters if you are interested in this flow:

Chapter 1, Overview of the ISE Simulator (ISim)

Chapter 2, Running ISim from ISE Project Navigator

Chapter 4, Using the ISim Graphical User Interface

## Using ISim Standalone

In this mode, you will simulate your design by creating your own ISim project files and running the HDL linker and simulation executable in a command line or batch file mode. This flow is intended for users who do not need to use Project Navigator for HDL design management.

The following chapters will help you understand this flow:

Chapter 1, Overview of the ISE Simulator (ISim)

Chapter 3, Running ISim Standalone

Chapter 4, Using the ISim Graphical User Interface

#### **Additional Resources**

To find more detailed information and discussions on ISE Simulator (ISim) topics covered in this tutorial, refer to the following documents:

ISim User Guide, accessible from the Software Manuals page on the Xilinx website:

 http://www.xilinx.com/support/documentation/sw\_manuals/xilinx12\_3/ plugin\_ism.pdf

Note: ISim Help is available from the ISim software by pressing F1 or from the Help menu.

Software Manuals - To find additional documentation, see the Xilinx website at:

http://www.xilinx.com/support/documentation/index.htm

**Tutorials Page** - To find the *ISim In-Depth Tutorial* design files and other ISE Design Suite tutorials, see the Xilinx website at:

• http://www.xilinx.com/support/documentation/dt\_ise12-3\_tutorials.htm

**Answer Records** - To search the Answer Database of silicon, software, and IP questions and answers, or to create a technical support WebCase, see the Xilinx website at:

http://www.xilinx.com/support/

**Xilinx Forums** - To discuss topics of interest with other Xilinx users, see the Xilinx User Community Forum at:

http://forums.xilinx.com/xlnx/



# Overview of the ISE Simulator (ISim)

#### Overview of ISim

The Xilinx® ISE Simulator (ISim) is a Hardware Description Language (HDL) simulator that enables you to perform functional (behavioral) and timing simulations for VHDL, Verilog and mixed-language designs.

This ISE Simulator environment is comprised of the following key elements:

- Vhpcomp (VHDL compiler)
- Vlogcomp (Verilog compiler)
- fuse (HDL elaborator and linker)
- Simulation Executable
- isimgui (ISim Graphical User Interface)

Note: More information about ISim is available in the ISim User Guide.

## vhpcomp, vlogcomp

vhpcomp and vlogcomp parse and compile VHDL and Verilog source files respectively. The object code generated by the compilers is used by HDL linker (fuse) to create a simulation executable.

#### fuse

The fuse command is the Hardware Description Language (HDL) elaborator and linker used by ISim. fuse effects static elaboration on the design given the top design units and then compiles the design units to object code. The design unit object files are then linked together to create a simulation executable.

fuse can link design units compiled previously with vhpcomp or vlogcomp. Alternatively, fuse can automatically invoke vlogcomp and vhpcomp for each VHDL or Verilog source code listed in a project file (.prj). This method allows for compilation of sources "on-the-fly".

#### Simulation Executable

The Simulation Executable is generated by the fuse command. To run the simulation of a design in ISim, the generated simulation executable needs to be invoked. When ISim is run inside the ISE Project Navigator interface, ISE takes care of invoking the generated simulation executable. A command-line user needs to explicitly invoke the generated simulation executable to effect simulation. The simulation executable effects event-driven simulation and has rich support for driving and probing simulation using Tcl.



**Note:** The ISE Simulation Executable has a .exe extension in both Linux and Windows. The default executable naming format is x. exe.

## isimgui.exe

isimgui.exe (isimgui on Linux) is the ISim Graphical User Interface. It contains the wave window, toolbars, panels, and the status bar. In the main window, you can view the simulation-visible parts of the design, add and view signals in the wave window, utilize ISim commands to run simulation, examine the design, and debug as necessary.



# Running ISim from ISE Project Navigator

## Overview of ISE Simulator (ISim)-Project Navigator Integrated Flow

The Xilinx® ISE Design Suite provides an integrated flow with the ISE Simulator (ISim) that allows simulations to be launched directly from the Project Navigator (ISE). All simulation commands that prepare the ISim simulation are generated by ISE Project Navigator and automatically run in the background when simulating a design using this flow.

## **Getting Started**

## Software Requirements

To use this tutorial, you must install one of the following software:

- ISE WebPACK<sup>TM</sup> 12.3
- One of the ISE Design Suite 12.3 Editions (Logic, DSP, Embedded, System)

For more information about installing Xilinx software, see the *Xilinx ISE Design Suite*: *Installation, Licensing, and Release Notes*.

## Installing the Tutorial Design Files

Design files for this tutorial are available from the Tutorials page on the Xilinx Website.

- Download the tutorial design zip file from the website.
- Unzip the design files into an easily accessible directory with full read and write permissions.

The contents of the tutorial design files are as follows:

Table 2-1: Tutorial Design Files

| Folder  | Description                                                                     |  |  |
|---------|---------------------------------------------------------------------------------|--|--|
| sources | Contains all the HDL files necessary for a functional simulation of the design. |  |  |



Table 2-1: Tutorial Design Files

| Folder    | Description                                                                                                                                                |  |  |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| scripts   | Contains incomplete script files to run the simulation. These script files will be completed as you go through the tutorial.                               |  |  |
| completed | Contains completed script, simulation and wave configuration files, as well as a completed ISE 12 project of the tutorial design, for comparison purposes. |  |  |

## **Design Description**

The tutorial design is a simple demonstration of the Dynamic Reconfiguration feature of the Virtex®-5 Digital Clock Manager (DCM).

Using the Virtex-5 DCM, the design generates an output clock using the following relationship:

Output Clock = Input Clock \* (Multiplier / Divider)

Using the Dynamic Reconfiguration Ports (DRP) in the DCM, the design allows you to re-define the Multiplier and Divider parameters to generate different output frequencies.

#### **Functional Blocks**

The tutorial design consists of the following functional blocks.

## drp\_dcm (drp\_dcm.vhd)

Virtex-5 DCM macro with internal feedback, frequency controlled output, duty-cycle correction, and Dynamic Reconfiguration ability.

The CLKFX\_OUT output provides a clock that is defined by the following relationship:

For example, using a 100 MHz input clock, setting the Multiplier factor to 6, and Divider factor to 5, produces a 120 MHz CLKFX\_OUT output clock.

Using the DRP ports of the DCM, the Multiplier (M) and Divider (D) parameters can be dynamically redefined to produce different CLKFX\_OUT frequencies. For the purposes of this tutorial, it suffices to show how the Multiply and Divide parameters are provided to the DCM via the 16-bit wide DI\_IN port:

$$DI_IN[15:8] = M - 1$$
  
 $DI_IN[7:0] = D - 1$ 

For example, for an M/D factor of 6 / 5, DI\_IN = 0504h.

#### drp\_stmach (drp\_stmach.vhd)

This module describes a Dynamic Reconfiguration Controller. The DRP controller asserts and monitors the DCM DRP signals in order to perform a dynamic reconfiguration cycle.

A dynamic reconfiguration cycle is started by asserting the drp\_start signal. Following this step, the DRP Controller asserts the appropriate DCM DRP pins in order to complete a full Dynamic Reconfiguration cycle.



Signal drp\_done indicates a successful completion of a dynamic reconfiguration cycle.

#### drp\_demo (drp\_demo.vhd)

This is the top module of the tutorial design which connects the DCM macro and the DRP controller modules to the external I/O ports.

#### drp\_demo\_tb (drp\_demo\_tb.vhd)

Self-checking HDL test bench. Refer to Design Self-Checking Test Bench for more information.

## Design Self-Checking Test Bench

To test the functionality of this design, a self-checking test bench has been provided. (Refer to source file drp\_demo\_tb.vhd in the sources/ folder.) A self-checking test bench contains a validation routine or function that compares sampled values from the simulation against expected results. The self-checking test bench provided for this design performs the following functions.

- Generates a 100 MHz input clock for the design system clock (clk\_in).
- Performs four different tests in order to dynamically change the output frequency of the design. In each test, a DRP cycle is started (using the drp\_start signal) to set the output clock to a different frequency. The following table shows the desired output frequency and Multiplier/Divider parameters used for each test.

Table 2-1: Desired Output Frequency and Multiplier/Divider Parameters Used For Each Test

| Test | Freq. (MHz) | Period (ps) | Multiplier (M) | Divider (D) |
|------|-------------|-------------|----------------|-------------|
| 1    | 75          | 13,332      | 3              | 4           |
| 2    | 120         | 8,332       | 6              | 5           |
| 3    | 250         | 4000        | 5              | 2           |
| 4    | 400         | 2,500       | 4              | 1           |

- In each test, the test bench compares the expected clock period and the clock period
  measured during simulation. Based on the comparison results, messages are written
  to the simulator indicating success or failure.
- Upon completion of the simulation, a summary report provides a list of tests, both passed or failed.

For more details on the functionality of this design, refer to the in-line comments included in the sources of the design.

**Tip:** To create an HDL test bench in Project Navigator, select **Project > Create New Sources** and select **VHDL Testbench** or **Verilog Text Fixture**.

**Note:** To learn more about designing HDL test benches, check out Application Note <u>XAPP199</u> "Writing Effective Testbenches."



## Simulating the Design

The ISE-ISim integrated flow enables you to perform behavioral and timing simulations of your design in the ISE Project Navigator software quickly.

In this tutorial flow, in the ISE Project Navigator you will create an ISE project for the tutorial design first. You will then set some behavioral simulation properties and launch the ISim simulator to perform a behavioral simulation of the design.

## Creating a Project in ISE Project Navigator

We will use the New Project Wizard in ISE Project Navigator to quickly create an ISE project for the tutorial design.

**Note:** Read Installing the Tutorial Design Files to obtain the files required for this design.

#### Launching Project Navigator and Using New Project Wizard

Follow these steps to launch Project Navigator software and create an ISE project.

1. Double-click on the Xilinx ISE 12.3 desktop icon to launch the ISE Project Navigator.



Figure 2-1: Xilinx ISE 12.3 Desktop Icon

- 2. Click the **New Project** button to launch the New Project Wizard.
- 3. Provide a name and an appropriate location for the project (Refer to Figure 2-2).
- 4. Click **Next** to continue.





Figure 2-2: New Project Wizard: Create New Project Page

- 5. In the window, select the device and project properties.
- 6. Change the settings to match the settings shown in Figure 2-3.
- 7. Click **Next** to continue.





Figure 2-3: New Project Wizard: Project Settings

- 8. Review the Project Summary page and make sure that the settings match those shown in Figure 2-4.
- 9. Click **Finish** to continue.





Figure 2-4: Project Summary

#### Adding Tutorial Source Files to the Project

- 1. Click the Add Source button in the Design Panel toolbar to select the sources provided for this tutorial.
- 2. In the next window, make sure that the association and libraries have been properly specified for the tutorial sources. Compare your settings with those in Figure 2-5.





Figure 2-5: Status of Source Files and Associations

#### 3. Click **OK**.

The source files are added to the project.





Figure 2-6: ISE Project Navigator Design Summary

## Creating VHDL Library

Next, you need to create a user VHDL library for a VHDL package (drp\_tb\_pkg.vhd) that will be used by the test bench of this design. The VHDL package contains VHDL functions used by the test bench to perform verification routines. Once the VHDL library is created, you will move the VHDL package file from the work library to the newly-created VHDL library.

Follow these steps to create a VHDL library.

- 1. In Project Navigator, select **Project > New Source**. The New Source Wizard opens.
- Select VHDL Library as a source type.
- 3. Type **drp\_tb\_lib** for the VHDL library name. (Refer to Figure 2-7).
- 4. Click **Next** to continue.





Figure 2-7: Select Source Type

5. In the Summary page, click **Finish** to complete the New Source Wizard.

## Moving VHDL files to a Library

Follow these steps to move the VHDL package file to the drp\_tb\_lib VHDL library.

1. In the Sources Panel, click the Libraries tab to switch to the Libraries Panel. (Refer to Figure 2-8.)





Figure 2-8: Select the Libraries Tab

- 2. Expand the work library by clicking once on the hierarchy separator. (Refer to Figure 2-8.)
- 3. Right-click the drp\_tb\_pkg.vhd file, and select **Move to Library**.
- 4. In the Move to Library dialog box, select drp\_tb\_lib as the library into which you will move drp\_tb\_pkg.vhd, the VHDL package file.
- 5. Click **OK**. (Refer to Figure 2-9.)



Figure 2-9: Move to Library Window

You can now observe that a new VHDL library, drp\_tb\_lib, contains the VHDL package file drp\_tb\_pkg.vhd. (Refer to Figure 2-10.)





Figure 2-10: Source Libraries

## Launching a Behavioral Simulation

Now that the ISE project has been created for the tutorial design, we can proceed to set up and launch a behavioral simulation using ISim.

## **Setting Behavioral Simulation Properties**

Follow these steps to set behavioral simulation properties in ISE:

- 1. In the Design Panel, select **Behavioral Simulation** from the dropdown list.
- 2. Select the tutorial design test bench file, drp\_demo\_tb.

  You should now see the simulation processes available for the design in the Processes pane. (Refer to Figure 2-11)

22





Figure 2-11: Process Pane

3. Right-click **Simulate Behavioral Model** under the ISim Simulator process and select **Properties**. The ISim Properties dialog box displays (Refer to Figure 2-12).

In this window you can set different simulation properties, such as simulation runtime, waveform database file location, and even a user-defined simulation command file to launch the simulation.

For the purposes of this tutorial, we will disable the feature that runs the simulation for a specified amount of time.

4. In the ISim Properties dialog box, uncheck the property **Run for Specified Time**, and click **OK**. (Refer to Figure 2-12.)



Figure 2-12: ISim Properties Dialog Box



#### Launching Behavioral Simulation

You are now ready to launch the ISE Simulator to perform a behavioral simulation of the tutorial design. To launch the simulator:

In the Processes panel, double-click **Simulate Behavioral Model**.

The ISim Graphical User Interface (GUI) (Figure 2-13) will appear shortly after the design is successfully parsed and compiled.



Figure 2-13: ISim Graphical User Interface

#### What's Next?

Continue on to Chapter 4, Using the ISim Graphical User Interface to learn more about the ISim GUI features, and tools for analyzing and debugging HDL designs.



## Running ISim Standalone

## Overview of ISE Simulator (ISim) Standalone Flow

You can use the ISim standalone flow to simulate your design without setting up a project in ISE® Project Navigator. In this flow, you:

- Prepare the simulation project by manually creating an ISim project file in order to create a simulation executable using **fuse**.
- Start the ISim Graphical User Interface (GUI) by running the simulation executable generated by **fuse**.

## **Getting Started**

## Software Requirements

To use this tutorial, you must install one of the following software:

- ISE WebPACK<sup>TM</sup> 12.3
- One of the ISE Design Suite 12.3 Editions (Logic, DSP, Embedded, System)

For more information about installing Xilinx software, see the *Xilinx ISE Design Suite*: *Installation, Licensing, and Release Notes*.

## Installing the Tutorial Design Files

Design files for this tutorial are available from the Tutorials page on the Xilinx Website.

- Download the tutorial design zip file from the website.
- Unzip the design files into an easily accessible directory with full read and write permissions.

The contents of the tutorial design files are as follows:

Table 3-1: Tutorial Design Files

| Folder  | Description                                                                     |  |  |
|---------|---------------------------------------------------------------------------------|--|--|
| sources | Contains all the HDL files necessary for a functional simulation of the design. |  |  |



Table 3-1: Tutorial Design Files

| Folder    | Description                                                                                                                                                |  |  |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| scripts   | Contains incomplete script files to run the simulation. These script files will be completed as you go through the tutorial.                               |  |  |
| completed | Contains completed script, simulation and wave configuration files, as well as a completed ISE 12 project of the tutorial design, for comparison purposes. |  |  |

## **Design Description**

The tutorial design is a simple demonstration of the Dynamic Reconfiguration feature of the Virtex®-5 Digital Clock Manager (DCM).

Using the Virtex-5 DCM, the design generates an output clock using the following relationship:

Output Clock = Input Clock \* (Multiplier / Divider)

Using the Dynamic Reconfiguration Ports (DRP) in the DCM, the design allows you to re-define the Multiplier and Divider parameters to generate different output frequencies.

#### **Functional Blocks**

The tutorial design consists of the following functional blocks.

## drp\_dcm (drp\_dcm.vhd)

Virtex-5 DCM macro with internal feedback, frequency controlled output, duty-cycle correction, and Dynamic Reconfiguration ability.

The CLKFX\_OUT output provides a clock that is defined by the following relationship:

For example, using a 100 MHz input clock, setting the Multiplier factor to 6, and Divider factor to 5, produces a 120 MHz CLKFX\_OUT output clock.

Using the DRP ports of the DCM, the Multiplier (M) and Divider (D) parameters can be dynamically redefined to produce different CLKFX\_OUT frequencies. For the purposes of this tutorial, it suffices to show how the Multiply and Divide parameters are provided to the DCM via the 16-bit wide DI\_IN port:

$$DI_IN[15:8] = M - 1$$
  
 $DI_IN[7:0] = D - 1$ 

For example, for an M/D factor of 6 / 5, DI\_IN = 0504h.

#### drp\_stmach (drp\_stmach.vhd)

This module describes a Dynamic Reconfiguration Controller. The DRP controller asserts and monitors the DCM DRP signals in order to perform a dynamic reconfiguration cycle.

A dynamic reconfiguration cycle is started by asserting the drp\_start signal. Following this step, the DRP Controller asserts the appropriate DCM DRP pins in order to complete a full Dynamic Reconfiguration cycle.



Signal drp\_done indicates a successful completion of a dynamic reconfiguration cycle.

#### drp\_demo (drp\_demo.vhd)

This is the top module of the tutorial design which connects the DCM macro and the DRP controller modules to the external I/O ports.

#### drp\_demo\_tb (drp\_demo\_tb.vhd)

Self-checking HDL test bench. Refer to Design Self-Checking Test Bench for more information.

## Design Self-Checking Test Bench

To test the functionality of this design, a self-checking test bench has been provided. (Refer to source file drp\_demo\_tb.vhd in the sources/ folder.) A self-checking test bench contains a validation routine or function that compares sampled values from the simulation against expected results. The self-checking test bench provided for this design performs the following functions.

- Generates a 100 MHz input clock for the design system clock (clk\_in).
- Performs four different tests in order to dynamically change the output frequency of the design. In each test, a DRP cycle is started (using the drp\_start signal) to set the output clock to a different frequency. The following table shows the desired output frequency and Multiplier/Divider parameters used for each test.

Table 2-1: Desired Output Frequency and Multiplier/Divider Parameters Used For Each Test

| Test | Freq. (MHz) | Period (ps) | Multiplier (M) | Divider (D) |
|------|-------------|-------------|----------------|-------------|
| 1    | 75          | 13,332      | 3              | 4           |
| 2    | 120         | 8,332       | 6              | 5           |
| 3    | 250         | 4000        | 5              | 2           |
| 4    | 400         | 2,500       | 4              | 1           |

- In each test, the test bench compares the expected clock period and the clock period
  measured during simulation. Based on the comparison results, messages are written
  to the simulator indicating success or failure.
- Upon completion of the simulation, a summary report provides a list of tests, both passed or failed.

For more details on the functionality of this design, refer to the in-line comments included in the sources of the design.

## **Preparing the Simulation**

The ISim standalone flow enables you to to simulate your design without setting up a project in ISE Project Navigator. In this flow, you will manually create an ISim project file which **fuse** will use to create a simulation executable. Following completion of this step, the ISim Graphical User Interface (GUI) can be launched by running the simulation executable.



## Creating an ISim Project File

The typical syntax for an ISim project file is as follows:

```
verilog|vhdl <library_name> {<file_name_1>.v|.vhd}
```

#### where:

- *verilog* | *vhdl* indicates that the source is a Verilog or VHDL file. Include either verilog or vhdl.
- < library\_name > indicates the library that a particular source on the given line should be compiled. work is the default library.
- <file\_name> is the source file or files associated with the library.

**Note:** While one or more Verilog source files can be specified on a given line, only one VHDL source can be specified on a given line.

Complete the following steps to build an ISim project file for the tutorial design:

- 1. Browse to the scripts/ folder from the downloaded files.
- Open the simulate\_isim.prj project file with a text editor.The project file is incomplete.
- 3. List the missing sources using the syntax guidelines shown above.

Missing sources:

- drp\_dcm.vhd: VHDL source file. It should be compiled to work library.
- drp\_tb\_pkg.vhd: VHDL package file. It should be compiled to drp\_tb\_lib library.

**Note:** You do not need to list the sources based on their order of dependency. **fuse** automatically resolves the order of dependencies and processes the files in the appropriate order.

For comparison purposes, you can browse to the completed/ folder of the tutorial files for a completed version of the project file.

4. Save and close the file.

## Building the Simulation Executable

In this simulation step, **fuse** will use the project file created in the previous section to parse, compile and link all the sources for the design. Following completion of these steps, a simulation executable will be created which will enable you to run the simulation in the ISim GUI.

## Using fuse

The typical fuse syntax is as follows:

```
fuse -incremental -prj  project file> -o <simulation executable> library.top_unit>
```

#### where:

- -incremental: requests fuse to compile only the files that have changed since the last compile
- -prj: specifies an ISim project file to use for input
- -o: specifies the name of the simulation executable output file



library.top\_unit>: specifies the top design unit

Complete the following steps to parse, compile and elaborate the tutorial design using fuse:

- 1. Browse to the folder scripts/ from the downloaded files.
- 2. Open the fuse\_batch.bat batch file using a text editor.
- 3. This fuse command is incomplete. Using the syntax information provided above, edit the command line so it includes the following options:
  - a. Use incremental compilation.
  - b. Use simulate\_isim.prj as the project file.
  - c. Use simulate\_isim.exe as the simulation executable.
  - d. Use work.drp\_demo\_tb as the top design unit for simulation.
- 4. Save and close the batch file.
- 5. Double-click the fuse\_batch.bat file to run fuse.

Once fuse completes compiling source code, elaborating design units, and linking the object code, a simulation executable (simulate\_isim.exe) should be present in the scripts folder.

For comparison purposes, you can browse to the completed/ folder for a completed version of the fuse batch file.

## Simulating the Design

In this simulation step you will launch the ISim GUI by running the simulation executable which was generated by the **fuse** tool in the previous section, **Building the Simulation Executable**. After this step is complete, you will be able to use the ISim GUI to explore the design in more detail.

## Running the Simulation Executable

The typical syntax used when launching the simulation executable is as follows:

```
Simulation_executable -gui -view <wave_configuration_file> -wdb <waveform_database_file>
```

#### where:

- -gui: launches ISim in GUI mode.
- -view: opens the specified waveform file in the ISim GUI.
- -wdb: specifies the file name of the simulation database output file.

Complete the following steps to launch the simulation:

- 1. Browse to the scripts/ folder from the downloaded files.
- 2. Open the simulate\_isim.bat batch file using a text editor. The batch file is intentionally blank.
- 3. Using the syntax information provided above, edit the batch file so it includes the following settings:
  - a. Simulation Executable name: simulate\_isim.exe.
  - b. Launch in GUI mode.
  - c. Set simulation database output name to simulate\_isim.wdb.



Note: A wave configuration file is not provided in the tutorial files. This file will be created

- 4. Save and close the file.
- 5. Double-click the simulate\_isim.bat file to run the simulator.

The ISim GUI will now open and load the design. The simulator time will remain at 0 ns until you specify a run time.

For comparison purposes, you can browse to the completed/ folder for a completed version of the simulate\_isim.bat batch file.

#### What's Next?

Continue on to Chapter 4, Using the ISim Graphical User Interface to learn more about the ISim GUI features, and tools for analyzing and debugging HDL designs.



# Using the ISim Graphical User Interface

## Overview of the ISE Simulator (ISim) Graphical User Interface

The ISim Graphical User Interface (GUI) contains the wave window, toolbars, panels, and the status bar. In the main window, you can view the simulation-visible parts of the design, add and view signals in the wave window, utilize ISim commands to run simulation, examine the design, and debug as necessary.



Figure 4-1: ISim Graphical User Interface



## Exploring the User Interface

#### Main Toolbar



Figure 4-2: Main Toolbar

The toolbars available in the ISim main window consists of many functionally different toolbars. Each of these toolbars offers access to frequently used commands:

- File and Edit menu commands
- Window and View menu commands
- Simulation menu commands

The main window toolbar icons are located near the top of the user interface.

#### Instances and Processes Panel



Figure 4-3: Instances and Processes Panel

The Instances and Processes panel displays the block (instance and process) hierarchy associated with the wave configuration open in the Wave window. Instantiated and elaborated entities/modules are displayed in a tree structure, with entity components being ports, signals and other entities/modules.



#### Source Files Panel



Figure 4-4: Sources Files Panel

The Source Files panel displays the list of all the files associated with the design. The list of files is provided by the **fuse** command during design parsing and elaboration, which is run in the background for GUI users. The HDL source files are available for quick access to the read-only source code.

## Objects Panel



Figure 4-5: Objects Panel

The Objects panel displays all ports and signals associated with the selected instances and processes in the Instances and Processes panel.



At the top of the panel, the Simulation Objects displays which instance/process is selected in the Instances and Processes panel and the corresponding objects and their values are listed in the Objects panel.

The table columns are defined as follows:

- **Object Name** Displays the name of the signal, accompanied by the symbol which represents the type of object it is.
- **Value** The value of the signals at the current simulation time or at the main cursor, as determined by the Sync Time toolbar button.
- **Data Type** Displays the data type of the corresponding simulation object, logic or an array.

#### **Wave Window**



Figure 4-6: Wave Window

The Wave window displays signals, buses and their waveforms. Each tab in the Wave window represents a wave configuration, which consists of a list of signals and buses, their properties, and any added wave objects, such as dividers, cursors, and markers.

In the user interface, the signals and buses in the wave configuration are traced during simulation, and therefore, the wave configuration is used to drive the simulation and to then examine the simulation results. Since design and simulation data are contained in a database, simulation data is not affected when adding signals to- or removing signals from the wave configuration.



#### **Text Editor**

```
-- Company: Xilinx, Inc.
    -- Engineer: Eddie Vergara
 3
                     08:38:05 03/16/2009
   -- Create Date:
 5
    -- Design Name: DRP Demo - Top
-- Module Name: drp_demo - Behavioral
 6
    -- Project Name: DRP Demo
    -- Target Devices: xc5vlx30
9
10
    -- Tool versions: 11.1
    -- Description:
                       This unit connects instantiations of the Virtex-5 DCM macro
11
                      and DRP controller to the external I/O.
12
13
14
15
16 library IEEE;
17 use IEEE.STD_LOGIC_1164.ALL;
    use IEEE STD LOGIC ARITH ALL;
18
    use IEEE.STD_LOGIC_UNSIGNED.ALL;
19
20
    entity drp_demo is
21
    Port (
22
                --Clock and Reset
                      ×
     Default.wcfg
                                    drp_demo.vhd
                                                       ×
```

Figure 4-7: Text Editor

The text editor window is available for easy access to the HDL source files used in the simulation. Basic steps available are:

- Opening HDL source files (read-only mode)
- Viewing HDL source files
- Setting breakpoints to source files for debugging
- Stepping through the source code

#### **Breakpoints Panel**



Figure 4-8: Breakpoints Panel

The Breakpoints panel displays a list of all breakpoints currently set in the design. For each breakpoint set in your source files, the list in the Breakpoints panel identifies the file location, file name and line number. You can delete a selection, delete all breakpoints, and go to the source code from the Breakpoint panel toolbar buttons or context menu.

For more information, see Chapter 4, "Debugging the Design" in the *ISim User Guide*.



#### Console Panel



Figure 4-9: Console Panel

The Console panel enables you to view a log of messages generated by ISim, and to enter standard Tcl and ISim-specific commands at the command prompt.

## **Examining the Design**

In this section, you will perform several steps to further analyze the functional behavior of the tutorial design. These include:

- Running and restarting the simulation to review the design functionality, using signals in the wave window and messages from the test bench shown in the Console panel.
- Adding signals from the test bench and other design units to the Wave window so their status can be monitored.
- Adding groups and dividers in order to better identify signals in the Wave window
- Changing signal and Wave window properties to better interpret and review the signals in the Wave window.
- Using markers and cursors to highlight key events in the simulation and to perform zoom and time measurement features.
- Using multiple Wave window configurations to further enhance your ability to review multiple signals in one simulation session.

## Adding Signals

**Note:** Skip this step if you completed Chapter 2, Running ISim from ISE Project Navigator. All visible simulation objects from the test bench have been added to the Wave window.

Prior to running simulation for a specified time, you must add signals to the Wave window in order to observe the signal status.

You will add all available simulation objects from the test bench to the Wave window, which include:

- **Input Clock (clk\_in)**: This is a 100 MHz clock generated by the test bench and will be the input clock into the Digital Clock Manager (DCM).
- Dynamic Reconfiguration Ports (DRP) (drp\_\*): These are signals associated with the DCM DRP feature. The test bench asserts and monitors these signals to control and review the DCM DRP functionality.
- DCM Output signals (dcm\_\*): These are output clocks from the DCM.



To add these signals to the Wave window:

- 1. In the Instances and Processes panel, right-click the drp\_demo\_tb instance unit.
- 2. Select **Add to Wave Window**. (Refer to Figure 4-10).



Figure 4-10: Add to Wave Window

All visible simulation objects from the drp\_demo\_tb test bench will now show up in the Wave windw. (Refer to Figure 4-11).



Figure 4-11: Wave Window



### Running the Simulation for a Specified Time

You can now run the simulator for a specified time. Run the simulation for 5 microseconds (us).

1. In the ISim menu toolbar, type **5 us** in the Simulation Time field and press **Enter**. (Refer to Figure 4-12).

**Note:** Instead of pressing **Enter**, you can click the Run For toolbar button



Figure 4-12: Simulation Time Field

**Note:** You can also type **run** 5 **us** at the Tcl prompt (refer to Figure 4-13), and press **Enter**.



Figure 4-13: ISim Tcl Prompt

The wave window now shows traces of the signals up to 5 microseconds in simulation time (Refer to Figure 4-14).



Figure 4-14: Wave Window



To display the full time spectrum in the Wave window, select Edit > Zoom > Zoom Full View or click the Zoom Full View button



- You can use the horizontal and vertical scroll bars to view the full wave configuration.
- There are assertions from the test bench during the time of simulation. Review the Console panel for messages from the test bench (Refer to Figure 4-15).



Figure 4-15: Console Panel

### Restarting the Simulation

1. Before you continue, restart the simulation to clear the Wave window and set the simulation time to 0 picoseconds (ps).

To restart the simulation, either:

- Click the Restart button in the menu toolbar
- Run menu command Simulation > Restart.
- Type **restart** at the Tcl prompt.

The wave window should look like the one shown in Figure 4-16.





Figure 4-16: Wave Window

In the next section, you will be analyzing the simulation of the tutorial design in more detail using features from the Wave window, such as dividers, groups, cursors and markers.

### **Adding Groups**

In the next steps, you will be adding signals from other design units in order to better analyze the functionality of this design. However, soon after you add additional signals to the wave window, the size of the wave window will not be large enough to display all signals in the same view. Reviewing all signals would require the use of the vertical scroll bar in the Wave window repeatedly, making the review process rather tedious.

We can remedy this situation by collecting signals into a group. With a group, you can collectively show or hide signals of similar purpose.

To group signals in the wave configuration:

- 1. Click and hold the **Ctrl** key, and select signals of similar purpose in the Wave window.
- Right-click any selected signal and select New Group.
- 3. Type a name for the group, such as **DRP Test Signals**.
- 4. A collapsed group will be created in the Wave window. To expand the group, click once to the left of the group name.

Use the instructions above to make groups for the following signals:

- 1. All signals in the drp\_demo\_tb design unit that start with "drp\_". Name the group "DRP Test Signals".
- 2. All signals in the drp\_demo\_tb design unit that start with "dcm\_". Name the group "DCM Test Signals".
- 3. Expand all the created groups. Your wave window should be similar to the one shown in Figure 4-17.





Figure 4-17: Adding Groups

**Note:** If your signal groups do not match the figure shown above, you can use the following techniques to fix them:

- If you included an unrelated signal, use *cut and paste* to move it into the main list.
- If you created the group but missed a signal in the main list, use *drag and drop* to move the signal into the group. The signal will then be placed inside the group.
- You can undo the group using the Edit > Undo menu command.
- You can start over by ungrouping a group. Right-click on the group and select **Ungroup**.

# **Adding Dividers**

Soon you will be adding signals from other design units in order to better analyze the functionality of this design. To better visualize which signals belong to which design units, you can add dividers to separate the signals by design unit.

To add dividers to the Wave window:

- 1. Right-click anywhere on the Wave window and select **New Divider**.
- 2. Enter a name for the divider.
- 3. Use the instructions above to add three dividers named:
  - TEST BENCH
  - DCM
  - DRP CONTROLLER
- 4. Move the TEST BENCH divider to the top of the list by clicking the divider name and holding the mouse button down while moving the cursor to the top of the list.
- 5. Move the other dividers to the bottom of the list.



**Note:** Divider names can be changed at any time by double-clicking on the divider name or pressing the F2 function key, and entering a new name.

Your Wave window should be similar to the one shown in Figure 4-18 (with Groups collapsed).



Figure 4-18: Adding Dividers

# Adding Signals from Sub-Modules

You will now add signals from the instantiated DCM module (Inst\_drp\_dcm) and the instantiated DRP controller module (Inst\_drp\_statmach) in order to study the interactions between these sub-modules and the test bench test signals.

Follow these steps to add the necessary signals:

- 1. In the Instances and Processes panel, expand the hierarchy by clicking once to the left of each child module (refer to Figure 4-19).
- 2. Simulation objects associated with the currently highlighted design unit will appear in the Objects panel (refer to Figure 4-20).





Figure 4-19: Instances and Process Panel



Figure 4-20: Simulation Objects Panel

- 3. Add all input and output ports from the Inst\_drp\_dcm design unit instantiation to the Wave window. To do so, do one of the following:
  - Select the Inst\_drp\_dcm design unit in the Instance and Process panel to
    highlight it. Then in the Objects panel, right-click on the input/output ports and
    select Add to Wave Window (Refer to Figure 4-21).





Figure 4-21: Add to Wave Window

- Click and hold the Ctrl key, and select the input/output ports of the Inst\_drp\_dcm design unit. Then, drag and drop the signals to the Wave window.
- Type wave add Tcl command at the ISim Tcl prompt. For example:

```
wave add /drp_demo_tb/uut/inst_drp_dcm
```

**Note:** By default, all types of simulation objects (variables, constants, etc.) are displayed in the Objects panel. You can filter the type of simulation objects shown in this panel. Use the Objects panel toolbar to filter by inputs, outputs, bi-directional, internal, constants and variables. Toggle the desired object type by clicking on the corresponding button.



Figure 4-22: Inputs, Outputs, Bi-Directional, Internal, Constants and Variables

- 4. You can move the recently added signals if they do not appear directly under the DCM divider.
  - a. Click and hold **Ctrl+Shift**, click once on the first added DCM signal (clk\_in) and the last added DCM signal (gnd\_bit).
  - b. Once all signals are selected, move the signals under the DCM divider by holding the mouse button and placing the mouse cursor right under the divider name.
- 5. Repeat the steps above for input/output ports of Inst\_drp\_statmach instantiated design unit.
- 6. Additionally, you can also create groups for the signals recently added. Using the instructions provided for adding groups, define groups "Inputs", "Internal", and "Outputs" for each set of signals recently added.

**Note:** Use the object icon to the left of the signal name to determine the type of the simulation object (Figure 4-23).



#### Signals



Figure 4-23: Signals and Icons

Your Wave window should be similar to the one shown in Figure 4-24 (with groups collapsed).



Figure 4-24: Configuring the Wave Window

# Changing Signal and Wave Window Properties

Next, you will change the properties of some of the signals currently shown in the Wave window in order to better visualize the behavioral simulation.



#### Changing the Signal Name Format

By default, ISim adds signals to the waveform using the short name (the hierarchy reference removed). For some signals, it is important to know which module they belong to.

To change the signal name format:

- 1. In the wave window, right-click on the signal name, listed under the Name column.
- 2. Select **Name > Long** (Refer to Figure 4-25).



Figure 4-25: Change the Signal Name Format

Note: You can perform a format change on multiple signals with fewer clicks by:

- Selecting multiple signals using Ctrl+Shift.
- Applying the format change via the right-click context menu.

Use the instructions above to change the format of the following bus signals from "Short" to "Long", listed under the DRP Test Signals group:

- drp\_multiply
- drp\_divide

#### Changing the Signal Radix Format

Some signals are better interpreted if seen in hexadecimal rather than in binary. For example, the signals drp\_multiply and drp\_divide are bus signals that are best interpreted in hexadecimal format, rather than binary.

To change the radix of a signal:

- 1. In the wave window, right-click on the signal name, listed under the Name column.
- 2. Select Radix, then the radix type you wish to interpret the signal in (Refer to Figure 4-26).



Figure 4-26: Changing the Radix of a Signal

Using the instructions above, change the format of the following signals from "Binary" to "Hexadecimal":

- drp\_demo\_tb/drp\_multiply
- drp\_demo\_tb/drp\_divide

### Changing the Signal Color

ISim allows you to change the signal color in the Wave window to help you quickly identify similar signals from each other.



To change the color of a signal:

- 1. In the Wave window, right-click a signal name in the Name column.
- 2. Select **Signal Color**, and pick a color from the color palette or a custom color by clicking on the ellipsis (...) button (Refer to Figure 4-27).



Figure 4-27: Changing the Signal Color

Using the instructions above, change the format of the following signals from their default color to a color of your choice:

- drp\_demo\_tb/drp\_multiply
- drp\_demo\_tb/drp\_divide

#### Floating the Wave Window

Depending on your screen resolution, you may notice that the wave window has been populated with more signals than the screen can view at one time. To alleviate this problem, we can increase the viewable area by floating the wave window. Following this step will open a new window with just the waveform contents.

To float a window, do one of the following:

- While highlighting an object in the Wave window, select Window > Float.
- Click the Float Window main toolbar button.



Figure 4-28: Selecting Float from the View Menu

Right-click the wave configuration name tab and select Float.



Figure 4-29: Selecting Float from the Wave Configuration Name Tab

You are done making modifications to the Wave window. The Wave window should now look similar to Figure 4-30 when test bench groups are expanded.)





Figure 4-30: Fully Configured Floating Wave Window

### Saving the Wave Window Configuration

You can save the current state of the Wave window (wave configuration) so it is available for use in future ISim simulation sessions of your design.

To save the wave configuration:

1. Select **File > Save As** to assign a name to the current wave configuration (Refer to Figure 4-31).



Figure 4-31: Saving the Wave Window Configuration

2. Save the current wave configuration to the filename **tutorial\_1.wcfg**.

The wave configuration is now saved for future use.



**Note:** You can load the saved Wave window configuration using the menu command **File > Open**. This feature is useful when you have set up a wave configuration that you will reuse in future simulation sessions of the design.

### Simulation the Design

You are ready to simulate the design again with the updated wave configuration. Re-run the simulation by either:

- Click the Run All toolbar button
- Select Simulation > Run All.
- Type run all at the Tcl prompt.

The simulation will run for about 13 microseconds (us).

After the simulation is complete, use the menu toolbar button is to zoom to full view.

The wave configuration should look similar to Figure 4-32.



Figure 4-32: Wave Window After 13 us Simulation Time

# **Using Markers**

The self-checking test bench used in this design performs four different tests to showcase the functionality of the DCM Dynamic Reconfiguration feature. Follow the next steps to use markers to mark each time a new test has started.



1. In the Console panel, identify the simulation times when each test has started. For example, Test 2 starts at about 3.46 microseconds (3,461,664 ps), as shown by this segment of the ISim Console:



Figure 4-33: Console Window

2. From the ISim main menu, select **Edit > Go To** and enter **1150 ns** in the Go To Time field to move the main (yellow) cursor to the first test bench test.



*Figure 4-34:* **Edit > Go To** 



Figure 4-35: Go To Time

- 3. In the Wave window, add a marker at this time. To add a marker, either:
  - Click the Add Marker toolbar button .
  - Select Edit > Markers > Add Marker.
- 4. Repeat these steps for all four tests performed by the test bench. The Wave window should look similar to Figure 4-36.





Figure 4-36: Using Markers to Identify Start of Tests

### **Using Cursors**

The ISim Console reports that Test 2 and Test 4 failed (Figure 4-37).



Figure 4-37: Console Report Test 2 and Test 4 Failed



In Test 2 and 4, a Dynamic Reconfiguration (DRP) write cycle is performed in order to change the multiply and divide factors of the Digital Frequency Synthesizer and set new clock output (CLKFX) frequencies (120 MHz and 400 MHz, respectively). However, at the end of the DRP cycle, the test bench measured a period that did not match the expected period. Tests 2 and 4 fail due to the period discrepancy (Figure 4-38, Figure 4-39).



Figure 4-38: Test 2 Fails Due To Period Discrepancy



Figure 4-39: Test 4 Fails Due To Period Discrepancy

In the next few steps, you will use the ISim main cursor (yellow cursor) to zoom in the wave window when one of the failing tests takes place. You will also use the cursor to measure the period of signal dcm\_clkfx\_out and verify that the test bench is making accurate measurements.

#### Zooming In

First, zoom in where Test 2 starts to review the status of output clock dcm\_clkfx\_out.

To use a cursor for zooming in on a specific area:

- 1. Place the cursor on the desired area using one of the following methods:
  - Click and drag the main cursor (yellow cursor) close to the marker that represents the start of Test 2 (marker at time 3,461,664 ps). The cursor will snap onto the marker.
  - Click the Previous Marker or Next Marker toolbar buttons to quickly move the main cursor from marker to marker.
  - Select **Edit > Go To** and specify the time when Test 2 starts (time 3,461,664 ps). The main cursor will now move to this time location.



- 2. Zoom in using one of the following methods:
  - Click the Zoom In toolbar button
  - Select View > Zoom > Zoom In.
  - Press F8.

The Wave window will zoom in around the area specified by the cursor.

3. Use step 2 above repeatedly until you can clearly see DCM test signals dcm\_clk0\_out and dcm\_clkfx\_out toggle.



Figure 4-40: Zooming into the Wave Window

### Measuring Time

You can use the main cursor to measure time between two endpoints. You will use this feature to confirm the test bench calculations reported in the Console during Test 2 by measuring the period of dcm\_clkfx\_out after the DRP cycle has completed (signal drp\_done is asserted).

To measure time using cursors:

- 1. Use the Snap to Transition toggle button 1 to easily snap the cursor on to transition edges.
- 2. Press and hold the left mouse button in an area around the first clock rising edge following DRP cycle completion (drp\_done signal asserted). The main cursor will snap to the rising edge of dcm\_clkfx\_out.



3. While holding the button, move the mouse over to the next clock rising edge. A second marker should appear.

The time between the two defined endpoints will appear at the bottom of the wave window as a time delta (refer to Figure 4-41).

**Note:** Use Zoom In for better performance of the time measurement feature.



Figure 4-41: Measuring Time With the Measure Tool

Using the cursors, we measure a 7,142 ps time difference between two rising edges of the dcm\_clkfx\_out output clock. This translates to a 140 MHz clock signal. Test 2 fails due to the frequency discrepancy (expected is 120 MHz).

4. Repeat the same steps above to analyze the Test 4 failure. You should observe that while the test bench expects a frequency of 400 MHz, the actual frequency measured is 300 MHz.

**Note:** Use the Floating Ruler feature (available from the wave window toolbar) to display a hovering ruler over the wave configuration. This feature is available when performing a time measurement using cursors between two endpoints. The zero (0 ps) on the ruler is placed at the first time endpoint. This feature is useful when making multiple time measurements with respect to the first endpoint (Figure 4-42).



Figure 4-42: Floating Ruler Feature

### Using Multiple Wave Configurations

Depending on the resolution of the screen, a single Wave window may not display all the signals of interest at the same time. You can resolve this problem by opening multiple Wave windows, each with their own set of signals and signal properties.

To open a new Wave window:

- 1. In ISim, select **File > New**.
- 2. In the New dialog box, select **Wave Configuration** and click **OK** (Figure 4-43).

A blank wave configuration will be shown.



Figure 4-43: New Wave Configuration

To move dividers, groups and simulation objects to the new wave configuration:

- Press and hold the Ctrl key, and highlight objects you want to move to the new wave window.
- 2. Right-click any selected signals, and select **Cut**.
- 3. Click the window tab for the new wave configuration, untitled 1.
- 4. Right-click in the Name column area of the wave configuration, and select **Paste**.
- 5. Use the instructions above to move all the simulation objects associated with the DCM and DRP Controller units to a new wave window (dividers, groups, etc.).
- 6. Upon completion of this task, select **File > Save As** to save this wave configuration as tutorial\_2.wcfg.



You should now have two wave windows that should look similar to Figure 4-44 and Figure 4-45.



Figure 4-44: tutorial\_1.wcfg





Figure 4-45: tutorial\_2.wcfg

# **Debugging the Design**

Now that you have examined the design using markers, cursors, and multiple wave configurations, you will now use ISim debugging features, such as setting breakpoints and stepping through source code, in order to debug the design and address the two failing DRP tests.

# Viewing Source Code

First, take a look at the test bench for the tutorial design and learn how each test is performed.

To open a source code (read-only mode), either:

- Select **File > Open** to point to the file of choice.
- In the Instances and Processes Panel, right-click on the design unit described by the source file of interest, then select **Go to Source Code**.
- In the Objects Panel, right-click on any of the simulation objects declared in the source file of choice, then select **Go to Source Code**.
- In the Source Files Panel (viewable by clicking on the "Source Files" tab), double-click a source file.



Use the directions above to open the source code for the tutorial design test bench (drp\_demo\_tb.vhd). The source file will be opened using the integrated text editor (Refer to Figure 4-46).



Figure 4-46: Integrated Text Editor

# Using Breakpoints and Stepping

A breakpoint is a user-determined stopping point in the source code used for debugging the design with ISim. When simulating a design with set breakpoints, simulation of the design stops at each breakpoint in order to verify the design behavior. Once the simulation stops, an indicator is shown in the text editor next to the line of source code where the breakpoint was set, allowing you to compare the Wave window results with a particular event in the source code.

Another useful ISim debugging tool is the Stepping feature. With stepping, you can run the simulator one simulation unit at the time. This is helpful if you are interested in learning how each line of your source code affects the results in simulation.

We can use both of these debugging features to learn how the DRP cycle is performed during Test 2 in an attempt to debug the failing test.

#### **Setting Breakpoints**

Begin by first setting a breakpoint around the first signal assignment performed during each of the DRP cycle tests.



To set a breakpoint:

- Open the source code which will contain the breakpoint.
- Go to an executable line in the source code which will contain the breakpoint.
- Add a breakpoint using one of the following methods:
  - Right-click anywhere on the executable line and select **Toggle Breakpoint**.
  - Highlight the line by performing a left-click on the line number, then from the menu, select View > Breakpoint > Toggle Breakpoint.
  - Click the text editor toolbar breakpoint button
- Use the instructions above to set a breakpoint at line 185 in drp\_demo\_tb.vhd (Refer to Figure 4-47). Doing so will cause the simulator to stop every time the signal drp multiply is assigned a value.

```
-- 1. Set Multiplier and Divider values
183
184
            drp_multiply <= conv_std_logic_vector((t</pre>
185 🬑
            drp divide <= conv std logic vector((tes
186
```

Figure 4-47: Setting a Breakpoint at Line 185 in drp\_demo\_tb.vhd

Note: You can manage breakpoints by clicking on the Breakpoints tab (next to the Console tab). All set breakpoints will appear in this list. From here, you can:

- Delete selected breakpoint
- Delete all breakpoints
- Go to the line of source code for selected breakpoint



Figure 4-48: Breakpoints Tab

Re-run the simulation with the breakpoint enabled by following these steps:

1. Bring the ISim main window into focus.

Note: Debugging with the breakpoints and stepping features work best when you are able to review the console output and the Wave window at the same time. Use the Float feature of the ISim panels, or resize the windows of the simulator, to best accommodate the windows so they can be reviewed at the same time.

To restart the simulation from the ISim menu toolbar, click the Restart button .



To run the simulation, click the Run All button

The simulation runs near the start of the first test.

Focus changes to the text editor where it shows the yellow indicator ( ) at the last line of source code the simulator executed.



```
183 -- 1. Set Multiplier and Divider values
184
185 drp_multiply <= conv_std_logic_vector((te
186 drp_divide <= conv_std_logic_vector((test
```

Figure 4-49: The Last Line of Executed Source Code

Additionally, a message will appear in the Console indicating that the simulator has stopped, including the line of source code last executed by the simulator.

We know Test 1 finishes successfully when we examined the design earlier. As such, we can skip debugging this test.

4. To continue forward to Test 2, click the Run All button



The simulation now stops at the start of Test 2.

```
Console

at 3461664 ps: Note: (/drp_demo_tb/).

-- Test 2: *START* - Set DCM_CLKFX_OUT = 120 MHz (8.332 ns) via DRP Cycle (M=7, D=5)

Stopped at time: 3461664 ps: File *C:/Projects/ISim Tutorial/ISim in depth design files/sources/drp demo tb.vhd**Line 185

ISIm>

Console

Breakpoints

Find in Files Results

Search Results
```

Figure 4-50: Message in the Console Indicating That the Simulator Has Stopped

#### Stepping through Source Code

You first need to verify that in Test 2, the appropriate Multiplier and Divider parameters are being set correctly via the drp\_multiply and drp\_divide bus signals. You will use stepping to step through the source code line by line and review how the drp\_multiply and drp\_divide bus signals are assigned to the DCM DRP ports.

To step through a simulation, either:

- Click on the Step toolbar button 🛂
- Select Simulation > Step.
- Type step at the Tcl prompt.
- 1. Use the instructions above to step through the design. As you step through the source code, pay close attention to each of these events:
  - drp\_multiply and drp\_divide bus signals are assigned values from a constant test\_vectors.
  - drp\_start asserts in order to start a DRP cycle.
  - drp\_multiply bus signal is assigned to the 8 uppermost bits of bus signal DI\_IN, while drp\_divide bus signal is assigned to the 8 lowermost bits of the same bus.
  - The DRP controller (drp\_stmach.vhd) leaves idle mode and moves to the next DRP cycle step, clearing the DCM status registers.
- 2. In the "tutorial\_2" wave window, expand the DCM Inputs bus.
- 3. Continue stepping through the simulation until the di\_in bus signal is updated with a new value (you may need to zoom in considerably in order to observe the change). At around 3,465 ns, the bus should be updated from 0203h to 0604h.



*Note:* Change the radix of bus signal di\_in to Hexadecimal to verify this value change.

Figure 4-51: Analyzing Output of DCM DI\_IN Input Bus on the Wave Window

4. The output clock frequency of this design (dcm\_clkfx\_out) is dependent on the multiply and divide factors you provide. For Test 2, we use the following parameters and expected output clock frequency:

Table 4-1: Parameters and Expected Output Clock Frequency

| Test | Freq. (MHz) | Period (ps) | Multiplier (M) | Divider (D) |
|------|-------------|-------------|----------------|-------------|
| 2    | 120         | 8,332       | 6              | 5           |

You may recall that for M=6 and D=5, di\_in[15:0] bus value should be 0504h. Notice that the status of di\_in in Test 2 is 0604h. Test 2 fails because an incorrect M/D factor is provided via the drp\_multiply and drp\_divide signals in the test bench.

5. You can repeat the steps above to determine the cause of failure for Test 4. You will determine that the failure is also due to incorrect assignments of the multiply and divide signals in the test bench.

# Fixing Bugs in the Design

By using breakpoints and stepping, you have determined that the incorrect multiply and divide values are assigned to the drp\_multiply and drp\_divide signals in the test bench.

In the next steps, revise the test bench test vectors to use the correct Multiplier and Divider parameters in Tests 2 and 4.

1. To close the ISE Simulator, select **File > Close**.

**Note:** If changes have been made to the wave configuration before the last save, ISim prompt you to save changes prior to closing the session.

Using a text editor (outside of ISim), open the test bench source file, drp\_demo\_tb.vhd.



3. In lines 117 through 127, test vectors for the 4 DRP tests are defined. Revise the constant declaration to read (changes highlighted in **bold**):

4. Save and close the file.

### Verifying Bug Fix

Now that the test bench source code has been fixed, you need to re-compile the source code and build a new simulation executable.

- 1. Re-launch the ISE Simulator (ISim).
  - If you are using the ISim ISE Integrated flow, in Project Navigator re-launch ISim by double-clicking on **Simulate Behavioral Model**.
  - If you are using the ISim Standalone flow, re-launch the ISE Simulator by running the **fuse** script, followed by the simulation executable (fuse\_batch.bat and simulate\_isim.bat).
- 2. Once ISim starts, load the tutorial\_1.wcfg and tutorial\_2.wcfg wave configurations previously saved in Examining the Design.

To load a wave window configuration:

- Select **File > Open**, and point to the wave configuration files (.wcfg).
- 3. You are ready to simulate the design again with the updated test bench. Re-run the simulation using one of the following methods:
  - Click the Run All toolbar button
    - Select Simulation > Run All.
  - Type **run all** at the Tcl prompt

If the test vectors in the test bench were properly revised, the simulation should run to completion, showing that all tests pass (Figure 4-52).





Figure 4-52: Console Showing That All Tests Pass

#### What's Next

This completes the ISE Simulator (ISim) In-Depth Tutorial. Refer to the Additional Resources section in the Preface for links to more detailed information about the ISE Simulator.

