



# XEPLD **REFERENCE GUIDE** FOR WINDOWS



**TABLE OF CONTENTS** 





GO TO OTHER BOOKS



0401306

Copyright 1995 Xilinx Inc. All Rights Reserved.

# Contents

#### Chapter 1 Design Flow

| Overview of Design Processing                | . 1-1  |
|----------------------------------------------|--------|
| Design Entry                                 | . 1-1  |
| Project Creation                             | . 1-2  |
| Design Translation                           | . 1-3  |
| Design Implementation and Device Programming | . 1-4  |
| Report Generation                            | . 1-5  |
| Timing Analysis                              | . 1-6  |
| Enter the Design                             | . 1-7  |
| Create a New Project                         | . 1-7  |
| Implement the Design                         | . 1-13 |
| Use the Report Browser                       | . 1-15 |
| Use the Timing Analyzer                      | . 1-16 |

## Chapter 2 Using The Design Manager

| Design Manager Fundamentals       | 2-2  |
|-----------------------------------|------|
| Managing Projects                 | 2-2  |
| Managing Design Versions          | 2-3  |
| Managing Device Implementations   | 2-3  |
| Managing Implementation Revisions | 2-3  |
| Design Management Procedure       | 2-4  |
| The Initial Design Manager Window | 2-5  |
| File Menu                         | 2-6  |
| File — New Project                | 2-6  |
| File — Open Project               | 2-11 |
| File — Save Project               | 2-11 |
| File — Close Project              | 2-11 |
| File — Delete Project             | 2-12 |
| File — File name                  | 2-12 |
| File — Exit                       | 2-12 |
| Design Menu                       | 2-13 |
| Design — Translate                | 2-13 |
| Design — Implement                | 2-14 |
| Design — Export                   | 2-18 |
|                                   |      |

|           | Design — New Device                           | 2-19 |
|-----------|-----------------------------------------------|------|
|           | Design — New Revision                         | 2-20 |
|           | Design — Copy Revision                        | 2-20 |
|           | Design — Browse Revision                      | 2-21 |
|           | Design — Rename                               | 2-24 |
|           | Design — Delete Revision                      | 2-24 |
|           | Tools Menu                                    | 2-25 |
|           | Tools — Flow Engine                           | 2-25 |
|           | Tools — Timing Analyzer                       | 2-25 |
|           | Tools — Partitioner                           | 2-26 |
|           | Utilities Menu                                | 2-26 |
|           | Utilities — Report Browser                    | 2-26 |
|           | Utilities — Command History                   | 2-27 |
|           | Utilities — Project Notes                     | 2-28 |
|           | Utilities — Template Manager                  | 2-28 |
|           | Help Menu                                     | 2-35 |
|           | Help — Contents                               | 2-35 |
|           | Help — Search                                 | 2-37 |
|           | Help — Tutorial                               | 2-37 |
|           | Help — About Design Manager                   | 2-37 |
|           | Setting Up The Process Flow                   | 2-39 |
|           | Using a Constraints File (to Define T-Specs)  | 2-39 |
|           | Using a Guide File (to Re-Use Pinouts)        | 2-39 |
|           | Flow Engine Menu Commands                     | 2-40 |
|           | Flow Engine — Flow                            | 2-40 |
|           | Flow Engine — Setup                           | 2-41 |
|           | Flow Engine — Utilities                       | 2-44 |
|           | Flow Engine — Help                            | 2-44 |
| Chapter 3 | Controlling Design Implementation             |      |
|           | Design Implementation Overview                | 3-1  |
|           | Design Manager — Single Device Selection      | 3-4  |
|           | Software Device Selection Criteria            | 3-5  |
|           | Schematic — Device Selection                  | 3-5  |
|           | PART or PARTTYPE                              | 3-5  |
|           | Behavioral — Device Selection                 | 3-6  |
|           | CHIP                                          | 3-6  |
|           | VHDL — Device Selection                       | 3-6  |
|           | set attribute                                 | 3-6  |
|           | Working With Multiple Devices.                | 3-7  |
|           | Design Manager — Multiple Device Partitioning | 3-7  |
|           |                                               |      |

| Schematic — Multiple Device Partitioning     | 3-8  |
|----------------------------------------------|------|
| GROUP                                        | 3-8  |
| CHIP                                         | 3-9  |
| Manual Logic Placement                       | 3-9  |
| Design Manager — Logic Placement             | 3-10 |
| Schematic — Logic Placement                  | 3-10 |
| F                                            | 3-10 |
| Н                                            | 3-11 |
| LOC=f-b-name_mc-location                     | 3-11 |
| Behavioral — Logic Placement                 | 3-11 |
| PARTITION                                    | 3-11 |
| VHDL — Logic Placement                       | 3-12 |
| F                                            | 3-12 |
| Н                                            | 3-12 |
| Manual Pin Assignment                        | 3-12 |
| Design Manager — Pin Assignment              | 3-13 |
| Schematic — Pin Assignment                   | 3-13 |
| LOC=pin_name[@chip_name]                     | 3-13 |
| Behavioral — Pin Assignment                  | 3-14 |
| INPUTPIN                                     | 3-14 |
| OUTPUTPIN                                    | 3-14 |
| IOPIN                                        | 3-14 |
| FOEPIN                                       | 3-14 |
| FASTCLOCK                                    | 3-14 |
| CEPIN                                        | 3-14 |
| VHDL — Pin Assignment                        | 3-15 |
| set_attribute                                | 3-15 |
| Design Manager — Design Optimization Control | 3-16 |
| Timing                                       | 3-19 |
| Input Register                               | 3-19 |
| Fast Output Enable                           | 3-19 |
| Fast Clock                                   | 3-19 |
| UIM                                          | 3-20 |
| Pre Load                                     | 3-20 |
| Schematic — Design Optimization Control      | 3-20 |
| OPT=OFF ON UIM                               | 3-20 |
| LOGIC_OPT=OFF                                | 3-21 |
| UIM_OPT=OFF                                  | 3-21 |
| MINIM=OFF                                    | 3-21 |
| MINIMIZE=OFF                                 | 3-21 |
| FOE_OPT=OFF                                  | 3-22 |

| CLOCK_OPT=OFF                            | 3-22 |
|------------------------------------------|------|
| REG_OPT=OFF                              | 3-22 |
| PRELOAD_OPT=OFF                          | 3-22 |
| Behavioral — Design Optimization Control | 3-23 |
| LOGIC_OPT                                | 3-23 |
| MINIMIZE                                 | 3-23 |
| OPTIONS                                  | 3-23 |
| VHDL — Design Optimization Control       | 3-23 |
| NO_FOE                                   | 3-23 |
| NO_FCLK                                  | 3-24 |
| NO_IFD                                   | 3-24 |
| OPT_OFF                                  | 3-24 |
| OPT_UIM                                  | 3-25 |
| Power Management                         | 3-25 |
| Design Manager — Power Management        | 3-25 |
| Schematic — Power Management             | 3-28 |
| LOWPWR=ON   OFF   ALL                    | 3-28 |
| Behavioral — Power Management            | 3-28 |
| PWR                                      | 3-28 |
| VHDL — Power Management                  | 3-28 |
| LOWPWR                                   | 3-28 |
| Slewrate Control                         | 3-29 |
| Schematic — Slewrate Control             | 3-29 |
| FAST                                     | 3-29 |
| Behavioral — Slewrate Control            | 3-29 |
| FAST                                     | 3-29 |
| VHDL — Slewrate Control                  | 3-29 |
| set_pad_type                             | 3-30 |
| Schematic — Initial State Control        | 3-31 |
| INIT=R   S                               | 3-31 |
| PRELOAD_OPT                              | 3-31 |
| Behavioral — Initial State Control       | 3-32 |
| signal_name.PRLD                         | 3-32 |
| VHDL — Initial State Control             | 3-32 |
| PRELOAD                                  | 3-32 |
| INIT=R   S                               | 3-32 |
| set_attribute                            | 3-33 |
| Design Manager — Resource Reservation    | 3-34 |
| Reserved Input Pins                      | 3-36 |
| Reserved Output Pins                     | 3-36 |
| Reserved Bidirectional Pins              | 3-37 |

|           | Reserved Macrocells                              | 3-37 |
|-----------|--------------------------------------------------|------|
| Chapter 4 | Controlling Design Timing                        |      |
|           | Design Manager — Timing Control                  | 4-1  |
|           | Schematic — Timing Control                       | 4-3  |
|           | Defining Timing Specifications                   | 4-3  |
|           | The TIMESPEC Primitive                           | 4-4  |
|           | TIMESPEC Attribute Syntax                        | 4-4  |
|           | Defining Timing Path End Points                  | 4-5  |
|           | Using Predefined Groups                          | 4-6  |
|           | Creating Arbitrary Groups Using TNMs             | 4-6  |
|           | Creating New Groups from Existing Groups         | 4-10 |
|           | The TIMEGRP Primitive                            | 4-10 |
|           | Combining Multiple Groups into One               | 4-11 |
|           | Creating Groups by Exclusion                     | 4-11 |
|           | Creating Groups by Pattern Matching              | 4-12 |
|           | Using Wildcards to Specify Signal Names          | 4-12 |
|           | Multiple Specifications Applied to the Same Path | 4-13 |
|           | Ignoring Selected Paths                          | 4-14 |
|           | Breaking Combinational Loops                     | 4-14 |
|           | Specifying Relative TS Attribute Delays          | 4-14 |
|           | Specifying Time Delay Units                      | 4-15 |
|           | Example Schematic Using TNMs and TIMEGRPS        | 4-16 |
|           | Timing Control Syntax Summary                    | 4-17 |
|           |                                                  | 4-17 |
|           |                                                  | 4-17 |
|           | Timing Control using a Timing Constraints File   | 4-18 |
|           | Constraints File Surtay Constraints File         | 4-18 |
|           | TIMESPEC Constraint Statement Syntax             | 4-18 |
|           | TIMESPEC COnstraint Statement Syntax             | 4-19 |
|           | Creating a Constrainte File                      | 4-20 |
|           |                                                  | 4-21 |
| Chapter 5 | Timing Analysis                                  |      |
|           | Timing Analysis Procedure                        | 5-1  |
|           | Timing Analysis Window Features                  | 5-2  |
|           | Generating Reports                               | 5-3  |
|           | Standard Report Header                           | 5-3  |
|           | Performance to Timespecs Report                  | 5-4  |
|           | Performance Summary Report                       | 5-5  |
|           | Detailed Path Report                             | 5-7  |
|           |                                                  |      |

Chapter

|   | Check for Asynchronous Logic            | 5-9  |
|---|-----------------------------------------|------|
|   | Show Clocks                             | 5-9  |
|   | Show Settings                           | 5-9  |
|   | Report Window Commands                  | 5-10 |
|   | Report Paths Failing Timespec           | 5-12 |
|   | Report Paths with No Timespec           | 5-12 |
|   | Ignore Timespecs                        | 5-13 |
|   | Select Sources and Select Destinations  | 5-14 |
|   | Select Path Types                       | 5-17 |
|   | Include or Exclude Paths with Nets      | 5-19 |
|   | Break Logic Loops                       | 5-22 |
|   | Reset Path Filters                      | 5-24 |
|   | Selecting Additional Options (Optional) | 5-25 |
|   | Set Speed Grade                         | 5-25 |
|   | Set Delay Margins for I/O               | 5-25 |
|   | Report Options                          | 5-27 |
| 6 | Report Formats                          |      |
|   | Viewing Reports                         | 6-1  |
|   | The Resource Report                     | 6-3  |
|   | Logic Resources                         | 6-4  |
|   | Required Pin Resources                  | 6-4  |
|   | Used Pin Resources                      | 6-4  |
|   | Remaining Pin Resources                 | 6-4  |
|   | Fast Inputs and Outputs                 | 6-4  |
|   | Example Resource Report                 | 6-4  |
|   | The Mapping Report                      | 6-5  |
|   | Function Name                           | 6-5  |
|   | Macrocell Location                      | 6-6  |
|   | Pkg Pin                                 | 6-6  |

 Pin Use
 6-6

 Power Estimation (7300 Family Only)
 6-6

 The Pinout Report
 6-8

 Pkg Pin
 6-8

 Pin Type
 6-8

 Pin Use
 6-8

 Pin Name
 6-8

 Pin Use Legend
 6-8

 The Fitting Report
 6-10

 Summary
 6-10

 Part Name
 6-10

| Number of Outputs                | 6-10 |
|----------------------------------|------|
| Number of Input Lines Used       | 6-10 |
| Signal Inputs                    | 6-11 |
| Number of Shared Pt              | 6-11 |
| O/IO Used                        | 6-11 |
| O/IO Avail                       | 6-11 |
| Size Factor                      | 6-11 |
| Inputs Used by Each Partition    | 6-11 |
| Partition Listing                | 6-11 |
| Signals Used                     | 6-11 |
| Anded UIM Inputs Used            | 6-12 |
| Inputs Used by Each Output Table | 6-12 |
| MC No                            | 6-12 |
| Output Name                      | 6-12 |
| Pin Req                          | 6-12 |
| Pin Avl                          | 6-12 |
| Sh Pt                            | 6-12 |
| Input Listing                    | 6-12 |
| Example Fitting Report           | 6-13 |
| Example Timing Report            | 6-15 |
| The Timespec Report              | 6-17 |
| Example Timespec Report          | 6-17 |
| The EQN File                     | 6-18 |
| Example Equation File            | 6-19 |
|                                  |      |

## Appendix A Design Directories and Files

| File Flow                   | A-1 |
|-----------------------------|-----|
| The xproject Directory Tree | A-2 |
| Design Files                | A-3 |

## Index ..... i

### **Trademark Information**

# **Chapter 1**

# **Design Flow**

This chapter gives an introduction to the Design Manager design flow, including:

- How to prepare behavioral, schematic, and VHDL designs.
- How to translate designs into the required format.
- How to fit designs into a target device (or devices).
- Alternatives for simulation, programming, and reporting of designs that have been processed.
- A quick tutorial with a simple design example.

## **Overview of Design Processing**

There are seven basic steps in processing your design:

- 1. Design Entry to create your design source file.
- 2. Project Creation to open a new project file.
- 3. Translation of your design file into Xilinx's internal .XFF format.
- 4. Implementation of your design into a specific target device.
- 5. Export of your design for timing simulation and programming.
- 6. Report Generation showing the status of your design.
- 7. Timing Analysis for design verification.

## **Design Entry**

You can use a variety of schematic, behavioral, and VHDL tools to create your design.

The supported schematic entry tools are:

- Viewlogic.
- OrCAD.
- Mentor Graphics.

The supported behavioral entry tools are:

- Xilinx ABEL.
- PLUSASM.

The supported VHDL entry tools are:

- Viewlogic ViewSynthesis.
- Synopsys.

Prepare your design for input to the Design Manager as follows:

- For schematic designs Save your design using the native file extension (.1 for Viewlogic or .SCH for OrCAD.
- For Xilinx ABEL designs Generate an EPLD netlist for a standalone design (this saves the design as a .PLD file).
- For Viewlogic Synthesis or Synopsys designs Save your design as an .XNF file.

## **Project Creation**

This step is only done once for each project, to create the files which will contain all information about your design. Design translation, which is explained in the next section, is performed automatically when you create a new project file.

To create a new project do the following, after you have created a design source file:

- 1. Start the Design Manager.
- 2. Select the New Project command from the File menu. The New Project window appears.
- 3. Select XC7000 as the Target Family.
- 4. Select the Browse button to the right of the Input Design field. The Open browser window appears.

- 5. Change the List Files of Type value to Any File (\*.\*).
  - PLUSASM files have a .PLD extension.
  - OrCAD schematic files have a .SCH extension.
  - Viewlogic schematic files have a .1 extension.
  - All other files have an .XNF extension.
- 6. Select the drive if necessary, the directory, and the design file. (Viewlogic designs use the WIR directory.)
- 7. Select the OK button to close the browser.
- 8. Select the Translate button to close the New Project window.
- 9. The Translate Options window appears. If you did not specify the device type in the design file using the PART attribute, select the Read Part from Design box to remove the check. Click OK.
- 10. A translation window appears, which shows the translation of the design file into a standard Xilinx .XFF format, ready for processing. When these translations are complete, a message box appears telling you that the translation completed successfully. Click OK.

## **Design Translation**

You must first translate your source design into the standard Xilinx data format (.XFF) before the software can process your design. For new projects, design translation is performed automatically when the project is first created. For existing projects, you must do design translation each time you make a change to your design source file. Figure 1-1 shows the basic flow.



#### Figure 1-1 Design Manager Design Flow

To translate your design (after making changes to your source file) do the following:

- 1. Start the Design Manager.
- 2. Select the Translate command from the Design menu. The Translate Options window appears.
  - If you have want the software to read the target device part type from your design file, select Read Part From Design.
  - If you want to select a specific target device type, click Select Part and you will see the Part Selector window. From here you can choose any available device.

## **Design Implementation and Device Programming**

Design implementation is the process of fitting your design into a target device. To implement your design:

- 1. Select the Implement command from the Design menu. The XC7300 Design Implementation Dialog box appears with the following options:
  - Produce Timing Report If this box is checked, a timing report showing the calculated worst-case timing for your design is created.

- Produce Timing Simulation Data If this box is checked, the Flow Engine produces a timing simulation file in the appropriate format and copies this file into your design directory.
- Produce Configuration Data If this box is checked, the Flow Engine produces an Intel HEX file that you can use to program your device. For programming instructions, refer to the *HW130 Programmer User Guide*.
- 2. Select the Run button to start the Flow Engine. The Flow Engine window appears, displaying the stages in the design processing.

See Chapter 2 for more information about the Design Manager and the Flow Engine. For information about simulation, see the Interface User Guide for your system.

## **Report Generation**

The Flow Engine produces several reports, which are described in more detail in the "Reports" chapter.

- Translation Report Shows the results of the translation process.
- Resource Report Lists the device resources used by the design and the resources remaining.
- Pinout Report Shows how the external nets in your design were mapped to the device pins.
- Mapping Report Tells you how the logic in the design was mapped to the device.
- Fitting Report Shows the allocation of Function Block resources.
- Optimization Report Shows you how logic was optimized for your design.
- Timing Report Shows the calculated worst-case timing for the logic paths in your design.
- Timespec Report Tells you if you have made any errors in assigning T-Spec attributes in your design and lists the T-Specs that the fitter used.
- Multi-chip I/O Report Shows the pinouts of each device

resulting from multiple chip partitioning. This report is available only for multi-chip designs.

## **Timing Analysis**

You can analyze the timing of your implemented design using the Timing Analyzer. To open the Timing Analyzer, double click on its icon; the current design in the Design Manager is automatically loaded.

You can choose from the following timing reports, which are listed on the Analyze menu:

- Performance to TimeSpecs Compares the implementation of the design with the imposed timing constraints. (For more information about timing constraints, see the "Controlling Design Timing" chapter.)
- Performance Summary Summarizes the overall design performance.
- Detailed Path Report Lists worst-case path delay information for all paths in the design that have not been excluded by filters.
- Check for Asynchronous Logic Lists signals that are possibly asynchronous and the product-term clock signals that control them.
- Show Clocks Lists the clock signals in the design.
- Show Settings Lists the current settings of the timing analyzer, including which path filters have been applied.

You can apply filters to include in the reports only the paths you are interested in. You can also change other options that affect timing, such as the speed grade of the device. For more information, see Chapter 5.

## **Quick Tutorial**

This section shows you how a 4-bit Johnson counter design is processed through the Design Manager. The schematic version of this design is shown in Figure 1-2.



Figure 1-2 Example 4-Bit Johnson Counter Design (jcount)

## **Enter the Design**

Create the design in your design entry tool and save it to a file named "jcount." Be sure to include the target device part type in your source file. The design entry software will add the appropriate file extension to the design file.

## **Create a New Project**

1. Start the Design Manager. The initial Design Manager window, before you have opened a design, looks as shown in Figure 1-3.

| 🗖 Design Manager 🔽 🚽      | • |
|---------------------------|---|
| <u>F</u> ile <u>H</u> elp |   |
|                           |   |
|                           |   |
|                           |   |
|                           |   |
|                           |   |
|                           |   |
|                           |   |
|                           |   |
|                           |   |
|                           |   |
|                           |   |
|                           |   |
|                           |   |
|                           |   |

Figure 1-3 The Design Manager Window with No Design

2. Select the New Project command from the File menu. The New Project window appears as shown in Figure 1-4.

|                   | New Project                              |
|-------------------|------------------------------------------|
| Project Name:     |                                          |
| Input Design:     | Browse                                   |
| Work Directory:   | Browse                                   |
| Target Family:    | XC7000 🛓 🗵                               |
|                   | 🔘 Single Chip Design 🖲 Multi-Chip Design |
| <u>T</u> ranslate | Cancel <u>H</u> elp                      |

#### Figure 1-4 New Project Window

3. Select XC7000 as the Target Family.

4. Select the Browse button to the right of the Input Design field. The Open browser window appears as in Figure 1-5.

|                                                                          | Open                                                                                             |                         |
|--------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|-------------------------|
| File <u>N</u> ame:<br>jcount.xnf<br>icount.xnf<br>scan.xnf<br>xemake.xnf | Directories:<br>c:\newdsgn<br>C:\<br>Prewdsgn<br>C plddsgn<br>Syndsgn<br>C syndsgn<br>C xproject | OK<br>Cancel<br>Network |
| List Files of <u>T</u> ype:                                              | Dri <u>v</u> es:                                                                                 |                         |
| Netlist File (*.xnf *.1) 👤                                               | 🖃 c: ms-dos_5 🛓                                                                                  | ]                       |

#### Figure 1-5 New Project Browser

- 5. For an OrCAD design or a behavioral design, change the List Files of Type value to Any File (\*.\*). OrCAD schematic files have a .sch extension and PLUSASM files have a .PLD extension. Other design files have extensions of .1 (for Viewlogic) or .XNF (generic).
- 6. Select the drive if necessary, the directory (the WIR directory for a Viewlogic design), and the design file.
- 7. Select the OK button to close the browser. Select the Translate button to close the New Project window.

8. The Translate Options window appears as in Figure 1-6:

| 😑 Translate Options           |              |
|-------------------------------|--------------|
| Design Version: V1.1          | OK           |
|                               | Cancel       |
| 🔲 Read Part From Design       | <u>H</u> elp |
| Part: 73108-7PC84 Select Part |              |

#### Figure 1-6 Translate Options Window

- If you specified a target device in your source file (and you want to use that device) select Read Part From Design.
- If you did not specify the device type in your design source file, remove the "X" from the Read Part From Design box. Then, specify the target device type by clicking on Select Part. You will see the Part Selector window as shown in Figure 1-7.

| Part Selector    |                                |        |  |  |  |
|------------------|--------------------------------|--------|--|--|--|
|                  |                                | OK     |  |  |  |
| Filters          | Filtered List (76 devices)     |        |  |  |  |
| Family: XC7300 보 | 73108BG225-20 +                | Lancel |  |  |  |
| Device: All 🛓    | 73108BG225-15<br>73108BG225-12 | Help   |  |  |  |
| Package: All +   | 73108BG225-10                  |        |  |  |  |
|                  | 73108BG225-7                   |        |  |  |  |
| Speed: All 🛓     | 73108PC84-20                   |        |  |  |  |
| Final Selection  | Final Selection 73*            |        |  |  |  |

Figure 1-7 Part Selector

Select XC7336PC44-5 and click OK.

9. A translation window appears, which translates the design file into an .XNF and an .XFF file. When these translations are complete, a message box appears telling you that the translation completed successfully. Select the OK button.

After your design has been loaded, the Design Manager window looks as shown in Figure 1-8.



Figure 1-8 The Design Manager Window with a Design Loaded

## Implement the Design

To implement the design, follow these steps:

1. Select the Implement command from the Design menu. The XC7300 Design Implementation Dialog box appears as shown in Figure 1-9.

| 1                      | XC7300 Design     | Implementation Dialog | ]            |
|------------------------|-------------------|-----------------------|--------------|
| Control Files          |                   |                       |              |
| Guide Design:          | None              | <u>+</u>              |              |
| Constraints File:      |                   |                       | Browse       |
| Program Option T       | emplates          |                       |              |
| Implementation:        | User1             |                       |              |
|                        |                   |                       | _            |
| Optional Targets       |                   |                       |              |
| 🗖 Produce Timing       | g Simulation Data | 🗵 Produce Timing Re   | port         |
| Produce Confi <u>c</u> | juration Data     |                       |              |
| Run                    | Cancel            |                       | <u>H</u> elp |

#### Figure 1-9 XC7300 Design Implementation Dialog Box

- 2. Select Produce Timing Report, Produce Timing Simulation Data, and Produce Configuration Data options.
- 3. Click Run to implement the design. The Flow Engine window appears as in Figure 1-10, displaying the stages in the design processing. As reports are generated, you see their icons appear in the Report Browser window.

|                          | Report B                | rowser - JCOUI         | NT(V1.1->REV  | 2                     | -          |
|--------------------------|-------------------------|------------------------|---------------|-----------------------|------------|
| Timespec F<br>Report     | Fitting Report R        | esource Pino<br>Report | ut Report 🛛 🔊 | Aapping Tim<br>Report | ing Report |
|                          | Flow E                  | ingine - SCAN(         | V1.1->REV1)   |                       |            |
|                          |                         |                        |               |                       |            |
| XC7300 Design            | Flow (Rev1)             |                        | Stat          | us: OK                |            |
| :⊡>><br>>><br>           |                         | •                      |               |                       | ĵ          |
| Optimize                 | Fit                     | т                      | iming         | Bitstrear             | n          |
| Completed                | Comple                  | eted (                 | Completed     | Compl                 | eted       |
| Design Nar<br>Product: 2 | me: scan<br>XC7354-10PC | 44                     |               |                       | +          |
|                          |                         |                        | SU            | op                    | Close      |
| Part: 7354PC44           | -10 Constrain           | ts: None               | Guide: 1      | Vone                  |            |

#### Figure 1-10 Flow Engine Window (Non-Interactive)

4. When processing is complete, you can view the fitter reports (including the timing report) as described in the next section, perform timing simulation, and program the device. Timing simulation is described in the Interface User Guide for your system. Device programming is described in the *HW130 Programmer User Guide*.

## **Use the Report Browser**

The Report Browser opens automatically when you select the Implement command. (To manually open the report browser, select the Report Browser command from the Utilities menu.) The Report Browser window appears as shown in Figure 1-11.



#### Figure 1-11 Report Browser

Double click on the Resource Report icon. The report appears in its own window, as shown in Figure 1-12.

| Text Editor - JCOUNT(V1.0->REV1) - Resource Report                                                                                                                                                                                                                                                                                     |   |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--|--|--|
| <u>F</u> ile <u>E</u> dit <u>S</u> earch <u>H</u> elp                                                                                                                                                                                                                                                                                  |   |  |  |  |
| XEPLD, Version PRE6.0.0C Xilinx Inc.                                                                                                                                                                                                                                                                                                   | + |  |  |  |
| Circuit name: jcount<br>Target Device: XC7336-5PC44<br>Integrated: 5- 4-95, 3:04PM                                                                                                                                                                                                                                                     |   |  |  |  |
| LOGIC RESOURCES                                                                                                                                                                                                                                                                                                                        |   |  |  |  |
| Required Used Remaining<br>Function Blocks 1 1 3<br>Macrocells 4 4 32                                                                                                                                                                                                                                                                  |   |  |  |  |
| PIN RESOURCES:                                                                                                                                                                                                                                                                                                                         |   |  |  |  |
| Type ReqUsedRemaining<br>I O I/O Fclk Foe Cen Tot I O I/O Fclk Foe Cen Tot                                                                                                                                                                                                                                                             |   |  |  |  |
| Inputs         2         0         2         0         29         29           Outputs         4         0         2         1         1         0         4         0         29         0         1         0         30           LOP         0         0         29         0         1         0         30         29         29 | + |  |  |  |



You can save the report to an ASCII file using the File-Save As command, print the report using File-Print, or close the report window using File-Exit. Select these commands from the report window, not the main Design Manager window.

## Use the Timing Analyzer

Double click on the Timing Analyzer icon in the Tools subwindow, as shown in Figure 1-13.



#### Figure 1-13 Timing Analyzer Icon

The Timing Analyzer main window opens as shown in Figure 1-14, and the jcount design is loaded automatically.

|              | = EPLD Timing Analyzer - jcount.vm6 🗾 🗖 |                      |                 |                |              |  |   |
|--------------|-----------------------------------------|----------------------|-----------------|----------------|--------------|--|---|
| <u>F</u> ile | <u>A</u> nalyze                         | <u>P</u> ath Filters | <u>O</u> ptions | <u>W</u> indow | <u>H</u> elp |  |   |
|              | 🗿 🥇 MHz                                 |                      |                 |                |              |  |   |
|              |                                         |                      |                 |                |              |  | + |
|              |                                         |                      |                 |                |              |  |   |
|              |                                         |                      |                 |                |              |  | + |
| +            |                                         |                      |                 |                |              |  | + |
|              |                                         |                      |                 |                |              |  |   |

#### Figure 1-14 Timing Analyzer Main Window

Select the Performance Summary command from the Analyze menu. A report window appears containing the following report:

Performance Summary Report \_\_\_\_\_ Design: jcount Device: XC7336-5PC44 Program: EPLD\_TA VER 1.0 SpeedsFile: model.tim Version 1 Release 1 Mon Apr 17 13:54:42 1995 Date: Timing Analysis Options: From: All To: All Speed Grade: -5 Selected Path Types: External Pad to Pad -Pad to pad combinatorial propagation delay. Paths through PRE/CLR register inputs are not reported. Clock Pad to Output Pad -Clock pad(global or product term clock) to output pad propagation delay. Setup to Clock at Pad -Setup time of data at PAD to clock at PAD. This parameter is only reported for global clocks and product term clocks driven directly from input pads Internal \_\_\_\_\_ Clock to Setup -Register to register cycle time. Pad to Setup -Data path delay from PAD to register data input. Includes register tSU. Clock to Pad -Delay from register clock input to output pad. Path Ending at Clock Pin of FFs -Clock path delay from clock pad(global or product term) to register clock input. Other Options: Maximum Number of Paths: 1000 Maximum Number of Paths per TimeSpec: 1000 Report Delays Less Than: 1000.0ns Performance Summary: Clock net 'C' path delays: Worst case clock pad to output pad delay : 4.5ns (1 macrocell levels) (Includes an external input margin of 0.0ns.) (Includes an external output margin of 0.0ns.) Clock Pad 'C' to Output Pad 'Q0' (Fast Clock) Clock to Setup path delay : 5.0ns (1 macrocell levels)





To close the report window, select the File-Exit command in the report window. To close the Timing Analyzer, select the File-Exit command in the main Timing Analyzer window.

# **Chapter 2**

# **Using The Design Manager**

This chapter shows you how to manage your design files and how to control your design process flow. Each menu command is described and procedures for common tasks are provided. A typical Design Manager Window is illustrated below.



Figure 2-1 The Design Manager Window

## **Design Manager Fundamentals**

There are four main functions of design management that are addressed by the Design Manager:

- Grouping all related Design Files (project). The Design Manager window displays all files related to a single project. The hierarchical file structure shows you the relationships of the files to each other.
- Maintaining Design Versions (logic). Each time you change the logic of your design a new version is created. This allows you to try modified versions of your design and easily keep track of them. Old versions can be deleted as desired.
- Selecting Device Implementations (target devices). Each version of your design can have multiple implementations (target devices) in which fitting can be attempted.
- Maintaining Implementation Revisions (fitting strategies). You can have multiple fitting strategies (revisions) for each device implementation. This allows you to optimize your design for speed and density while retaining your data.

The Design Manager Window, showing your design versions, implementations, and revisions appears when you have chosen an existing project in which to work or have opened a new project. In addition, within the Design Manager User Interface, there are three tools:

- The Flow Engine, used to control the fitting of your design.
- The Partitioner, used to manage multiple device partitioning.
- The Timing Analyzer, used to verify your design timing.

## **Managing Projects**

A project includes all design versions, device implementations, and implementation revisions that are created as you develop your design. The Design Manager Window shown in Figure 2-1 displays the data associated with a single project. You can work with multiple projects (designs) but only one at a time is displayed.

## **Managing Design Versions**

You create your design using third party front-end tools such as schematic editors, behavioral equation editors, and VHDL. These tools output either an .XNF or .PLD file that describes the logic of your design. You create a new .XNF or PLD file each time you change your source design and import that new design to the Design Manager.

Each new .XNF file you import becomes a new design version and is assigned a version number by the Design Manager. You can choose any one of the available versions for processing and for each version you may choose multiple target device implementations and different fitting strategies. The Design Manager also allows you to delete versions that are no longer useful.

## **Managing Device Implementations**

You can fit your design into any number of different target devices; each is called an implementation. You can specify devices explicitly or you can specify a range of devices from which the software can choose the best one. For example, you could specify a device family and package type only, allowing the software to choose the best device type and speed grade for your design. For a description of the automatic device selection process, see Chapter 3.

For each version of your design you can have multiple implementations using different target devices or different fitting strategies.

## **Managing Implementation Revisions**

After you have created a design version by inputting an .XNF file, and you have chosen a target device (or devices), you can try different fitting strategies on that design. This allows you to vary how your design is implemented in order to achieve your design objectives. For example, you can maximize speed and density for specific functions in your design by controlling the fitting process. Each of these fitting strategies is called a design revision.

Each design revision contains the output files and reports that are created based on a specific set of fitting strategies. the Design Manager also allows you to delete revisions that are no longer useful.

## **Design Management Procedure**

The typical procedure for managing a design is as follows:

- 1. Create your design using a third-party front-end tool such as those available from Viewlogic, OrCAD, Data I/O, and Mentor Graphics. Your design is output as an .XNF, .1, .SCH, or .PLD file, depending on the tool you are using.
- 2. Open an existing project file; or create a new project file in which to import your logic design.
- 3. Import your logic design. Your source file is converted into the Xilinx internal data base format (.XFF).
- 4. Choose a target device (or devices) in which to implement your design. Or, allow the software to automatically choose target devices based on your selection criteria.
- 5. Define option templates to control your design process flow. Or, use the default template settings.
- 6. Process (fit) your design and:
  - Create timing simulation files (optional).
  - Create a device programming file (optional)
- 7. Review your design reports to verify that your design fits within the target device and that your timing requirements are met.
- 8. If your design requirements are not met you can do the following and process your design again:
  - Change your logic design.
  - Choose a different target device, package, or speed grade.
  - Define a different set of fitting options (option templates).

## Using the Design Manager

This section describes the Design Manager menu commands and provides the procedures for using them.

## The Initial Design Manager Window

When you first run the Design Manager you will see the initial Design Manager window as shown in Figure 2-2.

|                   | Desi  | gn Manage | r 🔽 🗖                                                                                                                                                |
|-------------------|-------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>File H</u> elp | 02 20 | • •       | Menu Bar<br>Tool Bar                                                                                                                                 |
|                   |       |           | Help<br>View Command History<br>Edit Project Notes<br>Browse Reports<br>Copy Revision<br>New Revision<br>Save Project<br>Open Project<br>New Project |
|                   |       |           |                                                                                                                                                      |

#### Figure 2-2 The Initial Design Manager Window

The Menu bar contains the primary menu commands arranged according to the types of functions you need to perform. When you click a Menu Bar selection, you see a submenu with more commands. In the initial Design Manager Window (Figure 2-2) you see only the File and Help commands because these are all you need until you have opened a project. After a project is opened, you will see the full Menu Bar with all available menu commands as shown in Figure 2-1.

The Tool Bar contains icons that represent commonly used functions such as Help, for quick access. Each of these functions is also accessible through the Menu Bar sub commands.

Each menu command is described in the following sections.

## **File Menu**

Use the File menu to manage projects and to exit the Design Manager. When you select File, you see the menu shown in Figure 2-3.



Figure 2-3 The File Menu

#### File — New Project

Select New Project to create an empty project directory to receive a new design; you will see the New Project dialog window as shown in Figure 2-4.

|                 | New Project                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Project Name:   | xproject                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Input Design:   | Browse                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Work Directory: | Browse                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Target Family:  | XC7000   XC700   XC700   XC7000   XC7000   XC7000   XC7000   XC7000   XC700 |
|                 | 🔿 Single Chip Design 🖲 Multi-Chip Design                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <u> </u>        | Cancel <u>H</u> elp                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

#### Figure 2-4 The New Project Dialog Window

To open a new project, follow these steps:

1. Enter a project name in the Input Design dialog box. Or, click on Browse and you will see the Open dialog window as shown in Figure 2-5. From here you can select a design file to input.

| 0                                                                                        | Open                                                                                   |                         |
|------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|-------------------------|
| File <u>N</u> ame:<br>*.xnf *.1<br>comp.xnf<br>jcount.xnf<br>scan.xnf<br>xemake.xnf<br>* | Directories:<br>c:\newdsgn<br>C:\<br>mewdsgn<br>Comp<br>plddsgn<br>Syndsgn<br>xproject | OK<br>Cancel<br>Network |
| List Files of <u>T</u> ype:                                                              | Dri <u>v</u> es:                                                                       |                         |
| Netlist File (*.xnf *.1) 🛓                                                               | 🖃 c: ms-dos_5 🔄                                                                        |                         |

Figure 2-5 The Open Dialog Window
Note that the List of File Types in the Open Dialog Window is already set to find all .XNF files for you; .XNF is the most common input file type. You can change this to .PLD or any other file type for which you want to search.

- 2. Select the target device family from the Target Family pull-down dialog box. Select XC7000 to target Xilinx EPLDs. The other selections are for Xilinx FPGA devices.
- 3. Specify if your design is targeted to one device (Single Chip Design) or to multiple devices (Multi-Chip design).

**Note:** Use Single Chip Design only; multi-chip partitioning is not available in this beta release.

4. Specify your working directory. You can browse through the available directories by clicking on Browse, which brings up the dialog window as shown in Figure 2-6. From here, select the working directory and click OK.

| Design Manager                                                                         |                         |  |
|----------------------------------------------------------------------------------------|-------------------------|--|
| Directories:<br>c:\newdsgn<br>c:\<br>newdsgn<br>comp<br>plddsgn<br>syndsgn<br>xproject | OK<br>Cancel<br>Network |  |
| Dri <u>v</u> es:<br>c: ms-dos_5                                                        |                         |  |

Figure 2-6 The Work Directory Browse Dialog Window

5. After you have specified the project name, device family, and working directory, you can input (translate) your logic design by clicking on the Translate button. You will see the Translate Options dialog window as shown in Figure 2-7.

6. From the Translate Options dialog window you can choose a design version number or accept the default version number. You can also specify whether the software is to read the device information contained in your source file or use the part you have selected. To select a Part click Select Part and you see the Part Selector window from which you can specify a target device as shown in Figure 2-8. Click OK when done.

| Translate Options             |              |
|-------------------------------|--------------|
| Design Version: V1.1          | ОК           |
|                               | Cancel       |
| 🗖 Read Part From Design       | <u>H</u> elp |
| Part: 73108-7PC84 Select Part |              |

Figure 2-7 Import Design Translation Flow Window

| Part Selector    |                            |        |  |
|------------------|----------------------------|--------|--|
|                  |                            | OK     |  |
| Filters          | Filtered List (76 devices) |        |  |
| Family: XC7300 🛨 | 73108BG225-20 +            | Lancel |  |
|                  | 73108BG225-15              | Help   |  |
| Device: All 🛨    | 73108BG225-12              |        |  |
| Package: All 🛨   | 73108BG225-10              |        |  |
|                  | 73108BG225-7               |        |  |
| Speed: All 🛨     | 73108PC84-20               |        |  |
|                  |                            |        |  |
| Final Selection  | 73*                        |        |  |
|                  |                            |        |  |

Figure 2-8 Part Selector

After you have selected the Translate Options, click OK and your design file is input and converted to the Xilinx .XFF internal database format, ready for processing.

When the translation is complete, you see the Translate Confirmation Dialog Window as shown in Figure 2-9.



#### Figure 2-9 Translate Confirmation Dialog Window

7. From here, if you select Review log, you will see the Translation log report as shown in Figure 2-10.

| Text Editor - c:\newdsgn\xproject\ver1\xmake.log                                                                                 | - |
|----------------------------------------------------------------------------------------------------------------------------------|---|
| <u>F</u> ile <u>E</u> dit <u>S</u> earch <u>H</u> elp                                                                            |   |
| RUNNING XEMAKE                                                                                                                   | + |
| XNFMERGE Ver. beta-5.2.0b                                                                                                        |   |
| (C) Copyright 1987-1995 Allinx Inc. All rights reserved<br>2961D06-Eutondon 4.1 - Copyright (C) 1996-1992 Phan Lap Software Inc. |   |
| Soopbos-Extender 4.1 - Copyright (C) 1988-1993 Fhar Lap Sontware, The.                                                           |   |
|                                                                                                                                  |   |
| List of files read                                                                                                               |   |
| Read file scan.xnf                                                                                                               |   |
| Read file c:\xact\data\xnf7000\bufe.xnf                                                                                          |   |
| Netlist written to file xemake.xnf                                                                                               |   |
| XNFMERGE Ver. beta-5.2.0b                                                                                                        |   |
| (c) Copyright 1987-1995 Xilinx Inc. All rights reserved                                                                          |   |
| 386 DOS-Extender 4.1 - Copyright (C) 1986-1993 Phar Lap Software, Inc.                                                           |   |
|                                                                                                                                  | + |

#### Figure 2-10 Translation Log Report

This log report shows you the commands that were executed in the translation of your design as well as any warnings or error messages.

### File — Open Project

Select Open Project to open an existing project. You will see the following dialog box, which displays all available projects:

| 😑 Open Project                         |     |
|----------------------------------------|-----|
| Xilinx Projects                        |     |
| c:\newdsgn\scan7\scan.prj              |     |
| c:\newdsgn\lock7k\a\lock7k.prj         | 1.1 |
| c:\newdsgn\xproj5\scan.prj             | 1.1 |
| c:\newdsgn\scan5\scan.prj              | 11  |
| c:\newdsgn\proj1\jcount.prj            | 11  |
| c:\newdsgn\misc1\misc.prj              | 11  |
| c:\eugene\misc\misc.prj                | 11  |
| c:\newdsgn\xproj2\jcount.prj           |     |
| c:\newdsgn\xproject\carlis\scan.prj    |     |
| c:\newdsgn\scan1\scan.prj              | 11  |
| c:\newdsgn\comp5\comp.prj              | 1.1 |
| c:\xact\data\xnf7000\xproject\acc1.prj | H   |
| •                                      |     |
|                                        | _   |
| Open Cancel Browse <u>H</u> elp        |     |

Figure 2-11 The Open Project Dialog Window

If you double-click a project, or highlight a project and click Open, the project file opens and you will be returned to the Design Manager window with the project hierarchy displayed.

### File — Save Project

Select Save Project to save all files associated with your current project.

### File — Close Project

Use Close Project to close and save all files associated with the current project.

### File — Delete Project

Select Delete Project to remove a project from your list of active projects and you will see the dialog window shown in Figure 2-12.

| 💳 Xilinx Projects                                              |   |  |
|----------------------------------------------------------------|---|--|
| Projects                                                       |   |  |
| c:\newdsgn\xproject\scan.prj<br>c:\newdsgn\plddsgn\asc\asc.prj | + |  |
| c:\newdsgn\comp\comp.prj<br>c:\newdsgn\blddsgn\m2\m2 pri       |   |  |
| c:\newdsgn\xproject\jcount.prj                                 |   |  |
| c:\newdsgn\plddsgn\xproject\arb3.prj                           |   |  |
| c:\jg\examples.prj                                             |   |  |
|                                                                |   |  |
| *                                                              | + |  |
| Delete Cancel Help                                             |   |  |

#### Figure 2-12 The Xilinx Projects Dialog Window

Double-click on the project you want to delete, or highlight the project and click the Delete button.

If you do not wish to delete a project at this time, click Cancel and you are returned to the Design Manager window.

### File — File name

The File menu automatically lists all available project names. You can open any listed project by simply clicking the name.

### File — Exit

Select Exit to close your design and exit the Design Manager. Your project is saved automatically

# **Design Menu**

Select Design from the menu bar and you see the menu as shown in Figure 2-13.

#### Figure 2-13 The Design Menu

### Design — Translate

Select Translate to input your logic design and convert it to the Xilinx internal database format (.XFF) ready for processing. You will see the Translate Options dialog window as shown in Figure 2-14.

| 💳 Translate Options   |        |
|-----------------------|--------|
| Design Version: V1.2  |        |
| Read Part From Design | Lancel |
|                       |        |

Figure 2-14 Import Design Translation Flow Window

From the Translate Options dialog window you can choose a design version number or accept the default version number. You can also specify if the software is to read the device information contained in your source file.

After you have selected the Translate Options, click OK and your design file is input and converted to a Xilinx .XFF internal database format.

The supported input formats are:

- .XNF Xilinx Netlist Format, supported by most tools.
- .SCH OrCad schematic output format.
- .1 ViewLogic schematic output format.
- .PLD PAL and PLD files.

When the translation is complete you see the Translate Confirmation Dialog Window as shown in Figure 2-15.

|                                               | Design Manager |  |  |
|-----------------------------------------------|----------------|--|--|
| The Translate process completed successfully. |                |  |  |
|                                               | OK Review Log  |  |  |

Figure 2-15 Translate Confirmation Dialog Window

From here, if you select Review log, you will see the Translation log report as shown previously in Figure 2-10. Select OK and you are returned to the previous menu.

### **Design** — Implement

Select Implement and you see the XC7300 Design Implementation Dialog Window as shown in Figure 2-16. Use this dialog window to control the fitting process by specifying control files, program option templates, and optional target files for your design.

To implement your design follow these guidelines:

• Guide Design: If you want to use the pinouts from a previous implementation, click on the Guide Design scroll arrow to see a list of all available Guide Files (.GYD). A guide file is created each time you fit your design and you can reuse this pinout information to maintain design consistency. For more information on using Guide Files see Chapter 3.

| 1                 | XC7300 Design     | Implementation Dialog   |              |
|-------------------|-------------------|-------------------------|--------------|
| Control Files     |                   |                         |              |
| Guide Design:     | None              | Ŧ                       |              |
| Constraints File: |                   |                         | Browse       |
| Program Option T  | emplates          |                         |              |
| Implementation:   | User1             | <b>⊥</b> Edit Template  |              |
|                   |                   |                         |              |
| Optional Targets  |                   |                         |              |
| 🗖 Produce Timing  | g Simulation Data | 🗵 Produce Timing Report |              |
| Produce Config    | guration Data     |                         |              |
| Bun               | Cancel            |                         | <u>H</u> elp |

#### Figure 2-16 The XC7300 Design Implementation Dialog Window

- Constraints File: If you want to use timing-driven optimization, enter a constraints file name or click on the Browse button to see a list of all available timing constraints files. For information on how to create a constraints file, see Chapter 4.
- Implementation: If you want to use a Program Option Template, (a set of fitter options that control your design processing), click on the Implementation scroll arrow to see a list of all available Program Option Templates. Click Edit Template if you want to change the template parameters. See the "Template Manager" section (Figure 2-33) for more information on how to create and edit Option Templates.

- Produce Timing Report: If you want to produce a timing summary report click this check box; an X appears to indicate that the option is selected. For a more detailed timing analysis, you can use the static timing analyzer after the design is implemented. See Chapter 6 for more information on Timing Reports.
- Produce Timing Simulation Data: If you want to produce timing simulation data, click this check box. Check this option if you intend to use a third party timing simulator to verify your design.
- Produce Configuration Data: If you want to output configuration data (a device programming file), click this check box. You will also need to enter a unique text string in the Signature dialog box to identify this file.
- Run: When all options are entered, click the Run button to implement your design. You will see the simplified Flow engine Dialog window along with the Report browser, as shown in Figure 2-17. As the simplified Flow Engine processes your design, you will see the reports highlighted as they are created.

| 🖛 Report Browser - SCAN(V1.1->REV1) |                            |                         |                          |        |
|-------------------------------------|----------------------------|-------------------------|--------------------------|--------|
| Timespec Fitt<br>Report             | ting Report Resour<br>Repo | rce Pinout Report<br>rt | Mapping Timing<br>Report | Report |
|                                     | Flow Engin                 | e - SCAN(V1.1->RE       | V1)                      | ▼ ▲    |
|                                     |                            |                         |                          |        |
| XC7300 Design Fl                    | low (Rev1)                 |                         | Status: OK               |        |
|                                     |                            |                         |                          |        |
| Optimize                            | Fit                        | Timing                  | Bitstream                |        |
| Completed                           | Completed                  | Complete                | d Complet                | ed     |
| Design Name<br>Product: XC          | ≥: scan<br>27354-10PC44    |                         |                          | +      |
|                                     |                            |                         | Stop                     | lose   |
| Part: 7354PC44-1                    | 0 Constraints: No          | one Guid                | de: None                 |        |

#### Figure 2-17 The Simplified Flow Engine with Report Browser

**Note:** When you implement your design from the Design menu, you see the simplified Flow Engine shown above. The simplified Flow Engine has a limited set of options. If you want the full set of options, to control the operation of the Flow Engine, select the Flow Engine from the tools menu or from its icon in the Design Manager Toolbox.

### Design — Export

Select Export to control the types of output data produced by the software.

| Design Export Dialog                   |                 |  |
|----------------------------------------|-----------------|--|
| Export Options<br>Physical Design Data | Files To Export |  |
| Configuration Data                     | •               |  |
| Export To:<br>c:\newdsgn               | Browse          |  |
| ОК                                     | Cancel Help     |  |

#### Figure 2-18 The Export Data Dialog Window

- Physical Design Data: Select this option to export a guide file (.GYD) containing your pinout information. This file is used to recreate you existing pinout after making design changes.
- Timing Simulation Data: Select this option to export a simulation file (.XNF) for third-party simulators such as those available from Viewlogic (ViewSim) and OrCAD.
- Configuration Data: Select this option to export a device programming file (.PRG).
- Files To Export: Here you see all files that match the data type you have selected for export.
- Export To: Enter the full path of the file to which you are exporting the data. Select Browse to see a list of all available files as shown in Figure 2-19.

Click OK when you are ready to export the data.

| 🛥 🛛 Design Mar                     | Design Manager |  |  |  |
|------------------------------------|----------------|--|--|--|
| <u>D</u> irectories:<br>c:\newdsan | OK             |  |  |  |
| [⊖ c:\                             | Cancel         |  |  |  |
| 🗁 newdsgn<br>📋 comp                | Network        |  |  |  |
| 🗀 plddsgn<br>🛅 syndsgn             |                |  |  |  |
| 🗋 xproject 🕢                       |                |  |  |  |
| Dri <u>v</u> es:                   |                |  |  |  |
| ≡ c: ms-dos_5 ±                    |                |  |  |  |



### **Design** — New Device

Select New Device to add a new target device under the selected version hierarchy. This allows you to try different devices (and fitting strategies) for a specific version of your design. You can either specify a single device or a range of possible devices from which the software can choose the best one. The device selection procedure is described as follows:

- 1. Select the version under which the new target device is to be added.
- 2. Select New Device from the Design menu. You will see the Part Selector dialog window as shown in Figure 2-20.

|                  | Part Selector              |        |
|------------------|----------------------------|--------|
| - Fib            |                            | OK     |
|                  | Filtered List [76 devices] | Canaal |
| Family: XC7300 🛨 | 73108BG225-20 🔹            | Lancer |
|                  | 73108BG225-15              | Help   |
| Device: All      | 73108BG225-12              |        |
| Package: All 🛃   | 73108BG225-10              |        |
| r donago. rm 🔁   | 73108BG225-7               |        |
| Speed: All 🛃     | 73108PC84-20               |        |
|                  | <b>!</b>                   |        |
| Final Selection  | 1 73*                      |        |
|                  |                            |        |

Figure 2-20 Part Selector Window

- 3. If you know the specific device you want to use, select the part type, package type, and speed grade by scrolling through the available options as shown in Figure 2-20. For EPLD designs select the XC7000 family.
- 4. If you want to allow the software to choose the best device for your design, specify only those parameters that you require. For example, you can specify the PC84 package and leave the device type and speed grade unspecified. The unspecified parameters are shown as an asterisk (\*) in the Final Selection window and on the Design Manager window.

Click OK and the specified device (or set of devices) is added to the design hierarchy as shown in Figure 2-1.

### **Design** — New Revision

Select New Revision to create a new (translated) revision of your design in .XFF format. This does not save any of your previous implementation data.

# Design — Copy Revision

Select a revision in the Design Manager window and Select Copy Revision to make a copy of that revision. You will see the new revision (a copy) displayed in the Design Manager window using the next Rev number. For example, if Rev 1, Rev 2, and Rev3 already exist and you make a copy (of any one), Rev 4 will be created. Usually you copy a revision in order to modify the fitting strategy it contains. A revision copy contains the previous implementation data.

### **Design** — Browse Revision

Select Browse Revision to edit, copy, move, rename, or delete the files contained within a revision; you see the Revision Browser dialog window as shown in Figure 2-21.



#### Figure 2-21 The Revision Browser Dialog Window

This dialog window shows you the following information:

- Target Part: The device to which the selected revision is targeted.
- State: The last completed process step for the selected revision, which is either: TRANSLATED, OPTIMIZED, FIT, TIMING, or PROGRAMMED.

- Status: The status of the design processing up to the current state:
  - OK The software generated no errors or warnings.
  - Warning The software encountered a situation that may require your attention.
  - Error The software encountered a processing error.
- Directory: The directory in which the selected revision resides.
- Files: This scroll box shows you all the files contained within the selected revision. If you want to display the file details (creation date, creation time, and so on), select the Display File Details check box.
- Edit: If you want to modify a file, select the file and click Edit; you will see the dialog window shown in Figure 2-22:

| File Editor on c:\newdsgn\xproject\ver1\rev1\scan.xff                     |   |
|---------------------------------------------------------------------------|---|
| LCANET, 6                                                                 | • |
| PROG, XNFMERGE, beta-5.2.0b, "Created from xemake.xnf: Tue May 9 09:19:52 |   |
| 1995: Options: q"                                                         |   |
| PART, 7354-10pc44                                                         |   |
| HIERG, 16, bufe, U223/BUFE, c:\xact\data\xnf7000\bufe.xnf, 0              |   |
| HIERG, 17, bufe, U222/BUFE, c:\xact\data\xnf7000\bufe.xnf, 0              |   |
| HIERG, 18, bufe, U221/BUFE, c:\xact\data\xnf7000\bufe.xnf, 0              |   |
| HIERG, 19, bufe, U220/BUFE, c:\xact\data\xnf7000\bufe.xnf, 0              |   |
| HIERG, 20, bufe, U219/BUFE, c:\xact\data\xnf7000\bufe.xnf, 0              |   |
| HIERG, 21, bufe, U218/BUFE, c:\xact\data\xnf7000\bufe.xnf, 0              |   |
| HIERG, 22, bufe, U217/BUFE, c:\xact\data\xnf7000\bufe.xnf, 0              |   |
| HIERG, 23, bufe, U216/BUFE, c:\xact\data\xnf7000\bufe.xnf, 0              |   |
| HIERG, 2, vcc, add_85/plus/plus/U5,                                       |   |
| /products/released/sparc/510/ds401/data/synopsys/xprim_7000/vcc.xnf, 1    |   |
| HIERG, 3, inc4, add_85/plus/plus/U4,                                      |   |
| /products/released/sparc/510/ds401/data/synopsys/xprim_7000/inc4.xnf, 1   |   |
| HIERG, 4, inc4, add_85/plus/plus/U4_3,                                    | + |

Figure 2-22 The Browse Revision Edit Dialog Window

Use this file editor to make changes to the selected file.

• Copy: If you want to copy a file, click Copy and you see the following Save As Dialog window as shown in Figure 2-23.

|                                              | Save As                                                                                        |                         |
|----------------------------------------------|------------------------------------------------------------------------------------------------|-------------------------|
| File <u>N</u> ame:                           | Directories:<br>c:\\xproject\ver1\rev1<br>c:\<br>c:\<br>c:\<br>c:\<br>c:\<br>c:\<br>c:\<br>c:\ | OK<br>Cancel<br>Network |
| Save File as <u>T</u> ype:<br>Any File (*.*) | Dri <u>v</u> es:<br>c: ms-dos_5                                                                | ]                       |

#### Figure 2-23 The Save As Dialog Window

- Move: If you want to move a file, highlight the file name in the Revision Browser window and click Move; you will see the same Save As dialog window as shown in Figure 2-23.
- Delete: If you want to delete a file, select the file name in the Revision Browser window and click Delete; you will see the delete confirmation window shown in Figure 2-24.

| 1 | 🗕 🛛 Design Manager     |  |  |  |
|---|------------------------|--|--|--|
| 0 | Delete file: scan.xff? |  |  |  |
|   | Yes <u>N</u> o         |  |  |  |

Figure 2-24 The Delete Confirmation Window

Click Yes and the file is deleted. Click No and you are returned to the previous menu.

### Design — Rename

Highlight the revision in the Design Manager window and then select Name Revision to assign a name to the selected revision; you will see the Name Revision dialog window as shown in Figure 2-25.

| Name:     |
|-----------|
| V1.0      |
| OK Cancel |

#### Figure 2-25 Name Revision Dialog Window

Enter the revision name in the dialog box and click OK to apply that name to the selected revision. The name you enter will replace the Rev number. For example, if you select "Rev 1 (Translated)" to rename and enter the name "MyRev8", you will see the name change to "MyRev8 (Translated)". Click Cancel to return to the Design Manager window.

### **Design** — Delete Revision

Highlight a revision in the Design Manager window and then select Delete Revision and you will see the dialog window as shown in Figure 2-26.



Figure 2-26 Delete Revision Dialog Window

Click Yes and the highlighted revision is deleted. Click No and you are returned to the Implementation menu.

# **Tools Menu**

Use the Tools menu to select the Flow Engine, the Timing Analyzer, or the Multi-Chip Partitioner, and you see the menu as shown in Figure 2-27.



Figure 2-27 The Tools Menu

# Tools — Flow Engine

The Flow Engine is used to control the processing of your design including optimization, fitting, timing simulation data generation, and device programming file generation. See "Using the Flow Engine" later in this chapter, for more information.

# Tools — Timing Analyzer

The Timing Analyzer is used to verify the critical path timing in your design, as shown in Figure 2-28. See Chapter 5 for more information on how to use the Timing Analyzer.

|              | 😑 EPLD Timing Analyzer 🔽 🗖 |                      |                 |                |              |  |   |
|--------------|----------------------------|----------------------|-----------------|----------------|--------------|--|---|
| <u>F</u> ile | <u>A</u> nalyze            | <u>P</u> ath Filters | <u>O</u> ptions | <u>W</u> indow | <u>H</u> elp |  |   |
|              | 🞒 is minz                  | ALL 💦                |                 |                |              |  |   |
|              |                            |                      |                 |                |              |  | + |
|              |                            |                      |                 |                |              |  |   |
|              | •                          |                      |                 |                |              |  |   |
| +            |                            |                      |                 |                |              |  | + |
|              |                            |                      |                 |                |              |  |   |

#### Figure 2-28 Timing Analyzer

### Tools — Partitioner

The partitioner is used to fit your design into multiple target devices. This is a new feature. See the release notes for the latest information.

# **Utilities Menu**

Use the Utilities Menu to access the various Design Manager utilities as shown in Figure 2-29.

| <u>R</u> eport Browser   |
|--------------------------|
| Command <u>H</u> istory  |
| <u>P</u> roject Notes    |
| <u>T</u> emplate Manager |

Figure 2-29 The Utilities Menu

### **Utilities — Report Browser**

Select Report Browser to view and edit your design reports; you will see the Report Browser window as shown in Figure 2-30.



#### Figure 2-30 The Report Browser Window

Double click on a report icon to view the report. For more information on the Report Browser, see Chapter 6.

### **Utilities — Command History**

Select Command History to view the commands that were previously executed when you implemented your design; you will see the Command History window as shown in Figure 2-31.

| _ | Command History - JCOU                 | NT(V1.0->REV1)   |          |
|---|----------------------------------------|------------------|----------|
| 0 | Command History                        | View Mode: Norma | i 🛨      |
|   | Revision Created 5 May 1995 2:51:05 am |                  | <u>+</u> |
|   |                                        |                  |          |
|   |                                        |                  |          |
|   |                                        |                  |          |

#### Figure 2-31 The Command History Window

You can view the commands in either Normal mode, which displays only the command names; or Primitive mode, which displays the command name and the associated control parameters.

### **Utilities — Project Notes**

Select Project Notes to document your project; you will see the Project Notes dialog window as shown in Figure 2-32.

| -            |              |                | Text Editor - c:\newdsgn\xproject\project.not | • |
|--------------|--------------|----------------|-----------------------------------------------|---|
| <u>F</u> ile | <u>E</u> dit | <u>S</u> earch | <u>H</u> elp                                  |   |
| PROJ         | ECT N        | OTES :         |                                               | + |
|              |              |                |                                               |   |
|              |              |                |                                               |   |
|              |              |                |                                               |   |
|              |              |                |                                               |   |
|              |              |                |                                               |   |
|              |              |                |                                               |   |
|              |              |                |                                               |   |
|              |              |                |                                               |   |
|              |              |                |                                               |   |
|              |              |                |                                               |   |
|              |              |                |                                               |   |
|              |              |                |                                               |   |
|              |              |                |                                               |   |
|              |              |                |                                               |   |
|              |              |                |                                               | + |
|              |              |                |                                               |   |

#### Figure 2-32 The Project Notes Window

You can enter any text into this basic text editor. Project notes are usually used to document the revisions, implementations, and versions of your design.

### **Utilities — Template Manager**

Select Template Manager to create, edit, and delete implementation option templates, which control the processing of your design; you will see the Template Manager dialog window as shown in Figure 2-33.

| 💳 Template Manager - XC7000 🔽 🔺 |       |           |  |  |
|---------------------------------|-------|-----------|--|--|
| Implementation Templates        | Close |           |  |  |
| Default                         | +     |           |  |  |
|                                 |       | Edit      |  |  |
|                                 |       | New       |  |  |
|                                 |       | Delete    |  |  |
|                                 |       | Import    |  |  |
|                                 |       | Export    |  |  |
|                                 |       | Customize |  |  |
|                                 | +     | Help      |  |  |

#### Figure 2-33 The Template Manager Window

#### Utilities — Template Manager — Close

Click Close to close the Template Manager and return to the Flow Engine dialog window.

#### Utilities — Template Manager — Edit

After you have highlighted one of the option templates, click Edit to open the following templates for controlling Fitting options, Optimization options, and Resource reservation options.

When you click Edit you will see the Fitting Template, as shown in Figure 2-34.

|                     | 7000 Implementatio     | n Template: Defaul | t    |  |  |  |
|---------------------|------------------------|--------------------|------|--|--|--|
| Fitting             | Optimization           | Resources          | ОК   |  |  |  |
| 🗵 Use XACT-Perform  | ▼ Use XACT-Performance |                    |      |  |  |  |
| 🛛 Ignore Pin Assign | ments                  |                    | Help |  |  |  |
| 🗖 Drive Unused I/O  |                        |                    |      |  |  |  |
| Low Power Mode:     | 🔿 On 🔿 Off 💿 In D      | esign              |      |  |  |  |
| Use MR as input: (  | 🔿 On 🔿 Off 🖲 In D      | esign              |      |  |  |  |
|                     |                        |                    |      |  |  |  |
|                     |                        |                    |      |  |  |  |

#### Figure 2-34 The Fitting Options Template

The Fitting Template allows you to control the fitting options, which are set as follows:

- Use XACT-Performance: This indicates that you want the software to use your T-Spec information and perform timing-driven optimization in the fitting of your design. For this option to be useful, you must have previously created a timing constraints file or you must have placed T-Spec information on your schematic. See Chapter 4 for information on using T-Specs.
- Ignore Pin Assignments: This indicates that you do not want to use any pinout information that may be in the design file. This allows the fitter to place pins anywhere.
- Drive Unused I/O Pads On Chip: This indicates that you want all unused I/O pads to be actively driven by on-chip circuitry. Because all unused I/O signals must be actively driven, this option alleviates the need for external drivers or pull-up resistors. See the device data sheet for more information about I/O pads. Low Power Mode: Controls device power consumption:

- On Set Low Power mode for the entire design.
- Off Set high performance (higher power mode) for the entire design.
- In Design Allow the power mode to be controlled by information in your design file.
- Use MR As Input: Controls the use of the MR Input pin on the XC7318, XC7336, and XC7354:
  - On Use the MR pin as an input pin.
  - Off Use the MR pin as a Master Reset input pin.
  - In Design Allow the pin use to be determined by information in your design file.

Click OK to accept the template, click Cancel to return to the previous menu, click Default to set the default options, or click Help to open the on-line help system.

Click Optimization and you will see the Optimization Template as shown in Figure 2-35.

| XC7000 Implementation Template: User1 |       |           |   |           |                   |
|---------------------------------------|-------|-----------|---|-----------|-------------------|
| Fitting                               | Opt   | imization | _ | Resources | ОК                |
| Timing:                               | 🖲 On  | O Off     |   |           | Cancel<br>Default |
| Input Register:                       | () On | ○ Off     | • | In Design | <u>H</u> elp      |
| Fast Output Enable:                   | O On  | O Off     | ۲ | In Design |                   |
| Fast Clock:                           | 🔿 On  | O Off     | • | In Design |                   |
| UIM:                                  | 🔿 On  | O Off     | • | In Design |                   |
| Pre Load:                             | O On  | O Off     | ۲ | In Design |                   |
|                                       |       |           |   |           |                   |
|                                       |       |           |   |           |                   |



From the Optimization Template you can control the optimization options which are set as follows:

- On The option is activated for the whole design and corresponding schematic attributes, behavioral commands, or VHDL commands are ignored.
- Off The option is turned off for the whole design and corresponding schematic attributes, behavioral commands, or VHDL commands are ignored.
- In Design The option is controlled exclusively by schematic attributes, behavioral commands, or VHDL commands. If the option is not specified in the design, it defaults to On.

#### The options are:

• Timing — Determines if the fitter will try to optimize your design to achieve the best possible timing for your critical paths. If this option is off, the fitter will try to achieve the best possible density, without regard for timing.

This timing optimization is performed independently from the timing-driven optimization of XACT Performance, which was described in a previous section.

- Input Register Determines if unused input registers can be used to implement logic.
- Fast Output Enable Determines if output enable signals can use the dedicated high speed FOE nets.
- Fast Clock Determines if clocks can use the dedicated FastClock nets.
- UIM Determines if the UIM can be used to implement basic boolean logic functions.
- Pre Load Determines if the fitter can optimize registers that have no assigned preload values. This optimization allows the software to choose preload values that simplify fitting.

Click OK to accept the template, click Cancel to return to the previous menu, click Default to set the default options, or click Help to open the on-line help system.

**Note:** See the XC7000 data sheets for more information on how these options affect your design.

Click Resources and you see the Resources Template as shown in Figure 2-36.

| XC7000 Implementation Template: User1 |           |       |           |                   |  |
|---------------------------------------|-----------|-------|-----------|-------------------|--|
| Fitting                               | Optimiz   | ation | Resources | ОК                |  |
| Reserved Input Pin                    | s:        | 0     |           | Cancel<br>Default |  |
| Reserved Output Pi                    | ns:       | 0     |           | <u>H</u> elp      |  |
| Reserved Bidirectio                   | nal Pins: | 0     |           |                   |  |
| Reserved Macrocel                     | ls:       | 0     |           |                   |  |
|                                       |           |       |           |                   |  |
|                                       |           |       |           |                   |  |
|                                       |           |       |           |                   |  |

#### Figure 2-36 The Resource Reservation Template

From the Resources Template you can control the amount of device resources reserved for future use as follows:

- Reserved Input Pins Specifies the number of input pins to leave unused.
- Reserved Output Pins Specifies the number of Output pins to leave unused.
- Reserved Bidirectional Pins Specifies the number of I/O pins to leave unused.
- Reserved Macrocells Specifies the number of High Density Function Block macro cells to reserve.

Click OK to accept the Resources template, click Cancel to return to the previous menu, click Default to set the default options, or click Help to open the on-line help system.

#### Utilities — Template Manager — New

Click New to create a new template and you will see the dialog window as shown in Figure 2-37.

| Option Template Name: |
|-----------------------|
| •                     |
| OK Cancel             |
|                       |

#### Figure 2-37 The New Template Name Dialog Window

Enter the new template name and click OK; you will see the new name added to the list of option templates. This new template will have default settings that you can change as required.

#### Utilities — Template Manager — Delete

Click Delete to remove a selected option template from the list. You will see the Delete Confirmation dialog window as shown in Figure 2-38.



Figure 2-38 Delete Confirmation Dialog Window

#### Utilities — Template Manager — Import

Use Import to transfer a template file (created by Export as shown below) to a new design.

#### Utilities — Template Manager — Export

Use export to create a template file for outputting template information to another design.

#### Utilities — Template Manager — Help

Click Help to bring up the on-line help system.

### **Help Menu**

Use the Help menu to get quick answers to questions about using the Design Manager. You will see the Help menu as shown in Figure 2-39.

| <u>C</u> ontents             |
|------------------------------|
| <u>S</u> earch for Help On   |
| <u>T</u> utorial             |
| <u>A</u> bout Design Manager |

Figure 2-39 The Help Menu

### Help — Contents

Select contents to view the available help topics and you see the Help window as shown in Figure 2-40. Click on any topic to see the help it contains.

| Design Manager Help                                      |          |               |                  |     |  |
|----------------------------------------------------------|----------|---------------|------------------|-----|--|
| <u>F</u> ile <u>E</u> dit Book <u>m</u> ark <u>H</u> elp |          |               |                  |     |  |
| <u>Contents</u> <u>Search</u> <u>Back</u> History        | <u> </u> | <u>&gt;</u> > | <u>G</u> lossary |     |  |
| Design Manager Help Cont                                 | ents     |               |                  | +   |  |
|                                                          |          |               |                  |     |  |
| Basics                                                   |          |               |                  |     |  |
| Design Manager Introduction                              |          |               |                  |     |  |
| How to Use Help                                          |          |               |                  |     |  |
|                                                          |          |               |                  |     |  |
| Commands                                                 |          |               |                  |     |  |
| Menus - Design Manager                                   |          |               |                  |     |  |
| Menus - Flow Engine                                      |          |               |                  |     |  |
| Tool Box                                                 |          |               |                  |     |  |
| Mouse                                                    |          |               |                  |     |  |
| <u>Tool Bars</u>                                         |          |               |                  |     |  |
| Report Viewer                                            |          |               |                  |     |  |
| Brocedures                                               |          |               |                  |     |  |
|                                                          |          |               |                  | - 1 |  |
| Creating a New Project                                   |          |               |                  | •   |  |

### Figure 2-40 Help Contents

### Help — Search

Select Search to search for help on any keyword you choose; you will see the search dialog window as shown in Figure 2-41.

| 💳 Search                                                                                          |                       |
|---------------------------------------------------------------------------------------------------|-----------------------|
| Type a <u>w</u> ord, or select one from the list.<br>Then choose Show Topics.                     | Cancel                |
| closing XDS<br>exit command<br>export<br>files, exporting<br>files, opening<br>files, translating | *<br><br>*            |
| Select a <u>t</u> opic, then choose Go To.                                                        | <u>6</u> 0 T <i>o</i> |
|                                                                                                   |                       |

Figure 2-41 Help Search

### Help — Tutorial

Select Tutorial to see a step-by-step procedure for using Design Manager.

# Help — About Design Manager

Select About Design Manager and you see the Xilinx address, phone number, and software copyright notice.

# **Using the Flow Engine**

The Flow Engine allows you to easily manage the process flow of your design. Select the Flow Engine from the Design Manager Tools menu or by double clicking the Flow Engine icon:



You will see the Flow Engine Window as shown in Figure 2-42.

Design Name and Revision Number



Figure 2-42 The Flow Engine Window

The Process Indicators show you the various software functions that are available for processing your design. You control how far your design is processed by using the Stop After pull down dialog box. For example if you want to optimize and fit your design, but not create a timing simulation file or device programming file, select Stop After Fit. You will see a stop sign indicator verifying where the process will stop.

The Progress Bars show you the status of each processing step and the arrows between each step turn black after the previous step is completed.

# **Setting Up The Process Flow**

The Flow Engine allows you to interact with the process flow in several ways. For example, if you are new to Xilinx software or just want to run a quick "sanity check" on your design, you can simply click run and your design is processed using default fitting parameters. However, if you are an experienced user and want to fine tune your design to get the best possible speed or density, you can control each function in the process. These controls are located under the Setup menu.

# Using a Constraints File (to Define T-Specs)

You can create timing specifications, which control the implementation of your design, as described in Chapter 4. These T-Specs may be described in a constraints file (*design\_name.cst*). If you want to use a constraints file to control the implementation of your design, you can specify this file in the Flow Engine. The implementation software will then try to fit your design to meet the specified timing requirements. If the specified timing cannot be satisfied, the process flow is terminated.

# Using a Guide File (to Re-Use Pinouts)

Each time you fit your design, a guide file is created (*design\_name*.gyd) which contains your pinout information. You can re-use this file in subsequent iterations of your design if you want to keep the same pinouts. If you specify a valid guide file name in the Flow Engine window, the pinouts from that file will be used when the design is processed.

# **Flow Engine Menu Commands**

This section describes each Flow engine menu command.

### Flow Engine — Flow

The Flow menu contains basic flow control commands as shown in Figure 2-43. Each of these menu commands performs the same function as the corresponding button at the bottom of the Flow Engine dialog window.

| <u>R</u> un    |
|----------------|
| <u>S</u> tep   |
| <u>B</u> ackup |
| <u>S</u> top   |
| C <u>l</u> ose |

#### Figure 2-43 The Flow Menu

- **R**un: Select Run to begin the processing of your design. Processing will proceed until the Flow Engine encounters the Stop sign, until the last process is complete, or until a process error has occurred.
- Step: Select Step to process your design one process at a time. After each process is complete, you must click Step again to run the next process.
- Backup: Select Backup to cause the Flow Engine to return to the previous process step as indicated by the process indicator bars. Use this feature to save processing time by backing up to, and rerunning, only those steps that you want to change.
- Stop: Select Stop to stop the processing of your design at any time.
- Close: Select Close to close the Flow Engine.

### Flow Engine — Setup

Select Setup to specify the Flow Engine options, and you see the menu as shown in Figure 2-44.

| <u>O</u> ptions  |
|------------------|
| <u>F</u> ont     |
| <u>A</u> dvanced |

#### Figure 2-44 The Setup Menu

#### Flow Engine — Setup — Options

Select Options and you see the Design Implementation Dialog Window as shown in Figure 2-45.

| -                 | XC7300 Design     | Implementation Dialog          |
|-------------------|-------------------|--------------------------------|
| Control Files     |                   |                                |
| Guide Design:     | None              | <u>*</u>                       |
| Constraints File: |                   | Browse                         |
| Program Option T  | emplates          |                                |
| Implementation:   | User1             | Edit Template                  |
|                   |                   |                                |
| Coptional Targets |                   |                                |
| Produce Timin     | g Simulation Data | <b>×</b> Produce Timing Report |
| Produce Config    | guration Data     |                                |
| Run               | Cancel            | <u>H</u> elp                   |

#### Figure 2-45 The Options Window

See the previous section "Design – Implementation" (Figure 2-16) for more information.

#### Flow Engine — Setup — Font

Select Font and you see the Font Dialog Window as shown in Figure 2-46.

|                           | Font | t     |   |        |
|---------------------------|------|-------|---|--------|
| Fonts                     | :    | Sizes |   |        |
| algerian                  | ÷    | 12    | ÷ | OK     |
| arial                     |      |       |   |        |
| arial rounded mt bold     |      |       |   | Lancel |
| book antiqua              |      |       |   | Help   |
| bookman old style         |      |       |   |        |
| braggadocio               |      |       |   |        |
| britannic bold            |      |       |   |        |
| brush script mt           | +    |       | + |        |
|                           |      |       |   |        |
| Preview                   |      |       |   |        |
| abodefahiiklmnoparstuwwyy | 7    |       |   |        |
|                           | -    |       |   |        |
|                           |      |       |   |        |
|                           |      |       |   |        |
|                           |      |       |   |        |

#### Figure 2-46 The Font Dialog Window

Use this dialog window to select the font type and font size used for displaying messages in the Flow Engine message window.

#### Flow Engine — Setup — Advanced

Select Advanced and you see the Flow Configuration Dialog Window as shown in Figure 2-47.

| Flow Configuration: XC7300         |                              |
|------------------------------------|------------------------------|
| Implementation State: Programmed 💽 | OK<br>Cancel<br><u>H</u> elp |
| Guide File:                        | Browse                       |

#### Figure 2-47 The Flow Configuration Dialog Window

From here you can specify the flow control options as follows:

- Implementation State: This allows you to control the state at which the Flow Engine is stopped. The data must already be available in the specified state in order for the Flow Engine to back-up to that state.
- Use Flashing to Indicate Heartbeat: This causes the Process Indicators to flash as the software processes your design.
- Guide File: If you want to use the pinouts from a previous run of your design, specify that guide file here. Click Browse and you see the Open dialog window as shown in Figure 2-48.
| 1                           | Open                                                                                                  |                         |
|-----------------------------|-------------------------------------------------------------------------------------------------------|-------------------------|
| File <u>N</u> ame:<br>*.gyd | Directories:<br>c:\newdsgn<br>c:\<br>mail:<br>comp<br>comp<br>plddsgn<br>syndsgn<br>mail:<br>xproject | OK<br>Cancel<br>Network |
| List Files of <u>Type</u> : | Dri <u>v</u> es:                                                                                      |                         |
|                             | 🖃 c: ms-dos_5                                                                                         | <u>•</u>                |

#### Figure 2-48 The Open Dialog WIndow

#### Flow Engine — Utilities

Open the Utilities menu and you see the options shown in Figure 2-49. These utilities are the same as those described in the previous section "Design Manager Utilities" (Figure 2-29). See this section for details.



Figure 2-49 The Utilities Menu

#### Flow Engine — Help

Click Help to bring up the on-line help system.

# **Chapter 3**

# **Controlling Design Implementation**

This chapter shows you how to use the Design Manager to specify fitter guidelines. It also describes the design implementation control options that you can use within behavioral, schematic, and VHDL designs.

# **Design Implementation Overview**

A typical design process is composed of three phases:

- 1. The fundamental logic design.
- 2. The implementation of your logic into a target device.
- 3. The design verification.

Design implementation is controlled during the logic design phase by using schematic attributes, behavioral commands, and VHDL attributes. After your logic design is completed, including any design implementation information, you process your design in the Design Manager environment which provides additional implementation control through Design Manager menu selections.

During design implementation you provide guidelines to the software for:

- Selecting a device or devices to contain your design.
- Placing logic to achieve the most compact design.
- Assigning signals to specific device pin locations.
- Controlling various design optimization options for density or speed improvement.
- Controlling the device power consumption.

- Controlling the slewrate of device output buffers.
- Controlling the initial states of registers.
- Reserving device resources for future design iterations.

The following table shows you the types of design control options and the environments from which they are applied:

| Decign Control Ontions              | Design Environment |                         |                        |                    |  |
|-------------------------------------|--------------------|-------------------------|------------------------|--------------------|--|
| Design Control Options              | Design<br>Manager  | Schematic<br>Attributes | Behavioral<br>Commands | VHDL<br>Attributes |  |
| Single Device Selection - Manual    | Х                  | Х                       | Х                      | Х                  |  |
| Single Device Selection - Automatic | Х                  |                         |                        |                    |  |
| Multiple Device Selection           | Х                  | Note 2                  |                        | Note 2             |  |
| Logic Placement & Pin Assignment    | Note 3             | Х                       | Х                      | Х                  |  |
| Design Optimization Note 5          | Х                  | Х                       | Х                      | Х                  |  |
| Device Power Management             | Note 4             | Х                       | Х                      | Х                  |  |
| Master Reset Pin Control (MRINPUT)  | Note 4             | Х                       | Х                      | Х                  |  |
| Output Buffer Slewrate              |                    | Х                       | Х                      | Х                  |  |
| Register Initial State              |                    | Х                       | Х                      | Х                  |  |
| Resource Reservation                | Х                  | Note 1                  | Note 1                 | Note 1             |  |

*Note 1:* You can reserve resources for future design iterations in your schematic, behavioral, or VHDL design, by instantiating unused components which act as place holders.

*Note 2:* There are properties to control this option.

*Note 3:* Allows you to ignore values in the design.

Note 4: Allows you to globally turn the option on or off.

*Note 5:* The LOGIC\_OPT function is controlled only in the source design file. The TIMING\_OPT function is controlled only in Design Manager.

# **EPLD Device Selection**

During design implementation you must manually select target devices or provide a range of devices from which the software can automatically select the best ones to contain your design. The following table shows you all valid device options.

| Device  | Speed Grades      | Package Options                      |
|---------|-------------------|--------------------------------------|
| XC7318  | -5 -7             | PC44 PQ44                            |
| XC7336  | -5 -7 -10 -12 -15 | PC44 PQ44                            |
| XC7354  | -7 -10 -12 -15    | PC44 PC68                            |
| XC7372  | -7 -10 -12 -15    | PC68 PC84 PQ100                      |
| XC73108 | -7 -10 -12 -15    | PC84 PG84 PQ100 PG144<br>PQ160 BG225 |
| XC73144 | -7 -10 -12 -15    | PQ160 BG225                          |
| XC7336Q | -10 -12 -15       | PC44 PQ44 VQ44                       |

Table 3-1 Device Selection Options

**Note:** The XC7236A is also supported if explicitly targeted in your design file.

The package options are:

- BG Ball-Grid-Array.
- PC Leaded Chip Carrier.
- PG Pin-Grid-Array.
- PQ Quad Flat Pak.
- VQ Very Thin Quad Flat Pak.

# **Working With Single Devices**

This section shows you how to specify a single target device in which to implement your design. You can choose one specific device or you can specify a set of possible target devices from which the software will automatically select the most appropriate one.

If your design requires more than one device, please see the following section "Working With Multiple Devices."

# **Design Manager — Single Device Selection**

After you have opened a design, select New Device from the Implementation menu; the device selection menu appears, as shown in Figure 3-1.

| -        | - Part Selector |                                |        |  |  |  |
|----------|-----------------|--------------------------------|--------|--|--|--|
|          |                 |                                | OK     |  |  |  |
| Filters  |                 | Filtered List (76 devices)     |        |  |  |  |
| Family:  | XC7300 👤        | 73108BG225-20 +                | Lancel |  |  |  |
| Device:  | All 🛨           | 73108BG225-15<br>73108BG225-12 | Help   |  |  |  |
| Package: | All +           | 73108BG225-10                  |        |  |  |  |
| Speed:   | All 🛨           | 73108BG225-7<br>73108PC84-20   |        |  |  |  |
| F        | inal Selection  | 73×                            |        |  |  |  |

Figure 3-1 Device Selection Menu

From this menu, specify the target device parameters that you want for your design. For example if you choose "All" for all Filters fields the software is free to choose any device in the XC7300 family; in this case there are 76 possible devices to choose from as shown in Figure 3-1.

**Note:** You can also specify a part number in you design source file. This is described in the following sections.

#### **Software Device Selection Criteria**

If you select "All" for any device Filters field the software tries to fit your design within the range of possible devices you have selected by using the following selection criteria:

- 1. First, the software selects the smallest die.
- 2. Second, the software selects the smallest package.
- 3. Third, the software selects the slowest available device that meets your specified timing constraints.

The software will continue to try fitting your design into one of the possible range of selected devices until the first usable one is found or until there are no more devices to try.

## Schematic — Device Selection

Use the following attributes in schematic designs to control device selection.

### PART or PARTTYPE

For Viewlogic (or Mentor) designs, place the global PART attribute in your schematic to specify a target EPLD device; for OrCAD designs use the PARTTYPE attribute.

**Note:** Selecting a part type in the Design Manager menu overrides any PART or PARTTYPE attribute in your schematic.

The format of the PART attribute is:

**PART=**dddd-sspppp

*Where dddd* is the device number, *-ss* is the speed grade, and *pppp* is the package type and pin count. For example: XC7354-12PC68

The format of the PARTTYPE attribute is:

**PARTTYPE=***dddd-sspppp* 

*Where dddd* is the device number, *-ss* is the speed grade, and *pppp* is the package type and pin count. For example: XC7354-12PC68

### **Behavioral** — Device Selection

Use the following attribute in behavioral designs to specify a device type.

### CHIP

The CHIP statement can be used to specify a device type. The Syntax is:

**CHIP** *file\_name* XCddddpppp

Where *file\_name* is the name of your behavioral design file, XC*dddd* is the device number, and *pppp* is the package type. You cannot specify a speed grade; the software assumes the fastest speed grade for the chosen device.

For example, the following command will target your design to an XC7318-5PL44 device:

#### CHIP my\_design XC7318PL44

**Note:** If you want to specify a different speed grade (or a different device), you can choose a target device using the Design Manager menus, which will override any part selection in the CHIP statement.

See the Xilinx PLUSASM Reference for a complete description.

# VHDL — Device Selection

Use the following attribute in VHDL designs to specify a target device type.

#### set\_attribute

This attribute (for Synopsys only) is used to specify the target EPLD device type for FPGA Compiler only. (If you are using Design Compiler, you must specify the part type by using the -p option of the syn2epld command.)

The format is:

where:

- *design\_name* = the name of the top-level design entity.
- *dddd* = basic device type.
- ss = speed grade.
- *pp* = package type.
- *nn* = number of package pins.

For example:

```
set_attribute SCAN part -type string 7354-10PC44
```

# **Working With Multiple Devices**

This section shows you how to manage designs that are too large to fit within a single target device.

### **Design Manager — Multiple Device Partitioning**

The Design Manager contains a Partitioner tool for controlling how your design fits into multiple target devices. To open this tool select the Partitioner icon or select Partitioner from the Tools menu. You will see:



#### Figure 3-2 Multi-Chip Partitioner WIndow

From here you can select either the entire XC7300 family or a subset of the XC7300 family to be used as possible target devices; these show up in the Target Devices column after selection. The Partitioner then selects the best devices in which to fit your design and displays its choices in the Realized Devices column, after partitioning.

For more information on how to use the Multi-Chip Partitioner tool, see Chapter 2.

## Schematic — Multiple Device Partitioning

#### GROUP

The GROUP attribute is placed onto any internal logic symbol (including macros) in a multi-device design to specify that the logic for that symbol is to be implemented in the same physical device as other symbols assigned to the same *group\_name*. Groups of symbols with different *group\_names* can still be mapped into the same physical device unless otherwise prevented by using a CHIP attribute.

The format of this attribute is:

**GROUP**=group\_name

#### CHIP

The CHIP attribute is placed onto any internal logic symbol (including macros) in a multi-device design to specify that the logic for that symbol is to be implemented in a particular named device, exclusive of all other *chip\_names*. That is, symbols with different *chip\_names* are mapped into different physical devices. If a CHIP attribute is placed on a symbol that also has a GROUP attribute, all other symbols with the same *group\_name* are automatically assigned to *chip\_name*. This allows you to conveniently change the partitioning of groups of logic symbols among physical devices by modifying one CHIP attribute for each group.

You can also specify a physical device (*device\_type*) to be used for *chip\_name*.

The format of this attribute is:

**CHIP**=chip\_name [@device\_type]

# **Manual Logic Placement**

This section describes the schematic attributes, VHDL commands, and behavioral commands that you can use for manual logic placement. Pin assignment, described in the next section, also affects logic placement and therefore you should make sure these operations are coordinated and do not cause conflicting placement requests.

**Note:** For most designs you will achieve optimal speed and density if you allow the software to place logic automatically without restrictions. However, in some cases you may want to manually place logic to achieve the optimal density. To achieve optimal timing it is usually best to use T-Specs, as described in Chapter 4, rather than manually placing logic.

## Design Manager — Logic Placement

The following Design Manager menus contain options that globally affect logic placement:

- Design Implement
- Utilities Template Manager

For information on theses menus and their options see Chapter 2.

# Schematic — Logic Placement

Use the following attributes in schematics to control logic placement.

### F

The F attribute, placed on a component output, specifies that it is to be implemented in a Fast Function Block.

The F attribute produces an error if placed on components that require features only present in High-Density Function Blocks, such as:

- ADD
- ADSU
- ACC
- BUFCE
- IFD
- IFDX1
- ILD
- COMPM
- LD
- FDCP, FDCPE
- OBUFT
- OFDT
- XOR7, XOR8, XOR9

#### Н

The H attribute, placed on a component output, specifies that it is to be implemented in a High Density Function Block.

The F and H attributes are applied to nets in the Workview environment; they are represented by component symbols in the OrCad environment.

#### LOC=f-b-name\_mc-location

The LOC=*f*-*b*-*name\_mc*-*location* attribute, placed on a register or internal logic, assigns the signal to a specific function block and macrocell location.

For example, the following attribute places the signal to which it is attached into macrocell 5 of Function Block 3:

LOC=FB3\_5

### **Behavioral** — Logic Placement

Use the following command to control logic placement in behavioral designs.

#### PARTITION

Use physical PARTITION statements to group signals into a specific function block and optionally into specific consecutive macrocells.

For example, the following statement places the signals A1, A2, A3, and A4, in order, into function block 3 of the target device, beginning on a macrocell location chosen by the software.

#### PARTITION FB3 A1 A2 A3 A4

And the following statement places the signals A1, A2, A3, and A4, in order, into function block 4, beginning at macrocell number 3

#### PARTITION FB4\_3 A1 A2 A3 A4

You can place PARTITION statements in the header of a behavioral design file to control the assignment of equations to macrocells, which also determines the pin assignment of those outputs. All linked equations (equations using either .ADD, .SHIFT, or .EXPORT) must appear in a PARTITION statement; the order in which their

names appear determines the order in which the macrocells are linked. The software will automatically connect the carry chain across function block boundaries if necessary.

### VHDL — Logic Placement

Use the following signal attributes to affect logic placement in VHDL designs. These attributes are applied by instantiating the following components. Each of these components has one port (input) which you connect to the signal that receives the attribute.

#### F

The F attribute indicates either a Fast Function Block output signal or a Fast Input signal. Use this attribute to assign specific functions to EPLD Fast Function Blocks, which provide the highest performance.

To specify that a signal is driven from a Fast Function Block, use:

U1: F port map (signal\_name);

#### Н

The H attribute indicates a High Density Function Block output signal. Use this attribute to assign specific functions to High Density Function Blocks, which provide the most macrocell resources.

To specify that a signal is driven from a High Density Function Block, use:

U1: H port map (signal\_name);

### Manual Pin Assignment

This section describes the Design Manager options, schematic attributes, behavioral commands, and VHDL commands that you can use for manual pin assignment. Logic placement, as described in the previous section, must be coordinated with pin assignment to prevent conflicting placement requests.

For most designs you will achieve optimal speed and density if you allow the software to assign pins automatically, without restrictions.

### Design Manager — Pin Assignment

The software always saves the pinout of your design, in a file named *design\_name*.gyd, which can be used later as a guide file if you choose. You specify a guide design by using the Design-Implementation dialog window or by using the Flow Engine-Setup-Options dialog window.

## Schematic — Pin Assignment

Use the following attributes in schematics to control pin assignment.

### LOC=pin\_name[@chip\_name]

The LOC=*pin\_name* attribute, placed on a PAD symbol, assigns the signal to a specific device pin and optionally, for multi chip designs, to a specific device (*chip\_name*). The PAD symbols are IPAD, OPAD, and IOPAD. The pin name syntax varies according to the package:

- For PC packages: *pin\_name* = P*nn*, where *nn* is a pin number. For example, to place a signal on pin 24 use: LOC=P24
- For PG packages: *pin\_name* = *rc* where *rc* is row/column. For example, to place a signal on the pin at row G, column 2 use: LOC=G2

Pin assignments are unconditional; the software will not attempt to relocate a pin if it cannot achieve the specified assignment.

You can apply the LOC attribute to as many PADs in your design as you like. However, each pin assignment further constrains the software, making it more difficult to achieve the maximum density for your design.

**Note:** Pin assignment using the LOC attribute is not supported for bus components such as OBUF8.

For example, in a multi-device design, the following attribute places the signal to which it is attached onto pin 25 of the device named "MUX\_2" (which is in a PC package):

#### LOC=P25@MUX\_2

In a single device design, the following attribute places the signal to which it is attached onto the pin at row F, column 24 of the target device (which is in a PG package):

#### LOC=F24

you can have multiple pin specifications in a LOC attribute, by separating them with a semicolon. For Example:

```
LOC=P25@MUX_2;G2@CNTR_1
```

### **Behavioral** — Pin Assignment

Use the following commands to control pin assignment in behavioral designs.

#### INPUTPIN

The INPUTPIN statement assigns signals to device input pins.

#### OUTPUTPIN

The OUTPUTPIN statement assigns signals to device output pins.

#### IOPIN

The IOPIN statement assigns signals to device I/O pins.

#### FOEPIN

The FOEPIN statement assigns 3-state output enable signals to the device Fast Output Enable pins.

#### FASTCLOCK

The FASTCLOCK statement assigns clock signals to the device FastCLK pins.

#### CEPIN

The CEPIN statement assigns clock enable signals to the device Clock Enable pins.

Assign specific device pins to signals by appending the PIN keyword to any pin declaration statement. For example:

INPUTPIN (RCLK=C) X Y Z PIN 9 10 11 OUTPUTPIN A B C PIN 9 10 11 IOPIN D E F PIN 9 10 11

```
FOEPIN F PIN 32
FASTCLOCK CLKIN PIN 27
CEPIN G
```

All physically possible pin assignments are accepted regardless of their effect on device partitioning or mapping efficiency. Pin assignments within pin declaration statements override pin assignments from the pin-save file.

**Note:** Pin assignment affects logic placement, and therefore you must coordinate manual logic placement with manual pin assignment to prevent conflicts.

### VHDL — Pin Assignment

Use the following attributes to control pin assignment in VHDL designs.

#### set\_attribute

This (Synopsys only) signal attribute is used to specify the pins on which to place output signals. The format is:

set\_attribute port\_name pad\_location -type
 string pin\_number

where:

• *port\_name* = The name of the top-level design port.

The format of *pin\_number* is:

- **P***nn* for PC and PQ packages, where *nn* is the pin number.
- *rc* for PG and BG packages, where *rc* are the row letter and column number.

For example, for PC and PQ packages:

set\_attribute RDY pad\_location -type string P23

For example, for PG and BG packages:

set\_attribute RDY pad\_location -type string K13

# **Design Optimization Control**

There are a number of optimization control options the software can use before fitting your design. Each of these options is described in this section.

## **Design Manager — Design Optimization Control**

To access the Design Manager global design optimization control options, do the following:

- 1. Open the DESIGN MANAGER window.
- 2. Select Design from the menu bar.
- 3. Select Implement from the Implementation menu, which brings up the XC7300 Design Implementation Dialog Window, as follows:

|                   | XC7300 Design     | Implementation Dialog |              |
|-------------------|-------------------|-----------------------|--------------|
| Control Files     |                   |                       |              |
| Guide Design:     | None              | <u>+</u>              |              |
| Constraints File: |                   |                       | Browse       |
| Program Option T  | emplates          |                       |              |
| Implementation:   | User1             | €dit Template         | ]            |
|                   |                   |                       |              |
| Optional Targets  |                   |                       |              |
| 🗖 Produce Timin   | g Simulation Data | 🗵 Produce Timing Repo | ort          |
| Produce Config    | guration Data     |                       |              |
| Run               | Cancel            |                       | <u>H</u> elp |

Figure 3-3 XC7300 Design Implementation Dialog Window

4. Select Edit Template which brings up the XC7000 Implementation Template Window (for Fitting), as follows:

| 😑 XCI             | XC7000 Implementation Template: Default |       |  |  |  |  |  |  |
|-------------------|-----------------------------------------|-------|--|--|--|--|--|--|
| Fitting           | Fitting Optimization Resources          |       |  |  |  |  |  |  |
| X Use XACT-Perfor | Use XACT-Performance                    |       |  |  |  |  |  |  |
| Drive Unused I/O  |                                         |       |  |  |  |  |  |  |
| Low Power Mode:   | 🔿 On 🔿 Off 🖲 In D                       | esign |  |  |  |  |  |  |
| Use MR as input:  | 🔿 On 🔿 Off 🖲 In D                       | esign |  |  |  |  |  |  |
|                   |                                         |       |  |  |  |  |  |  |
|                   |                                         |       |  |  |  |  |  |  |

Figure 3-4 XC7000 Implementation Template — Fitting

| 5. | Select Optimization | , which | brings ı | ap the o | optimiza | tion wir | idow, | as |
|----|---------------------|---------|----------|----------|----------|----------|-------|----|
|    | follows:            |         |          |          |          |          |       |    |
|    |                     |         |          |          |          |          |       |    |

| XC7000 Implementation Template: User1 |      |           |   |           |                   |  |
|---------------------------------------|------|-----------|---|-----------|-------------------|--|
| Fitting                               | Opt  | imization |   | Resources | ОК                |  |
| Timing:                               | • On | O Off     |   |           | Cancel<br>Default |  |
| Input Register:                       | 🔿 On | O Off     | • | In Design | <u>H</u> elp      |  |
| Fast Output Enable:                   | O On | O Off     | • | In Design |                   |  |
| Fast Clock:                           | O On | O Off     | • | In Design |                   |  |
| UIM:                                  | O On | O Off     | • | In Design |                   |  |
| Pre Load:                             | 🔿 On | O Off     | • | In Design |                   |  |
|                                       |      |           |   |           |                   |  |
|                                       |      |           |   |           |                   |  |

#### Figure 3-5 XC7300 Implementation Template — Optimization

From here you can control the global design optimization options which are set as follows:

- On The option is activated for the whole design and corresponding schematic attributes, behavioral commands, or VHDL commands are ignored.
- Off The option is turned off for the whole design and corresponding schematic attributes, behavioral commands, or VHDL commands are ignored.
- In Design The option is controlled exclusively by schematic attributes, behavioral commands, or VHDL commands. If the option is not specified in the design, it defaults to On.

The Optimization options are described as follows:

#### Timing

The Timing option determines if the fitter will try to optimize your design to achieve the best possible timing for your critical paths. If this option is off, the fitter will try to achieve the best possible density, without regard for timing.

This timing optimization is performed independently from the timing-driven optimization of XACT Performance, which was described in Chapter 2.

### **Input Register**

The Input Register option controls register optimization for the entire design. Input Register ON is the default.

Input register optimization reduces the number of macrocells in a design by moving simple FD registers connected to IBUFs into a pad register (provided that the IBUF has no other fanouts). The clock that controls the register must be a FastCLK or an input that can be assigned to a FastCLK pin.

### **Fast Output Enable**

The Fast Output Enable option controls FOE (Fast Output Enable) optimization for the entire design. Fast Output Enable ON is the default.

FOE optimization changes a product-term 3-state signal to an FOE global control signal. Like FastCLK assignment, this reduces the number of UIM inputs and product terms required by each Function Block. FOE optimization generally applies only to BUFE, OBUFE, or 3-state PLD outputs driving an OBUF.

### **Fast Clock**

The Fast Clock option controls FastCLK optimization for the entire design. Fast Clock ON is the default.

FastCLK optimization changes a product-term clock to a FastCLK global signal, which reduces the number of UIM inputs and product terms required by each Function Block.

### UIM

The UIM option controls the placement of the Boolean functions into the UIM. The software automatically places all possible product terms into the UIM to achieve the maximum possible density.

#### Pre Load

The Pre Load option allows the XEPLD software to select register preload values to match the values supported by specified device resources such as FFBs and input registers. The default (Pre Load: ON) allows the XEPLD software to map your design most efficiently, using the device resources most suited to your design.

If you specify Pre Load: OFF, it may prevent registers from mapping into FFBs, and attempting to force such a register into an FFB (using the F attribute or through pin assignment) results in an error.

**Note:** The software always follows any preload values explicitly defined in your design. For example, the Pre Load Off option specifies a preload value of zero for all registers that do not have values explicitly defined.

# Schematic — Design Optimization Control

Use the following attributes to control the automatic optimization of your schematic design.

### **OPT=OFF|ON|UIM**

The OPT=OFF component attribute inhibits logic optimization of all macrocells used by the symbol to which it is attached. OPT=ON overrides the LOGIC\_OPT=OFF global attribute for individual symbols. This attribute has no effect on any symbol that contains no macrocell logic, such as an I/O buffer.

Logic optimization collapses logic forward into succeeding macrocells, where possible, to increase the available logic resources.

The OPT=UIM component attribute forces the placement of the Boolean function, to which it is attached, into the UIM. The software automatically places all possible product terms into the UIM to achieve the maximum possible density. However, by using this attribute, you can force specific functions (AND, NAND, OR, NOR, invert) into the UIM, if needed.

### LOGIC\_OPT=OFF

The LOGIC\_OPT=OFF global attribute inhibits Boolean logic optimization for the whole design. LOGIC\_OPT=ON is the default.

You can override the LOGIC\_OPT=OFF setting for individual symbols by using the OPT=ON attribute.

Logic optimization collapses logic forward into succeeding macrocells, where possible, to increase the available logic resources.

### UIM\_OPT=OFF

The UIM\_OPT=OFF global attribute inhibits UIM optimization for the entire design. UIM\_OPT=ON is the default.

UIM optimization extracts Boolean expressions and inverters out of macrocell logic functions and moves them into the UIM, which reduces the use of Function Block resources.

### MINIM=OFF

The MINIM=OFF attribute tells the fitter to disable logic minimization for the attached component. For example, if you have MINIMIZE=ON, you need to use the MINIM=OFF attribute if you want to specify redundant logic in a portion of your design to avoid a potential race condition such as when designing combinational feedback loops and latches.

If you have global minimization turned off (MINIMIZE=OFF) then you do not need to use the MINIM=OFF attribute on specific logic.

### MINIMIZE=OFF

The MINIMIZE=OFF global attribute inhibits logic minimization for the whole design. MINIMIZE=ON is the default.

Minimization eliminates any redundant or non-effective logic through Boolean minimization.

### FOE\_OPT=OFF

The FOE\_OPT=OFF global attribute inhibits Fast Output Enable optimization for the entire design. FOE\_OPT=ON is the default.

FOE optimization changes a product-term tri-state signal to an FOE global control signal. Like FastCLK assignment, this reduces the number of UIM inputs and product terms required by each Function Block. FOE optimization generally applies only to BUFE, OBUFE, or tri-state PLD outputs driving an OBUF.

### CLOCK\_OPT=OFF

The CLOCK\_OPT=OFF global attribute inhibits FastCLK optimization for the entire design. CLOCK\_OPT=ON is the default.

FastCLK optimization changes a product-term clock to a FastCLK global signal, which reduces the number of UIM inputs and product terms required by each Function Block.

### REG\_OPT=OFF

The REG\_OPT=OFF global attribute inhibits input register optimization for the entire design. REG\_OPT=ON is the default.

Input register optimization reduces the number of macrocells in a design by moving simple FD registers connected to IBUFs into a pad register (provided that the IBUF has no other fanouts). The clock that controls the register must be a FastCLK or an input that can be assigned to a FastCLK pin.

### PRELOAD\_OPT=OFF

The PRELOAD\_OPT=OFF global attribute allows the XEPLD software to select register preload values to match the values supported by specified device resources such as FFBs and input registers. The default (PRELOAD\_OPT=ON) allows the XEPLD software to map your design most efficiently, using the device resources most suited to the elements of your design.

If you specify PRELOAD\_OPT=OFF, it may prevent registers from mapping into FFBs, and attempting to force such a register into an

FFB (using the F attribute or through pin assignment) results in an error.

**Note:** The software always follows any preload values explicitly defined in your design. For example, the PRELOAD\_OPT=OFF option specifies a preload value of zero for all registers that do not have values explicitly defined.

### **Behavioral — Design Optimization Control**

Use the following commands to control optimization in behavioral designs.

### LOGIC\_OPT

The LOGIC\_OPT statement inhibits the automatic logic collapsing function of the XEPLD software. This can be used globally on all equations or explicitly on individual equations.

#### MINIMIZE

The MINIMIZE statement selectively enables or disables Boolean equation minimization.

### OPTIONS

The OPTIONS statement inhibits various XEPLD optimization routines for your design.

See the Xilinx PLUSASM Reference for more information.

## VHDL — Design Optimization Control

Use the following VHDL attributes to control design optimization.

### NO\_FOE

The global NO\_FOE attribute controls the automatic use of global Fast Output Enable inputs. If the NO\_FOE attribute is specified, it indicates that the software will not automatically assign 3-state control input signals to the global FOE device inputs. If NO\_FOE is not specified, the software assigns the 3-state control signals in your design to the global FOE inputs of the device, if possible.

To specify that no 3-state control signals will automatically be assigned to the global FOE inputs, instantiate the NO\_FOE component as follows:

```
U1: NO_FOE;
```

where U1 is any instance name.

### NO\_FCLK

The global NO\_FCLK attribute controls the automatic use of global FastClock inputs. If the NO\_FCLK attribute is specified, it indicates that the software will not automatically assign clock signals to the global FastClock inputs. If NO\_FCLK is not specified, the software will assign clock signals in your design to the dedicated FastCLK inputs of the device, if possible.

To specify that no clock signals will automatically be assigned to the global FastClock nets, instantiate the NO\_FCLK component as follows:

```
U1: NO_FCLK;
```

where U1 is any instance name.

#### NO\_IFD

The global NO\_IFD attribute controls the automatic usage of input pad registers. If the NO\_IFD attribute is specified, it indicates that the software will not automatically use the registers in the input pads. If NO\_IFD is not specified, the software will assign registers in your design to the input pads whenever possible, to reduce macrocell resource requirements.

To specify that registers will not be automatically placed into the input pads, instantiate the NO\_IFD component as follows:

```
U1: NO_IFD;
```

where U1 is any instance name.

### OPT\_OFF

The OPT\_OFF signal attribute inhibits the software from optimizing the cell that drives the connected signal.

To specify that a signal is to remain as a macrocell output, use:

U1: OPT\_OFF port map (signal\_name);

where U1 is any instance name.

#### OPT\_UIM

The OPT\_UIM signal attribute forces the software to place the specified AND gate into the UIM. It can only be connected to a signal that originates from an AND gate.

To specify that an AND gate is to be implemented in the UIM, instantiate the OPT\_UIM component as follows:

U1: UIM\_OPT port map (signal\_name);

where U1 is any instance name.

**Note:** The optimization of AND gates into the UIM is done automatically by the fitter whenever possible.

### Power Management

You can control the power consumption and speed of each component in your design. If you select low power, your speed is decreased. If you select high speed, power consumption is increased. These options can be applied to individual components by using Schematic attributes, behavioral commands, or VHDL commands.

### Design Manager — Power Management

To access the Design Manager global Low Power Mode option, do the following:

- 1. Open the DESIGN MANAGER window.
- 2. Select Design from the tool bar.
- Select Implement from the Design menu, which brings up the XC7300 Design Implementation Dialog Window, as shown in Figure 3-6.

| ZC7300 Design                    | n Implementation Options     |
|----------------------------------|------------------------------|
| Control Files                    |                              |
| Guide Design: None               | <u>+</u>                     |
| Constraints File:                | Browse                       |
| Program Option Templates         |                              |
| Implementation: User1            | Edit Template                |
|                                  |                              |
| Optional Targets                 |                              |
| 🗵 Produce Timing Simulation Data | <b>Produce Timing Report</b> |
| X Produce Configuration Data     | Signature: jcount            |
| Run Cancel                       | <u>H</u> elp                 |

Figure 3-6 XC7300 Design Implementation Dialog Window

4. Select Edit Template which brings up the XC7000 Implementation Template Window for Fitting, as follows:

|                                     | XC7000 Implementation Template: Default |           |    |  |  |  |
|-------------------------------------|-----------------------------------------|-----------|----|--|--|--|
| Fitting                             | Optimization                            | Resources | ОК |  |  |  |
| X Use XACT-Perfor                   | Cancel<br>Default<br>Help               |           |    |  |  |  |
| Drive Unused I/0                    |                                         |           |    |  |  |  |
| Low Power Mode:<br>Use MR as input: |                                         |           |    |  |  |  |
|                                     |                                         |           |    |  |  |  |

Figure 3-7 XC7000 Implementation Template — Fitting

From here you can control the Low Power Mode option which is set as follows:

- On Low power is activated for the whole design and schematic attributes, behavioral commands, or VHDL commands for power management are ignored.
- Off High speed is activated for the whole design corresponding schematic attributes, behavioral commands, or VHDL commands for power management are ignored.
- In Design Device power is controlled exclusively by schematic attributes, behavioral commands, or VHDL commands. If power management options are not specified in the design, it defaults to Off.

### Schematic — Power Management

Use the following schematic attribute to control device power consumption.

## LOWPWR=ON | OFF | ALL

The LOWPWR attribute controls the power consumption for individual components (ON | OFF) or globally for all components (ALL). The default is LOWPWR=OFF (high speed) for all macrocells used in the design unless otherwise specified.

Use LOWPWR=ALL to make low power (slower speed) the global power setting.

To control the power setting of individual components, use LOWPWR=ON (if the default is LOWPWR=OFF) or LOWPWR=OFF (if the global attribute has been set to LOWPWR=ALL). This attribute is ignored if assigned to a symbol that uses no macrocells, such as an inverter, Boolean functions that are optimized into the UIM, and input registers. This attribute is valid only for XC7300 designs.

### **Behavioral — Power Management**

Use the following command to control device power consumption in behavioral designs.

#### PWR

The PWR statement specifies whether macrocells implementing the specified equations have LOW-power or standard-power (STD) operation.

See the Xilinx PLUSASM Reference for more information.

## VHDL — Power Management

Use the following VHDL global attribute to control the device power consumption.

### LOWPWR

The LOWPWR attribute controls the macrocell power usage. If the LOWPWR attribute is specified it indicates that all macrocells have

low power operation. If LOWPWR is not specified, the macrocells have standard power operation.

To specify low power operation for all macrocells, instantiate the LOWPWR component as follows:

#### U1: LOWPWR;

where U1 is any instance name.

## **Slewrate Control**

You can control the slew rate of your the output buffers in you design by using schematic attributes, behavioral commands, or VHDL commands only.

#### Schematic — Slewrate Control

Use the following global attribute to control the speed of your output buffers for XC73144 designs.

#### FAST

The Fast attribute causes the output buffers to switch as fast as possible.

**Note:** The output buffer slewrate defaults to slow for the XC73144; for all other devices the output slew rate is always fast.

### **Behavioral — Slewrate Control**

Use the following behavioral command to control the speed of your output buffers for XC73144 designs.

#### FAST

The Fast command causes the output buffers to switch as fast as possible.

### VHDL — Slewrate Control

Use the following signal attribute (for Synopsys only) to control the slew rate of the output buffers in your VHDL design.

#### set\_pad\_type

The SET\_PAD\_TYPE attribute, when used with the -slewrate option, controls the output buffer slew rate. The options are:

- *HIGH* Slows the output signal transition time and thus reduces internal ground-bounce noise.
- *NONE* Speeds up the output signal transition time. (The default is for fast transition times.)

The output buffers (IBUF, OBUF, and IOBUFE) default to fast transition outputs. However, in order to reduce possible ground-bounce problems, it is recommended that you use the fast transition default only for those output signals that require maximum speed.

To set all outputs for slow slew rate, use the following command:

#### set\_pad\_type -slewrate HIGH all\_outputs ()

Use this command after specifying the set\_port\_is\_pad command and before implementing the insert\_pads command.

After you have globally changed all outputs to the HIGH option (for slow signal transition) you can set any individual output for fast signal transition by using the following command:

#### set\_pad\_type -slewrate NONE port\_name

If you need fast transition time on most of your outputs, you can leave the default slew rate as NONE and slow only the selected outputs, by using the following command:

#### set\_pad\_type -slewrate HIGH port\_name

**Note:** Synopsys and Xilinx define the slew rate using opposite terms. The Synopsys HIGH attribute translates to a SLOW Xilinx slew rate. The Synopsys NONE attribute translates to a FAST Xilinx slew rate.

# **Initial State Control**

This section describes how to control the initial state of the registers in your design so that it will power-up into a known state.

### Schematic — Initial State Control

Use the following attributes to control the initial states of registers in your schematic design.

### INIT=R | S

The INIT=R (for a 0 value) or INIT=S (for a 1 value) component attributes specify the preload value of the registered component to which they are attached.

The INIT attributes are always obeyed by the fitter, regardless of the PRELOAD\_OPT attribute, but are ignored in functional simulation.

**Note:** You cannot change the preload value of an input register to 0 using the INIT=R attribute because input registers physically do not support preload to the 0 state. Also, if you specify INIT=R to control preload values, it prevents registers from mapping into FFBs, and attempting to force such a register into an FFB (using the F attribute or through pin assignment) results in an error.

## PRELOAD\_OPT

The PRELOAD\_OPT=OFF global attribute allows the XEPLD software to select register preload values to match the values supported by specified device resources such as FFBs and input registers. The default (PRELOAD\_OPT=ON) allows the XEPLD software to map your design most efficiently, using the device resources most suited to the elements of your design.

If you specify PRELOAD\_OPT=OFF, it may prevent registers from mapping into FFBs, and attempting to force such a register into an FFB (using the F attribute or through pin assignment) results in an error.

**Note:** The software always follows any preload values explicitly defined in your design. For example, the PRELOAD\_OPT=OFF option specifies a preload value of zero for all registers that do not have values explicitly defined.

### **Behavioral** — Initial State Control

Use the following command to control the initial states of registers in behavioral design.

### signal\_name.PRLD

The .PRLD extension specifies the initial logic value to be preloaded into the macrocell register during power-up (VCC=1, GND=0). The syntax is:

signal\_name.prld = VCC | GND

See the Xilinx PLUSASM Reference for more detailed information.

## VHDL — Initial State Control

Use the following VHDL attributes to control the initial states of registers in your design.

### PRELOAD

The global PRELOAD attribute controls the use of default initial state values for registers in your design. If PRELOAD is specified, the software uses the default initial states for each register as shown in the library specifications. If the PRELOAD attribute is not specified, it indicates that the software may change the initial states of registers (unless explicitly specified) if the change allows a more efficient implementation.

To prevent the software from changing the initial states of registers in your design, instantiate the PRELOAD component as follows:

#### U1: PRELOAD;

where U1 is any instance name.

#### INIT=R | S

The INIT=R (for a 0 value) or INIT=S (for a 1 value) component attributes specify the preload value of the registered component to which they are attached.

The INIT attributes are always obeyed by the fitter, regardless of the PRELOAD\_OPT attribute.

**Note:** You cannot change the preload value of an input register to 0 using the INIT=R attribute because input registers physically do not support preload to the 0 state. Also, if you specify INIT=R to control preload values, it prevents registers from mapping into FFBs, and attempting to force such a register into an FFB (using the F attribute or through pin assignment) results in an error.

#### set\_attribute

This attribute is used to specify the initial (power up) state of registers for Synopsys designs only.

The format is:

```
set_attribute instance_name
    fpga_xilinx_init_state -type string state
```

where:

- *instance\_name* is the name of a register instance
- *state* is either S (set) or R (reset)

For example:

```
set_attribute "QOUT_reg<2>"
    fpga_xilinx_init_state -type string S
```

You can also use the Synopsys **find** function to specify a set of instance names using wildcards, for example:

```
set_attribute find (cell QOUT*)
    fpga_xilinx_init_state -type string S
```

# **Resource Reservation for Design Iteration**

This section shows you how to reserve macrocells for design iteration and for use in multi-chip partitioning.

### **Design Manager — Resource Reservation**

To access the Design Manager Resources options, do the following:

- 1. Open the DESIGN MANAGER window.
- 2. Select Design from the tool bar.
- 3. Select Implement from the Design menu, which brings up the XC7300 Design Implementation Dialog Window, as follows:

| <b>—</b> X         | (C7300 Design I | mplementation Dialog | ]            |
|--------------------|-----------------|----------------------|--------------|
| Control Files      |                 |                      |              |
| Guide Design:      | None            | ¥                    |              |
| Constraints File:  |                 |                      | Browse       |
| Program Option Tem | plates          |                      |              |
| Implementation:    | User1           | Edit Template        |              |
|                    |                 |                      | _            |
| Optional Targets   |                 |                      |              |
| 🗖 Produce Timing S | imulation Data  | 🗵 Produce Timing Rep | port         |
| Produce Configura  | ation Data      |                      |              |
| Run                | Cancel          |                      | <u>H</u> elp |

Figure 3-8 XC7300 Design Implementation Dialog Window

4. Select Edit Template which brings up the XC7000 Implementation Window for Fitting, as follows:

| <b>—</b> XC              | XC7000 Implementation Template: Default |           |                   |  |  |  |
|--------------------------|-----------------------------------------|-----------|-------------------|--|--|--|
| Fitting                  | Optimization                            | Resources | ОК                |  |  |  |
| <b>X</b> Use XACT-Perfor | mance                                   |           | Cancel<br>Default |  |  |  |
| 🗵 Ignore Pin Assign      | nments                                  |           | Help              |  |  |  |
| Drive Unused I/0         | Drive Unused I/O Pads on Chip           |           |                   |  |  |  |
| Low Power Mode:          | 🔿 On 🔿 Off 💿 In D                       | esign     |                   |  |  |  |
| Use MR as input:         | 🔿 On 🔿 Off 🖲 In D                       | esign     |                   |  |  |  |
|                          |                                         |           |                   |  |  |  |
|                          |                                         |           |                   |  |  |  |

Figure 3-9 XC7000 Implementation Template — Fitting


5. Select Resources which brings up the following window:

Figure 3-10 Resources Dialog Window

From here you can control the amount of device resources that will be left unused in each device. If your design uses more than one device, these resource reservations are applied to each device; the resource reservations are not divided among the total number of devices used. The resource reservation options are:

### **Reserved Input Pins**

This specifies the total number of reserved input pins including Fast Input pins that are reserved in each device.

### **Reserved Output Pins**

This specifies the total number of output pins reserved in each device including those connected to Fast Function Blocks and those connected to High Density Function Blocks.

### **Reserved Bidirectional Pins**

This specifies the total number of I/O pins reserved in each device including those connected to Fast Function Blocks and those connected to High Density Function Blocks.

### **Reserved Macrocells**

This specifies the total number of macrocells reserved in each device including those contained in Fast Function Blocks and those contained in High Density Function Blocks.

# Chapter 4

# **Controlling Design Timing**

You can use Timing Specifications (T-Specs) to specify the maximum allowable delay between groups of components in your design. The software then places and routes your design to achieve the timing defined by these specifications. This Xilinx EPLD timing-driven optimization is called XACT-Performance.

T-Specs can be applied directly to a schematic design or they can be specified in a constraints file for behavioral and VHDL designs. You can then globally enable or disable T-Specs through Design Manager menu options.

# Design Manager — Timing Control

To enable global timing-driven optimization (XACT-Performance), do the following:

- 1. Open the DESIGN MANAGER window.
- 2. Select Design from the menu bar.
- 3. Select Implement from the Implementation menu, which brings up the XC7300 Design Implementation Dialog Window as follows:

| <b>—</b>           | (C7300 Design I | mplementation Dial | og           |
|--------------------|-----------------|--------------------|--------------|
| Control Files      |                 |                    |              |
| Guide Design:      | None            | <u>+</u>           |              |
| Constraints File:  |                 |                    | Browse       |
| Program Option Tem | plates          |                    |              |
| Implementation:    | User1           | Edit Template      |              |
|                    |                 |                    |              |
| Optional Targets   |                 |                    |              |
| Produce Timing 9   | Simulation Data | 🗵 Produce Timing R | eport        |
| Produce Configu    | ration Data     |                    |              |
| Bun                | Cancel          |                    | <u>H</u> elp |

Figure 4-1 XC7300 Design Implementation Dialog Window

4. Select Edit Template, which brings up the XC7300 Implementation Template Window for Fitting as follows:



Figure 4-2 XC7300 Implementation Template — Fitting

5. If you place an X on Use XACT Performance the software will use your T-Spec information (if it exists) when fitting your design. If you do not select this option, the software will ignore all T-Spec information.

# Schematic — Timing Control

This section shows you how to specify timing control information in schematic designs.

# **Defining Timing Specifications**

Timing specifications are placed on your schematic using a TIMESPEC primitive that contains the Time Spec Attribute Definitions, which control the timing for paths between defined groups of components.

### The TIMESPEC Primitive

The TIMESPEC primitive, as illustrated in Figure 4-3, is 30 characters wide and contains TS attribute definitions. Each TIMESPEC primitive can hold up to eight TS attribute definitions. If you want to include more than eight TS attribute definitions, you can use multiple TIMESPEC primitives in your schematic.

**Note:** Though the TIMESPEC primitive is only 30 characters wide, you can create TS attribute definitions of any length by continuing on the next line.

| TIMESPEC                 |
|--------------------------|
| TS01=FROM:FFS:TO:PADS=25 |
|                          |
|                          |
|                          |
|                          |
|                          |
|                          |
|                          |

#### Figure 4-3 TIMESPEC Primitive

How you add a TIMESPEC primitive to your schematic depends on your specific schematic-entry software. Refer to the appropriate Xilinx Interface User Guide for step-by-step instructions.

### **TIMESPEC** Attribute Syntax

The TIMESPEC attribute definitions specify the maximum delay between groups of components. They begin with the letters "TS" and a unique identifier that can consist of letters, numbers, or the underscore character (\_). The From-To statement specifies the timing requirements between specific end points. The full syntax is shown as follows:

**TS***identifier***=FROM:***group1***:TO:***group2***=***delay* 

The parameters *group1* and *group2* can be any of the following:

• Predefined groups consisting of FFS, LATCHES, or PADS, which are discussed in the "Using Predefined Groups" section.

- Previously created TNM identifiers, which are introduced in the "Creating Arbitrary Groups Using TNMs" section.
- Groups defined in TIMEGRP symbols, which are introduced in the "Creating New Groups from Existing Groups" section.

The *delay* parameter defines the maximum delay for the attribute, using nanoseconds as the default unit of measurement. Other units of measurement such as MHZ may also be used; see the section "Specifying Time Delay Units" later in this chapter.

**Note:** Keywords, such as FROM and TO, appear in this document in upper case; however, you can enter them in the TIMESPEC primitive in either upper or lower case.

The following examples show typical TIMESPEC attribute definitions:

```
TS01=FROM:FFS:TO:FFS=30
TS_OTHER=FROM:PADS:TO:FFS=25
TS_THAT=FROM:PADS:TO:LATCHES=35
```

Note: Latches refer to input latches only.

*OrCAD Users* — The TIMESPEC primitive does not exist in the Xilinx OrCAD library. For details on how to use Time Specs in an OrCad design, refer to the *OrCAD Interface User Guide*.

*Mentor Graphics Users* — The term *attribute* in this chapter is equivalent to *property* as used in the Mentor Graphics environment.

# **Defining Timing Path End Points**

Specify the start and end points of your timing paths using one of the following methods:

- Refer to a predefined group by specifying one of the corresponding keywords FFS, PADS, LATCHES.
- Create arbitrary groups within a predefined group by tagging symbols with TNM (pronounced *tee-name*) attributes.
- Create groups that are combinations of existing groups by using TIMEGRP symbols.
- Create groups by pattern matching on signal names.

The following sections discuss each method in detail.

### **Using Predefined Groups**

You can refer to a group of flip-flops, input latches, or I/O pads, by using the corresponding keywords:

| Keyword | Group                                                          |
|---------|----------------------------------------------------------------|
| FFS     | Macrocell or IOB flip-flops                                    |
| LATCHES | input latches only; not latches built from function generators |
| PADS    | input/output pads                                              |

These predefined groups represent all symbols of that type. For example the following TS Attribute means that the delay between any two flip-flops must be no greater than 30 ns.

TS01=FROM:FFS:TO:FFS=30

And the following TS attribute means that the delay between any I/O pad and any flip-flop must be no greater than 25ns.

TS\_OTHER=FROM:PADS:TO:FFS=25

To create groups that are more specific, see the next section, "Creating Arbitrary Groups Using TNMs."

### **Creating Arbitrary Groups Using TNMs**

A TNM (T-Name or timing name) is a flag that you place directly on your schematic to tag specific pads, flip-flops, or input latches. All symbols tagged with the TNM identifier are considered a group. Place TNM attributes directly on your schematic using the following syntax:

```
TNM=identifier
```

where *identifier* is a value that consists of any combination of letters, numbers, or underscores. It is usually a good idea to keep the TNM short for convenience and clarity. For example:

#### TNM=grp\_1

**Warning:** Do not use reserved words, such as FFS, LATCHES, or PADS, for TNM identifiers.

You can specify as many groups of end points as you need.

You can tag groups of end points by placing TNM identifiers on:

- primitive symbols
- macro symbols
- signals or pins

The method you choose depends on how the path end points are related in your design.

Placing TNMs on Primitive Symbols

You can group individual logic primitives explicitly by flagging each symbol, as illustrated in the following figure:



#### Figure 4-4 Placing a TNM on Primitive Symbols

In Figure 4-4, the flip-flops tagged with the TNM form a group called "FLOPS." The untagged flip-flop is not part of the group.

**Note:** You cannot use TNMs to group instances of incompatible symbols; for example, it is incorrect to tag a pad and a flip-flop with the same TNM. The only compatible predefined groups are flip-flops and input latches, on which you can use the same TNM.

Place only *one* TNM on each symbol. If you want to assign more than one identifier to the same symbol, include all identifiers on the right side of the equal sign (=) separated by a semicolon (;), as follows:

```
TNM=joe;fred
```

Placing TNMs on Macro Symbols

When a macro contains only one symbol type, you can place a TNM directly on the macro. If the macro contains only flip-flops, all the flip-flips are identified by the given TNM.

When a macro contains more than one symbol type, use the TNM identifier in conjunction with one of the predefined groups: FFS, PADS, or LATCHES as indicated by the following syntax examples:

TNM=FFS: *identifier* TNM=LATCHES: *identifier* TNM=PADS: *identifier* 

If you want to place an identifier on more than one symbol type, separate each symbol type and identifier with a semicolon (;) as illustrated by the following examples:

TNM=FFS:FLOPS\_1;PADS:OPADS\_6
TNM=RAMS:MEMS;LATCHES:INLATS

#### Placing TNMs on Signals or Pins to Group Flip-Flops

You can easily group flip-flops by flagging a common input signal, typically either a clock signal or an enable signal. If you attach a TNM to a signal or load pin, that TNM applies to all flip-flops and/or input latches that are reached through the signal or pin. The software traces forward on that path, through any number of gates or buffers, until it reaches a flip-flop or input latch and adds that element to the specified TNM group. This mechanism is called forward tracing.

Placing a TNM on a signal is equivalent to placing that TNM attribute on every load pin of the signal. Use pin TNM attributes when you need finer control.

Figure 4-5 illustrates the use of a TNM on a net that traces forward to create a group of flip-flops. The TNM traces forward to the first two flip-flops, which form a group called FLOPS. The bottom flip-flop is not part of the group FLOPS.



#### Figure 4-5 Placing a TNM on Signals to Group Flip-Flops

Figure 4-6 illustrates placing a TNM on a clock pin, which traces forward to all three flip-flops and forms the group Q\_FLOPS:



X4676

#### Figure 4-6 Placing a TNM on a Clock Pin to Group Flip-Flops

## **Creating New Groups from Existing Groups**

In addition to naming groups using the TNM identifier, you can also define groups in terms of other groups. You can create a group that is a combination of existing groups by defining a TIMEGRP attribute as follows:

newgroup=existing\_grp1:existing\_grp2[:existing\_grp3...]

where *newgroup* is a newly created group that consists of existing groups which were created via TNMs, predefined groups, or other TIMEGRP attributes.

*Mentor Graphics Users* — You must specify a leading equal sign (=) when defining TIMEGRP attributes, for example, *=newgroup*. The preceding equal sign lets Mentor know that this is a user-defined attribute. Refer to the *Mentor Interface User Guide* for more information.

### The TIMEGRP Primitive

TIMEGRP attributes reside in the TIMEGRP primitive, as illustrated in Figure 4-7. After you create a TIMEGRP attribute definition within a TIMEGRP primitive, you can use it in the TIMESPEC primitive. Each TIMEGRP primitive can hold up to eight group definitions and you can use multiple TIMEGRP primitives.

| TIMEGRP              |
|----------------------|
| some_ffs=flips:flops |
|                      |
|                      |
|                      |
|                      |
|                      |
|                      |
|                      |

#### Figure 4-7 TIMEGRP Primitive

You can place TIMEGRP attributes either in the TIMEGRP primitive on the schematic as discussed in this section or in the constraints (CST) file. You can use TIMEGRP attributes to create groups using the following methods:

- Combining multiple groups into one
- Creating groups by exclusion

The following sections discuss each method in detail.

#### **Combining Multiple Groups into One**

You can define a group by combining other groups. The following syntax example illustrates the simple combining of two groups:

big\_group=small\_group:medium\_group

In this syntax example, small\_group and medium\_group are existing groups defined using a TNM or TIMEGRP attribute. Within the TIMEGRP primitive, TIMEGRP attributes can be listed in any order; that is, you can create a TIMEGRP attribute that references another TIMEGRP attribute that appears after the initial definition.

Note: A circular definition, as shown below, causes an error.

```
many_ffs=ffs1:ffs2
ffs1=many_ffs:ffs3
```

#### Creating Groups by Exclusion

You can define a group that includes all elements of one group except the elements that belong to another group, as illustrated by the following syntax examples:

```
group1=group2:EXCEPT:group3
```

where *group1* represents the group being defined; *group2* and *group3* can be a valid TNM, predefined group, or TIMEGRP attribute.

As illustrated by the following example, you can specify multiple groups to include or exclude when creating the new group.

group1=group2:group3:EXCEPT:group4:group5

**Note:** Do not use reserved words, such as FFS, PADS, RISING, FALLING, or EXCEPT, as group names or TNMs.

# **Creating Groups by Pattern Matching**

You can use wildcard characters to define groups of symbols whose associated signal names match a specific pattern as follows:

group=predefined\_group(pattern)

where *predefined\_group* can only be one of the following predefined groups — FFS, LATCHES, or PADS. A *pattern* is any string of characters used in conjunction with one or more wildcard characters.

**Note:** When specifying a signal name, you must use its full hierarchical path name so the software can find the signal in the flattened design.

For flip-flops, and input latches, specify the output signal name. For pads, specify the external signal name.

In XACT-Performance, any place you specify a predefined group, you can specify a predefined group qualified by a pattern as follows:

**TS***identifier***=FROM:***group*(*pattern*)**:TO:***group*(*pattern*)**=***delay* 

The following example illustrates creating a group that includes the flip-flops that source signals whose names begin with \$1I3/FRED:

group1=ffs(\$1I3/FRED\*)

The following example illustrates a group that excludes certain flipflops whose output signal names match the specified pattern:

group\_23=ffs:EXCEPT:ffs(a\*)

In this example, group\_23 includes all flip-flops except those whose output signal names begin with the letter "a."

### Using Wildcards to Specify Signal Names

The wildcard characters "\*" and "?", enable you to select a group of symbols whose output signal names match a specific string or pattern. The asterisk (\*) represents any character string. The question mark (?) indicates a single character.

For example, DATA\* indicates any signal name that begins with "DATA," such as DATA1, DATA22, DATABASE, and so on. The string NUMBER? specifies any signal names that begin with "NUMBER" and end with one single character, for example, NUMBER1 and NUMBERS, but not NUMBER12.

You can also specify more than one wildcard character. For example, \*OR? specifies any signal names that begin with any series of characters followed by "OR" and end with any one character such as NOR1, OR2, and MULTIPLEXOR5.

### **Multiple Specifications Applied to the Same Path**

When you apply more than one From-To specification to the paths between a given pair of end points, the software analyzes all of them. In this case, the software chooses the fastest one, which might not be the specification you want. For example, suppose you have the following timing requirements:

```
TS_ALL=FROM:PADS:TO:FFS:=30
TS_SLOWER=FROM:PADS:TO:SLOW_FFS=40
```

For TS\_SLOWER to control the paths to SLOW\_FFS, it would have to disable TS\_ALL on these paths; however, no specification can disable another. Therefore, the TS\_SLOWER paths are specified faster than intended. You can avoid this problem by either of two methods:

• Make sure your broad specifications are always the slowest ones. You could create a FAST\_FFS group instead of a SLOW\_FFS group, as follows:

TS\_ALL=FROM:PADS:TO:FFS=40 TS\_FASTER=FROM:PADS:TO:FAST\_FFS=30

• Explicitly exclude slower paths from faster, more general specifications by using a TIMEGRP EXCEPT statement, as explained in the previous section.

Using this method, you could create a TIMEGRP attribute to define the FAST\_FFS group as a complement of the SLOW\_FFS group as follows:

FAST\_FFS=FFS:EXCEPT:SLOW\_FFS

In the TIMESPEC primitive, you can define two non-overlapping specifications:

```
TS_FASTER=FROM:PADS:TO:FAST_FFS=30
TS_SLOWER=FROM:PADS:TO:SLOW_FFS=40
```

# **Ignoring Selected Paths**

Timing paths that are never used during time-critical operations do not require path analysis and any timing requirement placed on these paths will unnecessarily restrict the software and may result in failure to meet the overall timing requirements. You can use IGNORE to disable any paths that you do not need to control by using the following syntax within the TIMESPEC primitive:

#### TSid=IGNORE

Attaching this to a net or load pin causes the timing analysis software to ignore any paths that include the net or load pin and this makes your design easier to route.

#### **Breaking Combinational Loops**

The software cannot perform timing path analysis on combinational loops and therefore it automatically ignores certain connections in order to break the loops. By using IGNORE, you can direct the software to ignore specific nets or load pins, consequently controlling how loops are broken.

## **Specifying Relative TS Attribute Delays**

Instead of specifying time or frequency in a TS attribute definition, you can specify timing as a multiple or division of another TS attribute. This is useful in a system where all clocks are derived from a master clock; in this situation, changing the timing specification for the master clock changes the specification for all clocks in the system.

Use the following syntax to specify a relative TS attribute delay:

**TS***identifier=specification*:*reference\_TS\_attribute*[\*,/]*number* 

where *number* can be either a whole number or a decimal. The *specification* can be any From-To statement as illustrated by the following examples:

FROM: PADS: TO: PADS
FROM: group1:TO: group2
FROM: tnm\_identifier: TO: FFS
FROM: LATCHES: TO: group1

Use "\*" to represent multiplication and "/" to represent division. The specification type of the reference TS attribute does not need to be the same as the TS attribute being defined. However, it must not be specified in terms of AUTO or IGNORE.

Examples of specifying relative TS attributes are described as follows. In these cases, assume that the reference attributes were specified as delays (not frequencies)

| TS08=FROM:FFS:TO:PADS=<br>TS05*10 | The paths between flip-flops<br>and pads are placed and routed<br>so their delay is at most 10<br>times the delay specified in the<br>TS05 attribute.       |
|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TS1=FROM:PADS:TO:PADS=<br>TS07/8  | The paths between input and out-<br>put pads are placed and routed so<br>their delay is at most one-eighth<br>the delay specified in the TS07<br>attribute. |

**Note:** When a reference attribute is specified as a frequency, a multiple represents a faster specification; a division represents a slower specification.

You can also specify relative TS attributes in terms of other relative TS attributes. The following example provides an illustration.

```
TS09=FROM:FFS:TO:FFS=50
TS10=FROM:FFS:TO:PADS=TS09*2
TS11=FROM:PADS:TO:PADS=TS10*4
```

# **Specifying Time Delay Units**

Nanoseconds are the default units for specifying delay times in TS attributes. However, after specifying the maximum delay or minimum frequency numerically, you can enter the unit of measure by specifying the following:

- NS for nanoseconds
- MHZ for megahertz
- US for microseconds
- KHZ for kilohertz

The software converts all units to nanoseconds and rounds them to 0.1 ns accuracy.

# **Example Schematic Using TNMs and TIMEGRPs**

TNM identifiers define symbols or groups of symbols that are used in timing specifications. They can also define other groups. Figure 4-8 shows an example of a TNM attribute attached to an individual symbol. In this circuit, the flip-flop D\_FF has the attribute TNM=D\_FF attached to it.



Figure 4-8 Using TNMs and TIMEGRPs in a Schematic

The TIMEGRP symbol contains an attribute that defines a group of flip-flops called Q\_FFS, which includes all flip-flops in the schematic except the one labeled D\_FF. You can then use the group Q\_FFS to create timing specifications in the TIMESPEC primitive. The flip-flop D\_FF has its clock enable driven at 1/16th of the clock frequency; therefore, its flip-flop to pad and pad to flip-flop timing specifications are longer than the flip-flop to pad specifications in the Q\_FFS group.

# **Timing Control Syntax Summary**

The following sections summarize the XACT-Performance syntax.

#### **TNM Attributes**

The following table lists the syntax used when creating TNMs, which you enter directly on the primitive symbol, macro symbol, signal, or load pin.

| Flag Type              | TNM Attribute Syntax                                                                |  |  |
|------------------------|-------------------------------------------------------------------------------------|--|--|
| Symbol<br>Macro symbol | TNM=group1 [;group2]         TNM=predefined_group:group1 [;predefined_group:group2] |  |  |
| Signal                 | <b>TNM</b> =group                                                                   |  |  |
| Load pin               | <b>TNM</b> =group                                                                   |  |  |

#### **TIMEGRP** Attributes

The following lists the syntax used within the TIMEGRP primitive.

| Group Type | TIMEGRP Attribute Syntax                             |
|------------|------------------------------------------------------|
| Combine    | new_group=group1:group2 [:group3]                    |
| Exclude    | new_group=group1: [:group2]:EXCEPT:group3: [:group4] |

### TIMESPEC Attributes

The following lists the syntax used for parameters that define TS attributes, which reside in the TIMESPEC primitive.

| Spec Туре | TIMESPEC Attribute Syntax      | TS Flag<br>Required? |
|-----------|--------------------------------|----------------------|
| From-To   | TSid=FROM:group:TO:group=delay | No                   |
| Ignore    | TSid=IGNORE                    | Yes                  |
| Auto      | TSid=path_type:AUTO            | Yes                  |

# **Timing Control using a Timing Constraints File**

For behavioral and VHDL designs you can use a Constraints file (.CST) to specify timing requirements. The TIMESPEC and TIMEGRP constraints that apply to EPLD designs are described here.

**Note:** You can also use a constraints file with schematic designs. The Constraints file will override any T-Specs within the schematic.

# **Constraints File Syntax Conventions**

The following conventions are used for .CST file entries:

- Lower-case words are case sensitive and must be lower case.
- [0-9] means a range of numbers between 0 and 9, inclusive.
- [a-z] means a range of characters between AA and Z, inclusive.
- % means "can be composed of."
- | indicates alternatives, of which only one must be selected.
- { } means that you must choose one of the enclosed items.
- [] means that the enclosed items are optional, or that the enclosed items represent a range of possible values.
- *italics* represent variables.

## **TIMESPEC Constraint Statement Syntax**

Use the following syntax for creating EPLD TIMESPEC statements:

```
TIMESPEC="timespec_line";
```

where *timespec\_line* is composed of the following elements:

- timespec\_line : := tsIdentifier=timespec\_statement Example: from:FFS:to:FFS=10
- *tsIdentifier* : := TSlabel

Example: TSmux\_23

- timespec\_statement : := {default\_spec | delay\_spec | link | ignore}
   Example: from:fred:to:joe:=15
- *tlabel* : := *alphanum* [*alphanum*...] Example: mux\_3
- *alphanum* : := {[a-z] | [A-Z] | [0-9] | \_} Example: Test\_Mux\_57
- *from\_to* : := from:*group*:to:*group=max\_delay* Example: from G\_1:to:G\_8=15
- *dmax\_delay* : := {*requirement* | auto}
   Example: auto
- thi : := *float\_number* Example: 5.5
- group : := {tlabel | pattern | whole\_class}
   Example: mux\_3
- whole\_class : := {ffs | pads | latches}
   Example: pads
- max\_delay : := {requirement | auto}
   Example: max\_delay : := 10.1 mhz

- pattern : := whole\_class (signame {:signame})
   Example: input\*
- signame : := {alphanum | \* | ?} [{alphanum | \* | ?} ...]
   Example: signame : := input\*
- requirement : := {float\_number [unit] | reference}
   Example: requirement : := 1.5 us
- *unit* : := {ns | us | mhz | khz} Example: unit : := mhz
- reference : := {tsIdentifier operator float\_number} Example: reference : := TSa\_5 \* 10.3
- *operator* ::= {\* | /} (*note:* the \* is a multiplier, not a wildcard)
   Example operator ::= /
- *float\_number* : := *number* [.*number*] Example: 45

# **TIMEGRP Constraint Statement Syntax**

Use the following syntax for creating EPLD TIMEGRP statements:

#### TIMEGRP="timegrp\_line";

where *timegrp\_line* is composed of the following elements, in addition to those described in the previous section:

• timegrp\_line : := tlabel=derived\_group

Example: mux\_3=Test\_mux\_45:except:ff\_23

- derived\_group : := compound | difference
   Example: mux\_3:Test\_mux\_45
- compound : := group [:group:group ...] Example: mux\_3:Test\_mux\_45
- *difference* : := *compound*:except:*compound* Example: Test\_mux\_45:except:Reg\_4

## **Creating a Constraints File**

You can create a constraints file by using an ascii text editor. Save the file as *file\_name*.CST in your design directory. An example of a constraints file is shown as follows:

```
TIMESPEC="TS02=FROM:FF_1:TO:FF_4=20";
TIMESPEC="TS08=FROM:FFS:TO:PADS=TS05*10";
TIMESPEC="TS59=FROM:G_1A:TO:G_8C=15";
TIMESPEC="TS62=FROM:LATCHES:TO:PADS=25";
TIMESPEC="TS65=FROM:PADS:TO:PADS=18";
TIMESPEC="TS73=FROM:FFS(a*):TO:FFS(b*)=20";
TIMEGRP="many_ffs=ffs1:ffs2";
TIMEGRP="group1=ffs(ctr*)";
TIMEGRP="group2=group1:except:ffs(ctr0)";
TIMEGRP="ff1=FFS(a*)";
```

Figure 4-9 Example .CST File

# **Chapter 5**

# **Timing Analysis**

After you have fitted your design, you can use the Timing Analyzer to find and report the timing of paths through the device. You can select specific paths or general types of paths to examine and you can choose from several report formats.

If you included time specification attributes in your design (also called TimeSpecs or T-Specs), you can use the Timing Analyzer to determine whether the XEPLD fitter was able to meet these specifications.

# **Timing Analysis Procedure**

The typical procedure for using the Timing Analyzer is as follows:

- 1. Make sure the design you want to analyze is the current design in the Design Manager, then open the Timing Analyzer.
- 2. Choose the kind of report you want from the Analyzer menu.
- 3. Use the report window commands to view the report in more detail, save the report, and print the report.
- 4. (Optional) If having all the paths in your design reported is more information than you need, select filters from the Path Filters menu to determine which types of paths will be analyzed and reported. You can "filter out" paths you are not interested in. Then repeat step 2.
- 5. (Optional) Select options from the Options menu to fine-tune the analysis even more. Then repeat step 2.

These steps are described in more detail in the following sections.

# **Opening the Timing Analyzer**

Open the Timing Analyzer by double clicking on the Timing Analysis icon in the Tools subwindow of the main Design Manager window. Figure 5-1 shows the icon.



#### Figure 5-1 Timing Analyzer Icon

The Timing Analysis window appears. The design that is loaded into the Timing Analyzer is the current design established in the Design Manager. To load a different design into the Timing Analyzer, exit to the Design Manager and load a different design from there.

# **Timing Analysis Window Features**

The Timing Analysis window is shown in Figure 5-2.

|              |                 | EPI                  | LD Timing       | Analyzer -     | jcount.vm6   | - | • |
|--------------|-----------------|----------------------|-----------------|----------------|--------------|---|---|
| <u>F</u> ile | <u>A</u> nalyze | <u>P</u> ath Filters | <u>O</u> ptions | <u>W</u> indow | <u>H</u> elp |   |   |
|              | 🞒 ?s 🤗          | ?<br>ALL N?          |                 |                |              |   |   |
|              |                 |                      |                 |                |              |   | + |
|              |                 |                      |                 |                |              |   |   |
|              |                 |                      |                 |                |              |   | ŧ |
| +            |                 |                      |                 |                |              | + |   |
| 1            |                 |                      |                 |                |              |   |   |

#### Figure 5-2 Timing Analysis Window

This Window controls the display of report windows generated by commands on the Analyze menu. Because the report windows can be moved and sized independently of the main Timing Analyzer window, the Cascade and Tile commands arrange report windows below and to the right of the main window rather than within it. However, when you collapse report windows, their icons appear in the main Timing Analyzer window.

# **Generating Reports**

To generate a report, select one of the commands on the Analyze menu; each of these commands generates a different timing report. If you have previously chosen path filters or other options, the report reflects these choices. After a report is generated, it appears in a separate window from which it can be saved and printed.

Double click on an icon in the main window to expand the report window. The selected report can be saved, printed, deleted, or closed. You can also save and print from the main window file menu by selecting the icon.

#### Standard Report Header

All Timing Analyzer reports have a header that summarizes the path filters and options that affect the report. Here is an example header for a Performance Summary report:

Performance Summary Report

```
Device:
            jcount
            XC7336-5PC44
           Timing Report Generator Version 6.0
Program:
            Mon Apr 17 13:54:42 1995
Date:
Timing Analysis Options:
From: CLR CE C $1N5.Q.FFB.REG.Q $1N8.Q.FFB.REG.Q $1N7.Q.FFB.REG.Q
      $1N6.Q.FFB.REG.Q
  To: Q0 Q1 Q2 Q3 $1N5.Q.FFB.D $1N16 $1N5.Q.FFB.RSTF $1N8.Q.FFB.D
      $1N8.Q.FFB.RSTF $1N7.Q.FFB.D $1N7.Q.FFB.RSTF $1N6.Q.FFB.D $1N6.Q.FFB.RSTF
Speed Grade:
                                          -5
Selected Path Types:
External
-----
Pad to Pad -
                                          Pad to pad combinatorial propagation
                                          delay. Paths through PRE/CLR register
                                          inputs are not reported.
Clock Pad to Output Pad -
                                          Clock pad(global or product term
                                          clock) to output pad propagation
                                          delay.
```

| Setup to Clock at Pad -                                                                                         | Setup time of data at PAD to clock at<br>PAD. This parameter is only reported<br>for global clocks and product term<br>clocks driven directly from input<br>pads |
|-----------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Internal                                                                                                        |                                                                                                                                                                  |
| Clock to Setup -                                                                                                | Register to register cycle time.                                                                                                                                 |
| Pad to Setup -                                                                                                  | Data path delay from PAD to register<br>data input. Includes register tSU.                                                                                       |
| Clock to Pad -                                                                                                  | Delay from register clock input to output pad.                                                                                                                   |
| Path Ending at Clock Pin of FFs -                                                                               | Clock path delay from clock<br>pad(global or product term) to<br>register clock input.                                                                           |
| Other Options:<br>Maximum Number of Paths:<br>Maximum Number of Paths per TimeSpec:<br>Report Delays Less Than: | 1000<br>1000<br>1000.0ns                                                                                                                                         |

### Performance to Timespecs Report

In the Performance to Timespecs report, timing is analyzed according to how well it matches the T-Specs you included in your design. Make sure the Report Paths Failing TimeSpec command on the Path Filters menu is ON. The format of this report is exactly the same as that of the Detailed Path Report, except that only paths failing to meet the time specifications assigned to them are listed.

**Note:** The Performance to Timespecs report shows the source and destination for all paths with T-Specs; the filter for sources and destinations does not apply.

#### **Performance Summary Report**

In the Performance Summary report, general indexes of overall performance are reported, for example worst-case pad-to-pad delay, pad-to-setup, clock-to-pad, clock-to-setup, and maximum clock speed. The Select Path Types command partially determines the contents of this report. Here is an example report without the header:

```
Performance Summary:
```

Clock net 'C' path delays:

```
Worst case clock pad to output pad delay :
                                                   4.5ns (1 macrocell levels)
(Includes an external input margin of 0.0ns.)
(Includes an external output margin of 0.0ns.)
Clock Pad 'C' to Output Pad 'Q0'
                                                                 (Fast Clock)
Clock to Setup path delay
                                        :
                                                    5.0ns (1 macrocell levels)
Clock to Q, net '$1N5.Q.FFB.REG.Q' to DFF Setup(D) at '$1N5.Q.FFB.D' (Fast Clock)
Target FF drives output net '$1N5.Q'
Clock to Pad path delay
                                                    3.0ns (1 macrocell levels)
(Includes an external output margin of 0.0ns.)
Clock to Q, net '$1N5.Q.FFB.REG.Q' to Pad 'Q0'
                                                                 (Fast Clock)
Pad to Setup path delay
                                                    8.5ns (0 macrocell levels)
(Includes an external input margin of 0.0ns.)
Pad 'CE' to DFF Setup(D) at '$1N5.Q.FFB.D'
                                                                 (Fast Clock)
Target FF drives output net '$1N5.Q'
                                                   1.5ns (0 macrocell levels)
Pad Ending at Clock Pin path delay
                                        :
(Includes an external input margin of 0.0ns.)
Clock Pad 'C' to DFF Clock Pin at '$1N16'
                                                                  (Fast Clock)
Setup to Clock at the Pad
                                        :
                                                    7.0ns (0 macrocell levels)
Data signal 'CE' to DFF D input Pin at '$1N5.Q.FFB.D'
Clock pad 'C' to DFF Clock Pin at '$1N16'
                                                                 (Fast Clock)
                         Minimum Clock Period: 5.0ns
                    Maximum Internal Clock Speed: 200.0Mhz
                           (Limited by Cycle Time)
               Estimated Maximum External Clock Speed: 142.8Mhz
                    (Limited by Setup to Clock at the Pad)
                                                       Clock Pad to Output Pad Delays(nsec)
\ Clock
          C
Output \-----
         4.5
Q0
01
         4.5
```



### **Detailed Path Report**

In the Detailed Path report, the timing of every path in the design is analyzed in detail, with a breakdown of each segment in each path. The Sort On field of the Report Options command determines the order in which paths are listed.

This report tends to be long, even for fairly simple designs. You may want to use path filters, described in the "Applying Path Filters" section of this chapter, to eliminate report paths not of interest to you.

Here is an example report that has been edited for brevity, without the header:

Report Only Longest Paths between Points: True

| Outpu<br>Logic                                            | t will be sorted by in<br>al Path                                           | creasing path delays.<br>Delay Type                          | De          | lay                                                | Cumulative                                                     |
|-----------------------------------------------------------|-----------------------------------------------------------------------------|--------------------------------------------------------------|-------------|----------------------------------------------------|----------------------------------------------------------------|
| From:<br>Thru:<br>To:                                     | C<br>C/BUF0.OUT<br>\$1N16                                                   | <br>MARGIN<br>FCLK BUFFER + FB.DFF                           | .FCLK:      | 0.0ns<br>0.0ns<br>1.5ns                            | (0.0ns)<br>(0.0ns)<br>(1.5ns)                                  |
| Source<br>Worst<br>From:<br>Thru:<br>To:                  | e clock net: \$1N16<br>case clock delay from<br>\$1N5.Q<br>Q0/OLDNODE<br>Q0 | origin C is 1.5ns<br>FFB.DFF.tCO<br>OUTPUT BUFFER<br>MARGIN  | :<br>:<br>: | 1.0ns<br>2.0ns<br>0.0ns                            | (1.0ns)<br>(3.0ns)<br>(3.0ns)                                  |
| Source<br>Worst<br>From:<br>Thru:<br>To:                  | e clock net: \$1N16<br>case clock delay from<br>\$1N6.Q<br>Q1/OLDNODE<br>Q1 | origin C is 1.5ns<br>FFB.DFF.tCO<br>OUTPUT BUFFER<br>MARGIN  | :<br>:<br>: | 1.0ns<br>2.0ns<br>0.0ns                            | (1.0ns)<br>(3.0ns)<br>(3.0ns)                                  |
| Source<br>Worst<br>From:<br>Thru:<br>To:                  | e clock net: \$1N16<br>case clock delay from<br>\$1N7.Q<br>Q2/OLDNODE<br>Q2 | origin C is 1.5ns<br>FFB.DFF.tCO<br>OUTPUT BUFFER<br>MARGIN  | :<br>:<br>: | 1.0ns<br>2.0ns<br>0.0ns                            | (1.0ns)<br>(3.0ns)<br>(3.0ns)                                  |
| Source<br>Worst<br>From:<br>Thru:<br>To:                  | e clock net: \$1N16<br>case clock delay from<br>\$1N8.Q<br>Q3/OLDNODE<br>Q3 | origin C is 1.5ns<br>FFB.DFF.tCO<br>OUTPUT BUFFER<br>MARGIN  | :<br>:      | 1.0ns<br>2.0ns<br>0.0ns                            | (1.0ns)<br>(3.0ns)<br>(3.0ns)                                  |
| From:<br>Thru:<br>Thru:<br>Thru:<br>Thru:<br>Thru:<br>To: | C<br>C/BUF0.OUT<br>\$1N16<br>\$1N5.Q<br>Q0/OLDNODE<br>O0                    | -<br>MARGIN<br>FCLK BUFFER<br>FFB<br>OUTPUT BUFFER<br>MARGIN | ::          | 0.0ns<br>0.0ns<br>1.5ns<br>1.0ns<br>2.0ns<br>0.0ns | (0.0ns)<br>(0.0ns)<br>(1.5ns)<br>(2.5ns)<br>(4.5ns)<br>(4.5ns) |

| Source | e clock net: \$1N10      | 5        |                    |   |            |          |
|--------|--------------------------|----------|--------------------|---|------------|----------|
| Worst  | case clock delay         | from or: | igin C is 1.5ns    |   |            |          |
| Destin | nation clock net:        | \$1N16   | 2                  |   |            |          |
| Worst  | case clock delay         | from or: | igin C is 1.5ns    |   |            |          |
| Source | e and destination        | clock sl | cew: 0.0ns         |   |            |          |
| From:  | \$1N5.Q.FFB.FBK          |          | -                  | : | 1.0ns      | (1.0ns)  |
| To:    | \$1N5.Q.FFB.D            |          | FFB.DFF.D          | : | 4.0ns      | (5.0ns)  |
|        |                          |          |                    |   |            |          |
| •••    |                          |          |                    |   |            |          |
| Destin | nation clock net:        | \$1N16   |                    |   |            |          |
| Worst  | case clock delay         | from or: | igin C is 1.5ns    |   |            |          |
| From:  | C                        |          | -                  | : | 0.0ns      | (0.0ns)  |
| Thru:  | C/BUF0.OUT               |          | MARGIN             | : | 0.0ns      | (0.0ns)  |
| Thru:  | \$1N16                   |          | FCLK BUFFER        | : | 1.5ns      | (1.5ns)  |
| Thru:  | \$1N5.Q.FFB.FBK          |          | FFB                | : | 1.0ns      | (2.5ns)  |
| To:    | \$1N6.Q.FFB.D            |          | FFB.DFF.D          | : | 4.0ns      | (6.5ns)  |
|        |                          |          |                    |   |            |          |
| •••    |                          |          |                    |   |            |          |
| Destin | nation clock net:        | \$1N16   |                    |   |            |          |
| Worst  | case clock delay         | from or: | igin C is 1.5ns    |   |            |          |
| From:  | C                        |          | -                  | : | 0.0ns      | (0.0ns)  |
| Thru:  | C/BUF0.OUT               |          | MARGIN             | : | 0.0ns      | (0.0ns)  |
| Thru:  | SINI6                    |          | FCLK BUFFER        | : | 1.5ns      | (1.5ns)  |
| Thru:  | SIN7.Q.FFB.FBK           |          | FFB                |   | 1.0ns      | (2.5ns)  |
| 10.    | ŞIN7.Q.FFB.D             |          | FFB.DFF.D          | • | 4.0115     | (0.5115) |
|        |                          |          |                    |   |            |          |
|        | <b>65 D</b>              |          |                    |   | <b>a a</b> |          |
| From:  | CLR                      |          | -                  | : | 0.0ns      | (0.0ns)  |
| Thru.  | CLR/BUFU.OUI             |          | MARGIN             | : | 0.00S      | (0.0 ns) |
| TO.    | SINIZ<br>SING O FFR ROTE |          | TILM T EED DEE G   | : | 6 5ng      | (1.5115) |
| 10.    | JINO.Q.FFD.KSIF          |          | OIM / FFB.DFF.5    | • | 0.5115     | (0.0115) |
| Desti  | nation clock net:        | \$1N16   |                    |   |            |          |
| Worst  | case clock delay         | from or: | igin C is 1.5ns    |   |            |          |
| From:  | CE                       |          | _                  | : | 0.0ns      | (0.0ns)  |
| Thru:  | CE/BUF0.OUT              |          | MARGIN             | : | 0.0ns      | (0.0ns)  |
| Thru:  | SIN20                    |          | INPUT BUFFER       | : | 1.5ns      | (1.5ns)  |
| 10:    | SINC.Q.FFB.D             |          | OIW + F.F.B.DF.F.D | • | /.Uns      | (8.5ns)  |
|        |                          |          |                    |   |            |          |
| Desti  | nation clock net:        | \$1N16   |                    |   |            |          |
| Worst  | case clock delay         | from or: | igin C is 1.5ns    |   |            |          |
| From:  | CE                       |          | -                  | : | 0.0ns      | (0.0ns)  |
| Thru:  | CE/BUF0.OUT              |          | MARGIN             | : | 0.0ns      | (0.0ns)  |
| Thru:  | \$1N20                   |          | INPUT BUFFER       | : | 1.5ns      | (1.5ns)  |
| To:    | \$1N8.Q.FFB.D            |          | UIM + FFB.DFF.D    | : | 7.0ns      | (8.5ns)  |

### **Check for Asynchronous Logic**

The Check for Asynchronous Logic command lists locations of signals that are possibly asynchronous and the product-term clock signals that control them. Two types of paths are considered possibly asynchronous:

• A clock pin with multiple origins, as in the following example:



In this case, the following statement appears in the report:

```
clock pin CLK has multiple origins A, B, C: possible asynchronous.
```

• A clock pin with multiple paths leading to it, as in the following example:



In this case, the following statement appears in the report:

```
clock pin CLK has multiple paths to its origin A: possible asynchronous.
```

### **Show Clocks**

The Show Clocks command lists the clock signals in the design.

# **Show Settings**

The Show Settings command lists the Path Filter and Options settings you chose during this session of the Timing Analyzer.

# **Report Window Commands**

After you select any command on the Analyze menu, the requested report appears in a new window. For example, here is a Performance Summary report window.

```
File
     Edit
           Search
                   Zoom
                          Help
                           Performance Summary Report
            /export/home/ranger/rebeccas/timing/ts3
Design:
Device:
            XC73108-7PQ160
Program:
            EPLD TA VER 1.0
SpeedsFile: model.tim Version 1 Release 1
            Mon Jan 16 16:42:34 1995
Date:
Timing Analysis Options:
From: T1 3 INV T1 3 INV.MC.FFB.REG.Q T3 3.MC.REG.Q T3 3 T2 3 INV
      T2 3 INV.MC.FFB.REG.Q Q2 EX.MC.REG.Q Q2 Q1 EX.MC.REG.Q Q1 Q3 EX.MC.REG.
      Q3 T2_2 CLEAR_EX CLOCK_EX INPUT_EX Q1_EX Q2_EX Q3_EX CLEAR
      CLEAR EX/BUF0. OUT CLOCK CLOCK EX/BUF0. OUT INPUT INPUT EX/BUF0. OUT
      Q1 EX/OLDNODE Q2 EX/OLDNODE Q3 EX/OLDNODE T3 2
  To: INPUT CLEAR CLOCK T1_3_INV. MC. FFB. D T1_3_INV. MC. FFB. SETF T3_3. MC. D
      T3 3.MC.RSTF T2 3 INV.MC.FFB.D T2 3 INV.MC.FFB.SETF Q2 EX.MC.D
```

#### Figure 5-3 Report Window

The Window menu in the main Timing Analyzer window controls the display of report windows generated by commands on the Analyze menu. Because the report windows can be moved and sized independently of the main Timing Analyzer window, the Cascade and Tile commands arrange report windows below and to the right of the main window rather than within it.

However, when you collapse report windows, their icons appear in the main Timing Analyzer window.

Collapsing the main window collapses the report windows as well. Restoring the main window also restores the report windows. Each report window has its own set of menu commands, which allow you to view the report in more detail, save the report, and print the report. The report window commands are as follows:

- File-Save As Opens a file browser window and lets you save the report file.
- File-Print Sends the report to the default printer. No dialog box is presented.
- Edit-Copy Saves the selected text to the clipboard so you can copy it into another text file or document.
- Edit-Select All Allows you to select all the text in the report at once. To copy the entire report, use this command followed by the Copy command.
- Edit-Word Wrap When this option is on (the default), lines too long to fit in the window wrap to the next line. When this option is off, lines do not wrap regardless of length. Turning word wrap off is useful for viewing tables.
- Search-Find Presents a dialog box that allows you to search for text. You can specify case sensitivity or whole word only matching, and you can search forward or backward.
- Search-Find Next Searches for the text you specified last time you used the Find command.
- Zoom-Zoom In Expands the text size and shows a smaller area of the report.
- Zoom-Zoom Out Shrinks the text size and shows a larger area of the report.
- Zoom-Zoom Normal Changes the text to its original size.

To close the report window, select the File-Exit command.
# **Applying Path Filters (Optional)**

The Path Filters menu offers the following choices, which enable you to eliminate paths from the report and examine only the kinds of paths of greatest interest to you. By default, if you do not use any filters, all paths are included in whichever report you choose.

The Options menu commands, which are described in the "Selecting Additional Options" section of this chapter, also refine the contents of the reports you select.

# **Report Paths Failing Timespec**

Use the Report Paths Failing TimeSpec command to view timing information for signals that do not meet your timing specifications. This command includes in the report paths that are slower than the time specification you assigned.

When this command is on, a check appears to the left of the command in the menu. The default setting is off.

# **Report Paths with No Timespec**

Use the Report Paths with No TimeSpec command to view timing information for all signals, including paths having no assigned time specification.

When this command is on, a check appears to the left of the command in the menu. The default setting is On.

### **Ignore Timespecs**

The Ignore TimeSpecs command deletes selected T-Specs from the report. Use this command to filter out signals that are not timing-critical. By default, all T-Specs are included.

When you select this command, the Ignore TimeSpec window appears as shown in Figure 5-4.



#### Figure 5-4 Ignore TimeSpec Window

Follow these steps to delete specific T-Specs from the report:

1. Type a name, partial name, or name with a wildcard in the Filter for Selected Timespecs field to select a subset of the T-Specs in the design. The ? is a single-character wildcard; the \* is a multiple-

character wildcard. Select the Apply button to apply the filter. To select all T-Specs, leave this field blank or select the Reset button followed by the >> button. This filtering step is optional.

**Note:** The Reset button clears the current filter and includes all the T-Specs in the Selected TimeSpec list except the T-Specs you have already moved to the Ignored TimeSpec list.

- To move a T-Specs into the Ignored TimeSpec list, select the T-Specs from the Selected TimeSpec list and select the > button. To move a all T-Specs into the Ignored TimeSpec list, use the >> button.
- 3. To move a T-Specs back into the Selected TimeSpec list (so it is NOT ignored), select the T-Specs from the Ignored TimeSpec list and select the < button. To move all T-Specs back into the Selected TimeSpec list, use the << button.

**Note:** After you move T-Specs to the Ignored TimeSpec list, the T-Specs remain highlighted so you can undo the move with a single mouse click on the < button.

4. When your Selected TimeSpec list and Ignored TimeSpec list are organized as you want them, select the OK button.

### **Select Sources and Select Destinations**

The Select Sources and Select Destinations commands include paths having the sources and destinations you specify in the report. These sources and destinations can be nets, flip-flops, pads, clocks, or macrocells. The following figure shows the source and destination of a typical pad to setup path.



#### Figure 5-5 Source and Destination

By default, all pads and registers are included as sources and destinations. You can add sources or destinations to the included list or select sources or destinations you want to be removed from the included list. When you select this command, the Select Sources or Select Destinations window appears. These two windows have exactly the same functions; the only difference is that Select Sources lists design elements that can be beginnings of paths and Select Destinations lists design elements that can be ends of paths.

**Note:** The Performance to Timespecs report shows the source and destination for all paths with T-Specs; the filter for sources and destinations does not apply.



**Figure 5-6 Select Sources Window** 

Follow these steps:

1. Select the type of source or destination element you are interested in from the Source Element Type or Destination Element Type field at the top of the window. Choices are All, Flip-flops, Pads, Clocks, Nets, or Macrocells. The All option, which is the default, means all pads and flip-flops, not all elements.

**Note:** If you select All, this text appears in the Source Elements or Destination Elements list: \*\*\* All Sources\*\*\* or \*\*\*All Destinations\*\*\*. If you add this text to the Selected Sources or Selected Destinations list using the > button, you cannot add additional elements to the Selected Sources or Selected Destinations list. To add other types of elements, first select the All text in the Selected Sources or Selected Destinations list and click on the < button, then add the elements you want.

 Type a name, partial name, or name with a wildcard in the Filter for Available Elements field to select a subset of the elements in the design to be excluded. The ? is a single-character wildcard; the \* is a multiple-character wildcard. Select the Apply button to apply the filter. To select all elements, leave this field blank or select the Reset button followed by the >> button.

**Note:** The Reset button clears the current filter and includes all the elements in the Available Elements list except the elements you have already moved to the Source Elements or Destination Elements list.

3. The Source Elements or Destination Elements list contains the elements that will be included in the report. To remove an element from this list, select it and select the < button. The element moves to the list on the left.

The > button moves an element from the list on the left back to the Source Elements or Destination Elements list. The >> and << buttons move all elements in one list to the other list.

**Note:** After you move elements to the Source Elements or Destination Elements list, the elements remain highlighted so you can undo the move with a single mouse click on the < button.

4. Select OK when your sources or destinations list is finished.

### **Select Path Types**

The Select Path Types command specifies the types of paths to include in the report, for example, "clock to setup." By default, all path types are listed.

When you select this command, the Select Path Type window appears.

| 🛛 Clock to Setup                           | 🛛 Pad to Pad   |  |  |  |  |  |  |
|--------------------------------------------|----------------|--|--|--|--|--|--|
| 🛛 Clock to Pad (Tco)                       | 🛛 Pad to Setup |  |  |  |  |  |  |
| 🖂 Setup to Clock at The Pad                |                |  |  |  |  |  |  |
| 🖂 Clock Pad to Output Pad                  |                |  |  |  |  |  |  |
| 🔀 Paths Ending at Clock Pins of Flip-Flops |                |  |  |  |  |  |  |
| OK Cancel                                  | Help           |  |  |  |  |  |  |

Figure 5-7 Select Path Type Window

If you wish to eliminate some path types from the report, click on them to remove the X's from their boxes.

The path types are defined as follows:

• Clock to Setup — Register to register cycle time, including clock to output and setup delay.



Figure 5-8 Clock to Setup Path

• Pad to Pad — Combinational pad to pad delay.



#### Figure 5-9 Pad to Pad Path

• Clock to Pad — Delay from the register clock input to the output pad.



#### Figure 5-10 Clock to Pad Path

 Pad to Setup — Data path delay from the pad to the register data input. Includes the register setup time.



#### Figure 5-11 Pad to Setup Path

• Setup to Clock at the Pad — Setup time of data at the pad-to-clock at the pad. This path type includes only global clocks and product term clocks driven directly from input pads. If the data input is signal A and the clock input is signal CLK, the timing calculation for this type of path is as follows:

Max(A to D) - Min(CLK to C)

Max and Min are maximum and minimum propagation delays through the combinational logic.



#### Figure 5-12 Setup to Clock at the Pad Path

• Clock Pad to Output Pad — Clock pad to output pad propagation delay. The clock can be a global or product term clock.



#### Figure 5-13 Clock Pad to Output Pad Path

• Paths Ending at Clock Pins of Flip-Flops — Delay from clock pad to register clock input. The clock can be a global or product term clock.



#### Figure 5-14 Path Ending at the Clock Pin of a Flip-Flop

#### **Include or Exclude Paths with Nets**

The Include and Exclude Paths with Nets commands are not opposites and can be used together.

The Include Paths with Nets command includes in the report only the paths that pass through at least one of the nets you specify; all other paths are excluded. By default all nets are included, so all paths are included in the report.

The Exclude Paths with Nets command excludes from the report the paths that pass through at least one of the nets you specify. Paths not

passing through any of the selected nets are not necessarily included, however. By default no nets are excluded.

You can use both of these commands together. First use Include Paths with Nets to select the set of paths you are interested in, then use Exclude Paths with Nets to refine this set of paths. A path that passes through both an included net and an excluded net is excluded.

When you select one of these commands, the Include Paths with Nets or Exclude Paths with Nets window appears. These two windows have the same layout of lists and buttons. You select paths to include or exclude in the same way; the only difference between these two commands is the results.



Figure 5-15 Include Path with Nets Window

Follow these steps:

1. Type a name, partial name, or name with a wildcard in the Filter for Nets not to be selected field to select a subset of the nets in the design. The ? is a single-character wildcard; the \* is a multiplecharacter wildcard. Select the Apply button to apply the filter. To select all nets, leave this field blank or select the Reset button followed by the > button.

**Note:** The Reset button clears the current filter and includes all the elements in the Nets not selected list except the elements you have already moved to the Selected Nets list.

2. Select nets from the Nets not selected list and move them to the Selected Nets list by selecting the > button.

To move a net back to the Nets not selected list, use the < button. The >> and << buttons move all nets in a list to the other list.

**Note:** After you move elements to the Nets not selected or Selected Nets list, the elements remain highlighted so you can undo the move with a single mouse click on the < button.

3. Select OK when your list of nets is as you want it.

# **Break Logic Loops**

The Break Logic Loops command specifies feedback loops to be broken in the report. When you select this command, the Break Logic Loops window appears.

| Filter for Available Nets                                                        |                 |
|----------------------------------------------------------------------------------|-----------------|
|                                                                                  | Apply           |
| Available Nets                                                                   | Selected Nets   |
| CLEAR<br>CLEAR_EX<br>CLEAR_EX/BUF0.OUT<br>CLOCK<br>CLOCK_EX<br>CLOCK_EX/BUF0.OUT |                 |
| Selected 0 of 23                                                                 | Selected 0 of 0 |
| Break Connections for Net to Macrocells:                                         |                 |
|                                                                                  | *               |
|                                                                                  | •               |
| •                                                                                | •               |
| Selected                                                                         | 0 of 0          |
| OK Cancel                                                                        | Help            |

#### Figure 5-16 Break Logic Loops Window

Follow these steps:

 Type a name, partial name, or name with a wildcard in the Filter for Available Nets field to select a subset of the nets in the design. The ? is a single-character wildcard; the \* is a multiple-character wildcard. Select the Apply button to apply the filter. To select all nets, leave this field blank or select the Reset button followed by the > button. **Note:** The Reset button clears the current filter and includes all the elements in the Nets not selected list except the elements you have already moved to the Selected Nets list.

2. Select nets from the Available Nets list and move them to the Selected Nets list by selecting the > button.

To move a net back to the Nets not selected list, use the < button. The >> and << buttons move all nets in a list to the other list.

**Note:** After you move elements to the Nets not selected or Selected Nets list, the elements remain highlighted so you can undo the move with a single mouse click on the < button.

- 3. After you select a net, the macrocells fed by that net appear in the Break Connections for Net to Macrocells list with check marks on the left. Select the macrocell(s) to which the net does not feed back to remove the checks. If you remove all macrocells, the net is removed from the Selected Nets list.
- 4. Select another net and repeat the previous step.
- 5. Select OK when your list of nets and macrocells indicating feedback loops is as you want it.

**Note:** To specify a feedback path for a net, you must specify (leave checked) only the macrocell(s) to which the net feeds back. If you specify all macrocells fed by the net, all load pins of that net are broken, including those that are not feedback paths. It is a good idea to display your design file in another window so you can see the feedback paths and macrocells clearly.

For example, in the following figure, A is a signal that feeds back to Macrocell 1. If you break all the macrocells fed by signal A, the load pin of A that goes to Macrocell 2 is broken in addition to the signal that goes to Macrocell 1.



Figure 5-17 Break Logic Loops Example

# **Reset Path Filters**

The Reset Path Filters command restores default path filters. In general, all paths are included in the report by default. More specifically, default filters are as follows:

- Report Paths Failing TimeSpec is OFF.
- Report Paths with No TimeSpec is OFF.
- Ignore TimeSpecs has no T-Specs selected, which means all paths are included.
- Select Sources includes all pads and flip flops.
- Select Destinations includes all pads and flip flops.
- Select Path Types includes all path types.
- Include Paths with Nets includes all nets.
- Exclude Paths with Nets includes no nets.
- Break Logic Loops includes no feedback paths, which means all feedback paths are included.

# **Selecting Additional Options (Optional)**

The commands on the Options menu allow you to fine-tune your analysis.

# Set Speed Grade

The Set Speed Grade command re-evaluates the timing based on a selected speed grade. When you select this command, the Set Speed Grade window appears.



#### Figure 5-18 Set Speed Grade Window

The speed grades you can select are different for each XC7000 device.

# Set Delay Margins for I/O

The Set Delay Margins for I/O command adds the specified delays to pads to simulate delays due to lines on the PC board.

When you select this command, the Set Delay Margins for I/O window appears.



#### Figure 5-19 Set Delay Margins for I/O Window

Follow these steps:

- 1. Type a name, partial name, or name with a wildcard in the Filter for Pad Names field to select a subset of the pads in the design. The ? is a single-character wildcard; the \* is a multiple-character wildcard. Select the Apply button to apply the filter. To select all pads, leave this field blank or select the Reset button.
- 2. In the Margin field, type the number of nanoseconds additional delay you wish to add to the selected pads. If you enter an invalid value such as a negative number, an error message is displayed.
- 3. Select pads from the Pads list and transfer them to the Defined Margins list by selecting the Define > button. The delay you specified in step 2 applies to the pads in the Defined Margins list.

To remove a margin from a pad, select the pad in the Defined Margins list and then select the < Undefine button. The Define All >> and << Undefine All buttons transfer all pads in one list to the other list.

- 4. To apply a different delay to a different set of pads, repeat steps 1 through 3 with a different value in the Margin field.
- 5. Select OK when you have finished assigning delays to pads.

The following figure shows input, output, and interchip delays.



Interchip delays:

CHIP1 to CHIP2 = MO1 + MI2 CHIP1 to CHIP3 = MO1 + MI3

#### Figure 5-20 Margin Delays

#### **Report Options**

The Report Options command gives you additional filters for report information. When you select this command, the Report Options window appears, with the default values shown. Blank fields indicate that an infinite number are allowed. If you enter an invalid value such as a negative number, a warning is displayed.

| Maximum Number                           | Maximum Number of Paths: |      |  |  |  |  |  |  |  |
|------------------------------------------|--------------------------|------|--|--|--|--|--|--|--|
| Maximum No. of F                         |                          |      |  |  |  |  |  |  |  |
| Report Delays Les                        | ns                       |      |  |  |  |  |  |  |  |
| Report Delays Gra                        | 0 ns                     |      |  |  |  |  |  |  |  |
| Sort On:                                 | <u>+</u>                 |      |  |  |  |  |  |  |  |
| Report Only Longest Paths Between Points |                          |      |  |  |  |  |  |  |  |
| 🗌 Wide Report                            |                          |      |  |  |  |  |  |  |  |
| ОКСС                                     | ancel                    | Help |  |  |  |  |  |  |  |

#### Figure 5-21 Report Options Window

The options are:

- *Maximum Number of Paths* The maximum number of paths that will appear in the report.
- *Maximum No. of Paths per TimeSpec* The maximum number of paths that will be reported for a specified T-Spec.
- *Report Delays Less Than* Only those delays that are shorter than this specification are reported.
- *Report Delays Greater Than* Only those delays that are longer than this specification are reported.
- *Sort On* Determines how paths are listed in the report as follows:
  - Ascending Delay Lists paths in order of their delay, with the shortest delay first and the longest last.
  - Descending Delay Lists paths in order of their delay, with the longest delay first and the shortest last.

- Source Net Lists paths alphabetically by the net at which they start.
- Destination Net Lists paths alphabetically by the net at which they end.
- Source Clock Net Lists paths alphabetically by the clock net at which they start.
- Destination Clock Net Lists paths alphabetically by the clock net at which they end.

# **Chapter 6**

# **Report Formats**

The XEPLD software creates a variety of report files in the design directory that provide you with information about the state of your design. The reports described in this chapter are as follows:

- Resource report (*design\_name*.res).
- Mapping report (*design\_name.map*).
- Pin Out report (*design\_name*.pin).
- Fitting report (*design\_name.par*).
- Timing Report (*design\_name.tim*).
- Timespec Report (*design\_name*.tsp).
- PLUSASM Assembler Log report (pld\_name.lga).
- EQN file (*design\_name*.eqn).
- Log file (*design\_name*.log).

The report formats are described in the following sections.

# Viewing Reports

You can use the Report Browser to view most reports. You can view those reports which are not displayed in the Report Browser with any ASCII text editor.

To use the Report Browser, follow these steps:

1. Select the Report Browser command from the Utilities menu. The Report Browser window appears as shown in Figure 6-1.



#### Figure 6-1 Report Browser

The yellow stars on the report icons indicate that the reports have not yet been read. After you open the report, the yellow star 5disappears.

2. Double click on the icon for the report of your choice. The report appears in its own window. Figure 6-2 shows an example report window.

|                                                     | Mapping Re                      | port                       |                       |                |
|-----------------------------------------------------|---------------------------------|----------------------------|-----------------------|----------------|
| File Edit Search Zoom Help                          | J                               |                            |                       |                |
| XEPLD, Version PRE6.0.0A                            | Mapping Repor                   | :t                         | Xilinx In             | nc.            |
| Circuit name: jcount<br>Target Device: XC7336-5PC44 |                                 | Integrated:                | 8-15-95,              | 2:36PM         |
| Function Block 1                                    | Fast inputs –<br>Total inputs – | 0/12 Shared<br>0/24 Macrod | l pterms –<br>cells – | - 0/0<br>- 0/9 |
| Function                                            |                                 | Macrocell                  | Pkg                   | Pin            |
| Name                                                |                                 | Location                   | Pin                   | Use            |
|                                                     |                                 |                            |                       |                |
| •                                                   |                                 | FB1-1                      | 7                     | · ·            |
| •                                                   |                                 | FB1-2                      | 8                     | •              |
| •                                                   |                                 | FB1-3                      | 9                     |                |
| •                                                   |                                 | FB1-4                      | 11                    | •              |
| ·                                                   |                                 | FB1-5                      | 12                    | · [_           |
|                                                     |                                 | FB1-6                      | 13                    | 17             |

#### Figure 6-2 Example Report Window

- 3. Use the commands in the report window to examine your report. The commands are:
  - File-Save As Opens a file browser window and lets you save the report file.
  - File-Print Sends the report to the default printer. No dialog box is presented.
  - Edit-Copy Saves the selected text to the clipboard so you can copy it into another text file or document.
  - Edit-Select All Allows you to select all the text in the report at once. To copy the entire report, use this command followed by the Copy command.
  - Edit-Word Wrap When this option is on (the default), lines too long to fit in the window wrap to the next line. When this option is off, lines do not wrap regardless of length. Turning word wrap off is useful for viewing tables.
  - Search-Find Presents a dialog box that allows you to search for text. You can specify case sensitivity or whole word only matching, and you can search forward or backward.
  - Search-Find Next Searches for the text you specified last time you used the Find command.
  - Zoom-Zoom In Expands the text size and shows a smaller area of the report.
  - Zoom-Zoom Out Shrinks the text size and shows a larger area of the report.
  - Zoom-Zoom Normal Changes the text to its original size.
- 4. To close the report window, select the File-Exit command.

# The Resource Report

The Resource report (*design\_name*.res) is the first report you should examine to determine the results of the fitting process. This report lists the used and remaining numbers of Function Blocks, Macrocells, and pins of each type.

## **Logic Resources**

The Logic Resources section shows the number of used and remaining Function Blocks and Macrocells.

## **Required Pin Resources**

The Required column of the Pin Resources section shows the number of input, output (excluding global control/output), I/O, FastClk, FOE, and CE pins required by the design.

## **Used Pin Resources**

The Used columns show how many of each type of physical device pin are occupied to satisfy the I/O signals in your design; note that output-only or input-only signals in your design may occupy I/O pins on the device.

## **Remaining Pin Resources**

The Remaining columns show how many pins are still available on the device.

### **Fast Inputs and Outputs**

The Fast Input/Fast Output section lists how many fast inputs and fast outputs the design requires and how many of each are available on the device.

# **Example Resource Report**

The following is a resource report example.

| XEPLD, Version 5.0                                     | Xilinx Inc.                  |
|--------------------------------------------------------|------------------------------|
|                                                        | Resource Report              |
| Circuit name: UARTPALC<br>Target Device: XC7354-10PC68 | Integrated: 11-10-93, 1:37PM |
| LOGIC RESOURCES                                        |                              |

|                 | Used | Remaining |
|-----------------|------|-----------|
| Function Blocks | 4    | 2         |
| Macrocells      | 30   | 24        |

| Туре    | Required | dRemaining |   |     |      |     |     |     |   |   |     |      |     |     |     |
|---------|----------|------------|---|-----|------|-----|-----|-----|---|---|-----|------|-----|-----|-----|
|         |          | I          | 0 | I/O | Fclk | Foe | Cen | Tot | I | 0 | I/O | Fclk | Foe | Cen | Tot |
| Inputs  | 3        | 3          |   | 0   |      |     |     | 3   | 5 |   | 34  |      |     |     | 39  |
| Outputs | 12       |            | 0 | 8   | 0    | 2   | 2   | 12  |   | 0 | 34  | 2    | 0   | 0   | 36  |
| I/Os    | 0        |            |   | 0   |      |     |     | 0   |   |   | 34  |      |     |     | 34  |
| Fclks   | 1        |            |   |     | 1    |     |     | 1   |   |   |     | 2    |     |     | 2   |
| Foes    | 0        |            |   |     |      | 0   |     | 0   |   |   |     |      | 0   |     | 0   |
| Cens    | 0        |            |   |     |      |     | 0   | 0   |   |   |     |      |     | 0   | 0   |
|         |          |            |   |     |      |     |     |     |   |   |     |      |     |     |     |
|         | 16       | 3          | 0 | 8   | 1    | 2   | 2   | 16  |   |   |     |      |     |     |     |

PIN RESOURCES:

Note: The design requires 0 pins with Fast Input capability. This device has 11 pins with Fast Input capability.

The design requires 0 pins with Fast Output capability.

This device has 0 FO and 15 I/FO remaining from original 0 FO and 18 I/FO.

End of Resource Report

# The Mapping Report

The Mapping report (*design\_name.*map) lists the contents of all the macrocells and Function Blocks in the target device. For each Function Block in the device, a header area lists the total number of FastInputs, total inputs, shared product terms, and macrocells used by the design, and the total number available for the Function Block. Beneath each header is a list indicating how each macrocell in the Function Block is used. The list contains the following columns and sections.

#### **Function Name**

This column shows the names of the signals in the design. For a behavioral design, the function name is the signal name.

For a schematic design, the function name is in the following format:

instance\_name:pin\_name

The instance name is the internal component name. The pin name is the name of the signal that the component pin drives.

# **Macrocell Location**

This column shows the Function Block and macrocell addresses where the component output pins or equation output signals are placed. The format of this column is: FB *function\_block – macrocell*. For example, FB4-3 signifies Function Block 4, macrocell 3.

If you have specified low power on some macrocells, an L will appear on these macrocells in this report.

If a macrocell is using the macrocell carry from the previous macrocell, a C will appear on the macrocell in this report.

# Pkg Pin

This column shows the pin numbers of the device output or I/O pins that can be driven by the macrocells. A dot in this column signifies that the macrocell is buried and cannot drive a device pin.

# Pin Use

This column shows how the corresponding device pins are used by the design (I, O, I/O, or dot). An "I" indicates that the pin is not used for macrocell output but is used by an input port in the design to receive some other type of signal.

# Power Estimation (7300 Family Only)

At the end of this report is an estimate of the power consumption for low power and high power settings.

- The MCHP value is the number of used macrocells in used Function Blocks not designated as low power.
- The MCLP value is the number of used macrocells designated as low power plus the number of unused macrocells in used function blocks.
- Macrocells in unused Function Blocks do not consume power; therefore they are not counted in the power estimation calculation.

For more details about the power estimation calculation, see the Xilinx EPLD data sheets.

# **Example Mapping Report**

The following is a mapping report example.

| XEPLD, V                                                            | <i>V</i> ersion                                                       | 5.0                                                                                                           | Manning                                                                                               | Penc                                       | ort                                                                           |                    | Xilinx                                          | In  | с.                |
|---------------------------------------------------------------------|-----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|--------------------------------------------|-------------------------------------------------------------------------------|--------------------|-------------------------------------------------|-----|-------------------|
| Circuit<br>Target I                                                 | : name:<br>Device:                                                    | UARTPALC<br>XC7354-10PC68                                                                                     | марринд г                                                                                             | cept                                       | Integrat                                                                      | ed: 11             | L- 5-93,                                        | 12: | 23PM              |
| Function                                                            | ı Block                                                               | 1                                                                                                             | Fast inputs<br>Total inputs                                                                           | -<br>- 1                                   | 0/12<br>.0/24                                                                 | Share<br>Macro     | d pterms<br>cells                               | -   | 0/0<br>3/9        |
| Function<br>Name                                                    | ı<br>-                                                                |                                                                                                               |                                                                                                       |                                            | Macroc<br>Locati                                                              | ell<br>on          | Pkg<br>Pin<br>                                  |     | Pin<br>Use<br>    |
| C2<br>START<br>PAR                                                  |                                                                       |                                                                                                               |                                                                                                       |                                            | FB1-1<br>FB1-2<br>FB1-3<br>FB1-4                                              |                    | 4<br>12<br>13<br>15                             |     | •<br>•<br>•       |
| •<br>•<br>•                                                         |                                                                       |                                                                                                               |                                                                                                       |                                            | FB1-5<br>FB1-6<br>FB1-7                                                       |                    | 17<br>19<br>21                                  |     |                   |
| ·<br>·<br>· · ·<br>Function                                         | ı Block                                                               | 6                                                                                                             | Fast inputs                                                                                           | _                                          | FB1-8<br>FB1-9                                                                | Share              | 22<br>23<br>d pterms                            | _   | 1/12              |
| Function<br>Name                                                    | l                                                                     |                                                                                                               | UIM inputs                                                                                            | - 1                                        | .5/21<br>Macroc<br>Locati                                                     | Macro<br>ell<br>on | cells<br>Pkg<br>Pin                             | -   | 9/9<br>Pin<br>Use |
| BITCLK<br>D4<br>D3<br>DOUT2<br>BYTECLK<br>D2<br>C0<br>C1<br>C5      | -                                                                     |                                                                                                               |                                                                                                       |                                            | FB6-1<br>FB6-2<br>FB6-3<br>FB6-4<br>FB6-5<br>FB6-6<br>FB6-7<br>FB6-8<br>FB6-9 |                    | 27<br>28<br>8<br>9<br>10<br>29<br>6<br>24<br>26 |     | I<br>O            |
| Power es<br>MCLP rep<br>MCHP rep<br>Macroce:<br>MCLP and<br>Consult | stimation<br>presents<br>presents<br>lls in to<br>d MCHP a<br>the pro | on parameters:<br>s macrocells ir<br>s macrocells ir<br>unused functior<br>are used to est<br>oper data sheet | MCLP = 6, M<br>1 low power mo<br>1 high power m<br>1 blocks are r<br>2 imate chip po<br>2 for this ca | ICHE<br>ode<br>node<br>not<br>ower<br>alcu | e = 30.<br>and<br>e.<br>conside:<br>consump<br>alation.                       | red.<br>ption.     |                                                 |     |                   |

End of Mapping Report

# **The Pinout Report**

The Pinout report (*design\_name*.pin) lists all pins on the target device, how they are used, and the names of their associated signals.

# Pkg Pin

This column shows all the pin numbers of the target EPLD device, in numerical order, or in alphanumeric order in the case of BPGA/PGA packages.

# Pin Type

This column shows whether the pin is physically input-only (I), output-only (O), bidirectional (I/O), power (VCC, VSS), or special-purpose (MR, CLK, CEN, FOE).

## Pin Use

This column shows how the pin is used in your design (I, O, I/O, and so on; see "Pin Use Legend"). For unused input and I/O pins, this column lists "tie" to remind you to tie the unused inputs to ground on your board. "NC" is shown for unused output-only pins indicating the pin should be left unconnected. If you select the "drive unused I/O pins" implementation option (in the default template), an (O) appears in this column whenever an instance is mapped to the macrocell but the output is not used.

### **Pin Name**

This column shows the name of the external signal mapped to the pin.

# **Pin Use Legend**

This section lists the codes for the types of pins shown in the Pin Use column.

#### **Example Pinout Report**

The following is a pinout report example.

XEPLD, Version 5.0 Xilinx Inc. Pin-List Report Circuit name: UARTPALC Target Device: XC7354-10PC68 Integrated: 11- 5-93, 12:23PM Pkg Pin Pin Pin Pin Type Use Name \_\_\_\_ \_\_\_\_ \_ \_ \_ \_ \_ \_ 1 MR 2 tie (unused) I 3 I tie (unused) 4 I/O tie (unused) 5 I tie (unused) 6 I/O tie (unused) 7 VSS 8 CLK I X4CLK DOUT2 9 CLK 0 10 CLK tie (unused) . . . 58 I/O tie (unused) 59 VCC 60 CEN DOUT1 0

| 61 | CEN | 0   | DOUT0    |
|----|-----|-----|----------|
| 62 | FOE | 0   | FRAMING  |
| 63 | VCC |     |          |
| 64 | FOE | 0   | PARITY   |
| 65 | I   | I   | RD       |
| 66 | I/O | tie | (unused) |
| 67 | I   | I   | CS       |
| 68 | I   | tie | (unused) |

Pin Use Legend:

| I     | - | input                                 |
|-------|---|---------------------------------------|
| 0     | - | output                                |
| I/O   | - | input/output                          |
| I-L   | - | input uses latch                      |
| I-R   | - | input uses register                   |
| I/0-L | - | input/output uses latch               |
| I/O-R | - | input/output uses register            |
| NC    | - | not connected/not available           |
| tie   | - | unused pin must be tied to VCC or GND |
| (0)   | - | unused pin attached to used macrocell |
|       |   |                                       |

End of Pin-List Report

# **The Fitting Report**

The Fitting report (*design\_name*.par) shows the allocation of Function Block resources. This report helps you to understand how the resources available on the device were filled by the equations in your design. It can provide useful information for optimizing or modifying your design.

The Fitting report lists all partitions created to implement the design, and for each partition lists the outputs and Function Block resources. It also shows the input signals used by each partition and each output. Use this report when trying to increase the design density or when modifying a design with a frozen pinout.

## Summary

The summary contains information that applies to all partitions.

#### Part Name

Partition names are Function Block names. If the number of partitions in the design exceeds the number of Function Blocks in the device, the extra partitions will be named OVERFLOW\_*n*, starting with OVERFLOW\_0.

If you see extra partitions even though your design has fewer partitions than the device, it means some of the partitions in your design cannot use the available function blocks. For example, a partition that requires output pins cannot use a Function Block that has no pins.

#### Number of Outputs

This column shows the number of macrocells used in the partition.

### **Number of Input Lines Used**

This column shows the combined number of pin and UIM inputs going into the partition. Fast Function Blocks allow up to 24 inputs. High Density Function Blocks allow up to 21 inputs.

#### **Signal Inputs**

This column shows the number of inputs that would be necessary if no UIM ANDing were performed.

#### Number of Shared Pt

This column shows the combined number of shared product terms used in the partition. High Density Function Blocks have 12 shared product terms available. Fast Function Blocks have none.

## O/IO Used

This column shows output pins and I/O pins used by each partition.

## O/IO Avail

This column shows the total number of output pins and I/O pins available to each partition. The partitioner only counts usable outputs after considering pin assignment and control pin assignment. If you use a FastCLK signal as a control input, you cannot use the attached macrocell for an output pin. If you assign an input signal to an I/O pin, you cannot use the attached macrocell for an output pin.

#### Size Factor

This column estimates the Function Block resources used (from 0 to 9) based on the number of inputs, outputs, and shared product terms.

# Inputs Used by Each Partition

This cross-reference table identifies the specific inputs feeding into each partition. Indexing numbers (top and bottom) for the inputs are listed at the end of the report. The Xs are inputs entering the function via an input line; the @s are ANDed UIM inputs.

# **Partition Listing**

There is one partition listing for each partition in the design. Each listing contains information that applies to one partition only.

### Signals Used

This list displays all the pin or UIM inputs to the partition.

#### Anded UIM Inputs Used

This list displays all UIM equations that are inputs to the partition.

#### Inputs Used by Each Output Table

This cross reference table identifies the specific inputs used by each output macrocell in the equation file. The indexing numbers for inputs are defined in the input name list at the end of the report.

#### MC No

This column shows the macrocell number of the Function Block.

#### **Output Name**

This column identifies the output signal name mapped to the corresponding macrocell.

### Pin Req

This column indicates that the output requires no pin ( - ), an output pin ( O ), or an I/O pin ( I/O ).

### Pin Avl

This column indicates that the pin available to the output is no pin (-), an output pin (O), an I/O pin (I/O), a FastCLK pin (FCLK), or a Fast Output Enable pin (FOE).

#### Sh Pt

This column indicates the combined number of shared D1 and D2 product terms used by each output (whether or not any of the product terms are actually shared with any other output).

# **Input Listing**

The names of all UIM inputs in the design appear in this list. At the end are all the UIM equations. The numbers correspond to the columns of the "Inputs Used" tables.

# **Example Fitting Report**

The following is a fitting report example.

| XEI | PLD, Vers                               | ion 6.0 |       |       |       |                              |          |            | X        | ilinx 1 | Inc.    |
|-----|-----------------------------------------|---------|-------|-------|-------|------------------------------|----------|------------|----------|---------|---------|
|     |                                         |         |       |       | Par   | rtitioning                   | Report   |            |          |         |         |
| C   | ircuit nam                              | ne: UAR | [PAL  | 2     |       |                              |          |            |          |         |         |
| Tai | get Devi                                | ce: XC7 | 354-3 | 10PC6 | 58    |                              | Int      | egra       | ted: 11- | 5-93,   | 12:23PM |
| Par | ct                                      | # of    | #     | of I  | Input | t Signal                     | # of     |            | 0/10     | 0/10    | Size    |
| Nar | ne                                      | Outputs | 5 L:  | ines  | Used  | d Inputs                     | Shared   | Pt.        | Rea      | Avail   | Factor  |
| FR  | 1                                       | 3       |       | 10    |       | 10                           | 0        |            | 0/0      | 0/9     | 4       |
| FR' | 2                                       | 0       |       | -0    |       | 10                           | 0        |            | 0/0      | 0/9     | 0       |
| FR' | 2                                       | 9       |       | 19    |       | 19                           | 0        |            | 6/0      | 4/3     | 9       |
| FB. | 1                                       | g       |       | 15    |       | 15                           | 0        |            | 5/0      | 0/6     | q       |
| ססי | -                                       | 0       |       | 10    |       | 10                           | 0        |            | 0/0      | 0/0     | 0       |
| FD. | 5                                       | 0       |       | 15    |       | 16                           | 1        |            | 1/0      | 2/6     | 0       |
| гы  | 5                                       | 9       |       | 1.2   |       | 10                           | T        |            | 1/0      | 2/0     | 9       |
|     |                                         | 30      |       |       |       |                              |          |            | 12/0     | 6/42    | 31      |
|     |                                         |         |       |       |       |                              |          |            |          |         |         |
| Par | ct                                      |         |       |       |       | Inputs Us                    | ed by Ea | ach P      | artition |         |         |
| Nar | ne                                      |         |       |       |       |                              |          |            |          |         |         |
|     |                                         |         |       |       |       | 1                            | +        | 2          | +3       |         |         |
| FB. | L                                       |         |       |       |       | XX.                          | XX       | XXXXX      | ХХ       |         |         |
| FB2 | 2                                       |         |       |       |       |                              |          |            |          |         |         |
| FB. | 3                                       |         |       |       |       | x.xxxxxxx                    | ххх      | XXXX       | XXX.     |         |         |
| FB4 | 1                                       |         |       |       |       | xxx.                         |          | xxxx.      | X.XX     |         |         |
| FB! | 5                                       |         |       |       |       |                              |          |            |          |         |         |
| FB  | 5                                       |         |       |       |       | xxxx.                        | XXXXX    | XXXX       | X.X.     |         |         |
|     |                                         |         |       |       |       | 1                            | +        | 2          | +3       |         |         |
|     |                                         |         |       |       |       |                              |          |            |          |         |         |
| ++- | +++++++++++++++++++++++++++++++++++++++ | +++++++ | ++++  | ++++- | ++++  | +++ FB1 +                    | ++++++   | +++++      | ++++++++ | +++++   | +++++   |
|     |                                         |         |       | 10.   | Sigi  | nais Used:                   | 0.0.     | <b>a F</b> |          |         |         |
| -   | L: SDIN                                 |         |       | 19:   | C2    |                              | 22:      | C5         | _        |         |         |
|     | 9: BITCLK                               |         |       | 20:   | C3    |                              | 23:      | STAR       | 1        |         |         |
| T   | /: C0                                   |         |       | 21:   | C4    |                              | 24:      | PAR        |          |         |         |
| Τł  | 3: CI                                   |         |       |       |       |                              |          |            |          |         |         |
| MC  | Output                                  | 1       | Pin   | Pin   | Sh    |                              |          |            |          |         |         |
| No  | Name                                    | Ι       | Req   | Avl   | Pt    |                              |          |            |          |         |         |
|     |                                         |         |       |       |       | 1                            | +        | 2          | +3       |         |         |
| 1   | C2                                      |         | -     | I/O   | 0     | ·<br>• • • • • • • • • • • • | XX       | κx         | х        |         |         |
| 2   | START                                   |         | -     | I/O   | 0     | х                            | XX       | XXXXX      | х        |         |         |
| 3   | PAR                                     |         | -     | I/O   | 0     | хх.                          |          |            | хх       |         |         |
| 4   | Unused                                  |         |       | I/O   |       |                              |          |            |          |         |         |
| 5   | Unused                                  |         |       | I/O   |       |                              |          |            |          |         |         |
| 6   | Unused                                  |         |       | I/0   |       |                              |          |            |          |         |         |
| 7   | Unused                                  |         |       | I/0   |       |                              |          |            |          |         |         |
| 8   | Unused                                  |         |       | T/0   |       |                              |          |            |          |         |         |
| 9   | Unused                                  |         |       | I/0   |       |                              |          |            |          |         |         |
| -   |                                         |         |       | _, 0  |       | 1                            | +        | 2          | +3       |         |         |

. . .

Signals Used: 3: RD 12: D2 20: C3 4: CS 13: D3 21: C4 17: C0 22: C5 8: READY 9: BITCLK 18: C1 23: START 11: D1 19: C2 25: BYTECLK MC Output Pin Pin Sh No Name Req Avl Ρt |-----3 1 BITCLK \_ I/O 0 .....XX....X. 2 D4 I/O 0 ....X...X.... 3 D3 \_ FCLK 0 .....X..X........ ..xx.....x....x. 4 DOUT2 FCLK 0 0 5 BYTECLK FCLK 0 .....x....xxxxxxx.... \_ .....X.X..... I/O 0 б D2 \_ 7 C0 I/O 0 ....X..... \_ 8 C1 I/O 0 .....XX....XX.... \_ 9 C5 I/O 1 .....XXXXXXX... \_ |----+----3 All outputs placed in a partition. In Input Name No SDIN 1 2 X4CLK 3 RD 4 CS FRAMING 5 б PARITY 7 OVERUN READY 8 9 BITCLK 10 D0 . . . D6 16 17 C0 . . . 22 C5 23 START 24 PAR 25 BYTECLK 26 D7

End of Partitioning Report

# **The Timing Report**

Use this report (*design\_name*.tim) to verify your design timing. This report shows the calculated worst-case timing based on the physical implementation of your design. General indexes of overall performance are reported; for example, worst-case pad-to-pad delay, pad to setup, clock to pad, clock to setup, and maximum clock speed. This report is the same as the Performance Summary report generated by the EPLD timing analyzer.

# **Example Timing Report**

The following is a timing report example.

```
Performance Summary Report
                          /export/home/ranger/rebeccas/timing/allpaths
Design:
Device:
           XC73144-7PQ160
Program: EPLD_TA VER 1.0
SpeedsFile: model.tim Version 1 Release 1
          Thu Feb 2 13:48:32 1995
Date:
Timing Analysis Options:
From: All
 To: All
Speed Grade
                                          : -7
Selected Path Types
                                          : Clock to Setup
                                            Pad to Pad
                                            Clock to Pad
                                            Pad to Setup
                                            Setup to Clock at Pad
                                            Clock Pad to Output Pad
                                            Path Ending at Clock Pin of FFs
Other Options:
Maximum Number of Paths
                                          : 1000
Maximum Number of Paths per TimeSpec
                                          : 0
Report Delays Less Than
                                          : 100.0ns
Report Delays Greater Than
                                          : 0.0ns
Performance Summary:
                                    : 31.8ns (4 macrocell levels)
Worst case Pad to Pad path delay
(Includes an external input margin of 0.0ns.)
```

(Includes an external output margin of 0.0ns.) Pad 'CAR2' to Pad 'OUT3.OUT.OUT' Worst case clock pad to output pad delay : 23.0ns (2 macrocell levels) (Includes an external input margin of 0.0ns.) (Includes an external output margin of 0.0ns.) Clock Pad 'PCLK' to Output Pad 'OUT2.OUT.OUT' Clock net 'PCLK' path delays: Clock to Setup path delay : 12.0ns (1 macrocell levels) Clock to Q, net 'REG3.MC.REG.Q' to DFF Setup(D) at 'OUT2.MC.ALU.F' Target FF drives output net 'OUT2.MC.Q' : 5.5ns (1 macrocell levels) Clock to Pad path delay (Includes an external output margin of 0.0ns.) Clock to Q, net 'OUT2.MC.REG.Q' to Pad 'OUT2.OUT.OUT' Pad to Setup path delay : 29.5ns (2 macrocell levels) (Includes an external input margin of 0.0ns.) Pad 'PCLK' to DFF Setup(D) at 'OUT2.MC.ALU.F' Target FF drives output net 'OUT2.MC.Q' Pad Ending at Clock Pin path delay : 17.5ns (1 macrocell levels) (Includes an external input margin of 0.0ns.) Clock Pad 'PCLK' to DFF Clock Pin at 'OUT2.MC.CLKF' Setup to Clock at the Pad : 28.5ns (2 macrocell levels) Data signal 'PCLK' to DFF D input Pin at 'OUT2.MC.ALU.F' Clock pad 'PCLK\_PIN' to DFF clock Pin at 'OUT2.MC.CLKF' Minimum Clock Period: 29.5ns Estimated Maximum Clock Speed: 33.9Mhz Clock net 'FCLK1' path delays: Clock to Setup path delay : 10.0ns (1 macrocell levels) Clock to Q, net 'REG1.MC.FFB.REG.Q' to DFF Setup(D) at 'OUT1.MC.FFB.D' Target FF drives output net 'OUT1.MC.Q' : 13.5ns (1 macrocell levels) Clock to Pad path delay (Includes an external output margin of 0.0ns.) Clock to Q, net 'LATCH' to Pad 'INREG\_OUT.OUT.OUT' : 11.5ns (0 macrocell levels) Pad to Setup path delay (Includes an external input margin of 0.0ns.)

Pad 'HIN1' to DFF Setup(D) at 'OUT1.MC.FFB.D' Target FF drives output net 'OUT1.MC.Q'

Pad Ending at Clock Pin path delay : 1.5ns (0 macrocell levels) (Includes an external input margin of 0.0ns.) Clock Pad 'FCLK1' to DFF Clock Pin at 'REG1\_CLK'

Setup to Clock at the Pad : 10.0ns (0 macrocell levels) Data signal 'HIN1' to DFF D input Pin at 'OUT1.MC.FFB.D' Clock pad 'FCLK1/BUF0.OUT' to DFF clock Pin at 'REG1\_CLK'

Minimum Clock Period: 13.5ns

Estimated Maximum Clock Speed: 74.1Mhz

### The Timespec Report

The Timespec report (*design\_name.*tsp) tells you if you have made any errors in assigning TSPEC attributes in your design and lists the T-Specs that the fitter used.

#### Example Timespec Report

The following is a timespec report example. Vertical spacing has been adjusted. This example design ran without TSPEC errors, so there are no error or warning sections.
| -                                                                                  |                | Text Editor - JCOUNT(V1.0->REV1) - Timespec Report                                |   |
|------------------------------------------------------------------------------------|----------------|-----------------------------------------------------------------------------------|---|
| <u> </u>                                                                           | e <u>E</u> dit | <u>S</u> earch <u>H</u> elp                                                       |   |
|                                                                                    |                | Timing Specifications Report For Design jcount<br>From TSPREP Version Beta-5.2.0b | + |
|                                                                                    |                | 1995/06/20 10:57:18                                                               |   |
|                                                                                    |                | Xilinx, Inc.<br>(c) Copyright 1995. All Rights Reserved.                          |   |
|                                                                                    | Repor          | t Contents                                                                        |   |
|                                                                                    | 1.             | Timing Specification Errors                                                       |   |
|                                                                                    | 2.             | Timing Specification Warnings                                                     |   |
|                                                                                    | З.             | Timing Specification Summary                                                      |   |
| Timing Specification Warnings<br><br>Timing Specification Summary<br>End of Report |                |                                                                                   |   |
|                                                                                    |                | -                                                                                 | + |

# The EQN File

The Equation File (*design\_name*.EQN) describes how your design was implemented on the EPLD device.

This file shows the following results of fitting the device:

- Where everything is placed in UIM functions
- FastCLK assignment
- FOE assignment
- Input register assignment
- Logic optimization results
- Logic minimizer results

- Equations assigned to a Fast Function Block with active-low polarity
- Export equations (Fast Function Blocks)
- Split equations

For information about how to use this report, see the *XEPLD Design Guide*.

#### **Example Equation File**

The following is an equation file example.

```
;;-----;;
; This is the .eqn file produced by the partitioner. It shows
                                                      ;
; how your equations were implemented in order to best utilize the ;
; resources available on the chip. Note that certain equations
; are now active low so that they are eligible to be placed in
                                                       ;
; a fast function block.
                                                         ;
                                                         ;
; This design was compiled for the 733644PC
                                                         ;
;;------;;
PATTERN jcount.eqn
DATE Wed Aug 02 09:30:21 1995
CHIP jcount XEPLD
MINIMIZE OFF
LOGIC_OPT OFF
OPTIONS OFF UIM_OPT REG_OPT CLOCK_OPT FOE_OPT
PARTITION FB3_1 Q0
PARTITION FB3_3 Q2 Q3
PARTITION FB3_9 Q1
INPUTPIN CLR CE
         PIN 28 42
OUTPUTPIN Q0 Q1 Q2 Q3
         PIN 06 40 04 03
FASTCLOCK C
         PIN 05
```

```
EQUATIONS
Q0 := CE * / Q3
     + /CE * Q0 ; Fast function block
  Q0.CLKF = C
  Q0.RSTF = CLR
Q1 := CE * Q0
      + /CE * Q1 ; Fast function block
  Q1.CLKF = C
  Q1.RSTF = CLR
Q2 := CE * Q1
      + /CE * Q2 ; Fast function block
  Q2.CLKF = C
  Q2.RSTF = CLR
Q3 := CE * Q2
     + /CE * Q3 ; Fast function block
  Q3.CLKF = C
  Q3.RSTF = CLR
```

# Appendix A

# **Design Directories and Files**

This appendix describes the flow of files through the Design Manager when a design is processed and the directories and files that comprise a Xilinx design.

## **File Flow**

Figure A-1 shows the types of design files the Design Manager can accept and the types of simulation and programming files the Design Manager can produce. You can create, process, and then simulate a design using Viewlogic, Viewlogic Synthesis, OrCAD, Mentor Graphics, Synopsys, Xilinx ABEL, or PLUSASM.



Figure A-1 Input and Output Files

For example, if you created a schematic in OrCAD named mydesign.sch, translating the design would produce a file called mydesign.xff, and implementing the design would produce a simulation file called mydesign.vst and a programming file called mydesign.prg. You would also see report files such as mydesign.pin (the Pinout report) and mydesign.map (the Mapping Report).

## The xproject Directory Tree

When you use the New Project command to bring a new design into the Design Manager, the Design Manager creates a directory called xproject. By default, the xproject directory is below the directory that contains your design file.

All the design files that the Design Manager creates are in the xproject directory tree. Figure A-2 shows the structure of the xproject directory and the files contained in its subdirectories. Directories are in boldface; files are in plain text. The  $vn_n$ , and revn directories represent multiple design versions and revisions.



Figure A-2 The xproject Directory Tree

# **Design Files**

Table A-1 lists some of the important files that are part of a Xilinx EPLD design. All the files in the table have the name *design\_name*; they differ only in the extension. All these files are located in a revision (rev*n*) subdirectory of xproject unless otherwise stated.

| File Extension | Description                                                                                                                                     |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| .1             | Viewlogic schematic file, located in the Viewlogic project directory (not xproject).                                                            |
| .eqn           | PLUSASM file showing the logic equations after optimization and fitting.                                                                        |
| .err           | Error log file.                                                                                                                                 |
| .gyd           | Guide file, which stores the frozen pinout and<br>information for reproducing some logic optimi-<br>zations.                                    |
| .inf           | OrCAD netlist file, located in the OrCAD project directory (not xproject).                                                                      |
| .lga           | PLUSASM Assembler Log Report (see the "Reports" chapter).                                                                                       |
| .lgc           | Optimization report (see the "Reports" chapter).                                                                                                |
| .log           | Log file.                                                                                                                                       |
| .map           | Mapping report (see the "Reports" chapter).                                                                                                     |
| .mrg           | XNFMerge report. May show errors in flatten-<br>ing the schematic hierarchy. Located in the ver-<br>sion (ver <i>n</i> ) directory.             |
| .par           | Fitting Report (see the "Reports" chapter).                                                                                                     |
| .pin           | Pin Out Report (see the "Reports" chapter).                                                                                                     |
| .pld           | PLUSASM file for a behavioral design or a<br>behavioral module of a schematic design, usu-<br>ally located in the parent directory of xproject. |
| .prg           | Intel HEX programming file produced by the XEPLD fitter.                                                                                        |
| .prj           | Design manager project data file, located in the xproject directory.                                                                            |

Table A-1 EPLD Design Files

| .res | Resource report (see the "Reports" chapter).                                                                                                                                                                                    |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| .sch | OrCAD schematic file, located in the OrCAD project directory (not xproject).                                                                                                                                                    |
| .tim | Timing report (see the "Reports" chapter).                                                                                                                                                                                      |
| .tsp | Timespec report (see the "Reports" chapter).                                                                                                                                                                                    |
| .vm6 | Design database file. The XEPLD software uses<br>the information in this file to generate timing<br>simulation files and programming files.                                                                                     |
| .vsm | Viewsim file for Viewlogic timing simulation,<br>located in the Viewlogic project directory (not<br>xproject).                                                                                                                  |
| .vst | VST file for OrCAD timing simulation, located in the OrCAD project directory (not xproject).                                                                                                                                    |
| .xff | Xilinx Flattened Format file. The file that results<br>when multiple .xnf files are merged into a single<br>design file. Each version, implementation, and<br>revision of the design has its own .xff file (see<br>Figure B-2). |
| .xnf | Xilinx Netlist Format file. A design file is trans-<br>lated into this format when you create a new<br>design project.                                                                                                          |

# Index

#### Symbols

"\*" used for multiplication, 4-15 "\*" wildcard character, 4-12, 5-13 "/" used for division, 4-15 "?" wildcard character, 4-12, 5-13 .1 files, 1-10, 2-14, A-3 .cst files, 2-39 .eqn files, A-3 .err files, A-3 .gyd files, 2-15, 2-39, 3-13, A-3 .inf files, A-3 .lga files, A-3 .lgc files, A-3 .log files, A-3 .map files, A-3 .mrg files, A-3 .par files, A-3 .pin files, A-3 .pld files, 1-3, 1-10, 2-14, A-3 .prg files, A-3 .prj files, A-3 .PRLD extension, 3-32 .res files, A-4 .sch files, 1-3, 2-14, A-4 .tim files, A-4 .tsp files, A-4 .vm6 files, A-4 .vsm files, A-4 .vst files, A-4 .xff file, 1-12 .xff files, 1-3, 2-13, A-4 .xnf files, 1-3, 1-10, 2-8, 2-14, A-4

#### Numerics

3-state control inputs, 3-23

#### Α

ABEL, Xilinx, 1-2 .ADD extension, 3-11 AND gate optimization, 3-25 attributes CLOCK\_OPT, 3-22 F, 3-10, 3-12 FAST, 3-29 FOE OPT, 3-22 H, 3-11, 3-12 INIT, 3-31, 3-32 LOC, 3-13 LOGIC\_OPT, 3-21 LOWPWR, 3-28 MINIMIZE, 3-21 NO FCLK, 3-24 NO FOE, 3-23 NO IFD, 3-24 OPT, 3-20 OPT OFF, 3-24 OPT UIM, 3-25 PART, 3-5 part type (VHDL), 3-6 PARTTYPE, 3-5 PRELOAD\_OPT, 3-22, 3-31 REG OPT, 3-22 **RELOAD**, 3-32 set\_pad\_type, 3-30 UIM OPT, 3-21

#### В

Break Logic Loops command, 5-22 Browse Revision command, 2-21

#### С

Cascade command, 5-10 CEPIN statement, 3-14 Check for Asynchronous Logic command, 5-9 CLOCK\_OPT attribute, 3-22 Close Project command, 2-11 combinational loops, 4-14 Command History command, 2-27 Configuration Data, 2-16, 2-18 Constraints file, 2-39 conventions, 4-18 creating, 4-18 example, 4-21 Syntax, 4-19 copy files, 2-23 Copy Revision command, 2-20

#### D

delete files, 2-23 Delete Project command, 2-12 Delete Revision command, 2-24 design control options table, 3-2 directories and files, A-1 directory tree, A-2 export, 1-1 files, table, A-3 flow, 1-1 implementation, 1-1, 1-4, 1-13 implementation overview, 3-1 management, 2-4 translation, 1-1, 1-3 Design Manager implementations, 2-2 projects, 2-2 revisions, 2-2 single device selection, 3-4

Tool Bar, 2-6 tutorial, 1-7 using, 2-5 versions, 2-2 window, 1-7, 1-12, 2-1, 2-5 Design Menu Browse Revision, 2-21 Copy Revision, 2-20 Delete Revision, 2-24 Export, 2-18 Implement, 1-4, 1-13, 2-14 New Device, 2-19 New Revision, 2-20 Rename, 2-24 Translate, 2-13 device selection automatic selection criteria, 3-5 behavioral, 3-6 in Design Manager, 3-4 in schematics, 3-5 multiple devices, 3-7 table, 3-3 VHDL, 3-6

### Ε

EQN file, 6-18 example, 6-19 equations chaining across FB boundaries, 3-12 linked, 3-12 Exclude Paths with Nets command, 5-19 Exit command, 2-12 Export command, 2-18 .EXPORT extension, 3-11 export, design, 1-1

#### F

F attribute, 3-10, 3-12 FAST attribute, 3-29 Fast Clock optimazation, 2-32 Fast Function Block, 3-12 Fast Output Enable optimization, 2-32 FastCLK inputs, 3-24 optimization, 3-22 FASTCLOCK statement, 3-14 File Menu Close Project, 2-11 Delete Project, 2-12 Exit, 2-12 File Name, 2-12 New Project, 1-9, 2-6 Open Project, 2-11 Save Project, 2-11 files .1, 1-10, 2-14 .cst, 2-39 .gyd, 2-15, 2-39, 3-13 .pld, 1-3, 1-10, 2-14 .sch, 1-3, 2-14 .xff, 1-3, 1-12, 2-13 .xnf, 1-3, 1-10, 2-8, 2-14 Constraints, 2-39, 4-18 copy, 2-23 delete, 2-23 editor, 2-22 guide, 2-15, 2-39 move, 2-23 filters, path, 5-7, 5-12 Fitter results (report), 6-3 Fitting Report, 6-10 example, 6-13 Flow command, 2-40 Flow Engine, 2-2 simplified, 2-17 using, 2-38 Flow Engine command, 2-25 Flow Engine Menu Flow, 2-40 Help, 2-44 Setup, 2-41 Utilities, 2-44

#### FOE

input, usage, 3-23 optimization, 3-22 FOE\_OPT attribute, 3-22 FOEPIN statement, 3-14

#### G

Guide Files, 2-15, 2-39

#### Η

H attribute, 3-11, 3-12 Help command, 2-44 Help Menu Contents, 2-35 Search, 2-37 Tutorial, 2-37 High Density Function Block, 3-12

I/O pads, driving, 2-30 I/O Resource Report, 6-4 Ignore Timespecs command, 5-13 IGNORE, timing path, 4-14 Implement command, 2-14 implementation, design, 1-1, 1-4, 1-13, 2-15 Include Paths with Nets command, 5-19 INIT attribute, 3-31, 3-32 initial state control behavioral, 3-32 in schematics, 3-31 VHDL, 3-32 Input pad registers optimization, 2-32 input pad registers optimization, 3-22 usage, 3-24 **INPUTPIN** statement, 3-14 Inputs, 3-state control, 3-23 IOPIN statement, 3-14

#### L

linked equations, 3-12 LOC attribute, 3-13

#### logic

minimization of, 3-21 optimization,global, 3-21 logic placement behavioral, 3-11 in Design Manager, 3-10 in schematics, 3-10 VHDL, 3-12 LOGIC\_OPT attribute (schematic), 3-21 LOGIC\_OPT statement (behavioral), 3-23 Low Power Mode, 2-30 LOWPWR attribute, 3-28

#### Μ

managing, designs, 2-4 Mapping Report, 6-5 example, 6-7 Master Reset, 2-31 Mentor Graphics, 3-5 using TIMESPECS, 4-5 MINIMIZE attribute (schematic), 3-21 MINIMIZE statement (behavioral), 3-23 move files, 2-23 MR Input, 2-31 Multi-Chip Design, 3-7 Multi-Chip Designs, 2-8 Multi-Chip Partitioner, 3-7 multiple device selection, 3-7

#### Ν

New Device command, 2-19 New Project command, 2-6 New Revision command, 2-20 NO\_FCLK, attribute, 3-24 NO\_FOE, attribute, 3-23 NO\_IFD, attribute, 3-24

#### 0

Open Project command, 2-11 OPT attribute, 3-20 OPT\_OFF, attribute, 3-24 OPT\_UIM, attribute, 3-25 optimization AND gates, 3-25 Fast Clock, 2-32 Fast Output Enable, 2-32 global, 3-21 inhibiting, 3-24 input register, 2-32 Preload, 2-32 timing driven, 2-32, 3-19 UIM, 2-32 optimization control behavioral, 3-23 Fast Clock, 3-19 Fast Output Enable, 3-19 in Design Manager, 3-16 in schematics, 3-20 input register, 3-19 Preload, 3-20 UIM, 3-20 VHDL, 3-23 Optimization Template, 2-32 **OPTIONS statement**, 3-23 OrCad, 1-10, 3-5 using TIMESPECS, 4-5 **OUTPUTPIN** statement, 3-14

#### Ρ

PART attribute, 3-5 Part Selector, 2-20 part type, attribute (VHDL), 3-6 PARTITION statement, 3-11 physical, 3-11 Partitioner, 2-2 Partitioner command, 2-26 Partitioner, Multi-Chip, 3-7 PARTTYPE attribute, 3-5 path filters, 5-7 applying, 5-12 Physical Design Data, 2-18 physical PARTITION statements, 3-11 pin assignment, 2-30, 3-12 behavioral, 3-14

in Design Manager, 3-13 in schematics, 3-13 MR Input, 2-31 PIN keyword, 3-14 Pinout Report, 6-8 example, 6-9 pin-save file, 3-15 PLUSASM, 1-2, 1-10 power control, 2-30 power management behavioral, 3-28 in Design Manager, 3-25 in schematics, 3-28 VHDL, 3-28 power usage, macrocells, 3-28 predefined groups, T-Spec, 4-6 PRELOAD attribute, 3-32 Preload optimization, 2-32 PRELOAD\_OPT attribute, 3-22, 3-31 PRLD (preload) signal optimization of, 3-22 PRLD extension, 3-32 Program Option Templates, 2-15 project management, 2-2 Project Notes command, 2-28 PWR statement, 3-28

#### R

REG\_OPT attribute, 3-22 register input pad, 3-24 registers optimization of, 3-22 preload values, 3-31 Rename command, 2-24 Report Browser, 1-15 Report Browser command, 2-26 Report Options command, 5-27 Report Paths Failing Timespec command, 5-12 Report Paths with No Timespec command, 5-12 Reports, 1-5 Detailed Path, 5-7 EQN file, 6-18 Fitting, 6-10 Mapping, 6-5 Performance Summary, 5-5 Performance to Timespecs, 5-4 Pinout, 6-8 Resource, 6-3 Timespec, 6-17 Timing, 6-15 viewing, 6-1 Reset Path Filters command, 5-24 Reset, Master, 2-31 Resource Report, 6-3 example, 6-4 resource reservation in Design Manager, 3-34 Resources Template, 2-33

#### S

Save Project command, 2-11 Search command, 2-37 Select Destinations command, 5-14 Select Path Types command, 5-17 Select Sources command, 5-14 Set Delay Margins for I/O command, 5-25 Set Speed Grade command, 5-25 set\_pad\_type attribute, 3-30 Setup command, 2-41 .SHIFT extension, 3-11 Show Clocks command, 5-9 Show Settings command, 5-9 Single-Chip designs, 2-8 slewrate control behavioral, 3-29 in schematics, 3-29 VHDL, 3-29 speed grade selection, 3-5 Synopsys, 1-2, 3-33

#### Т

Template Manager command, 2-28 Templates Fitting, 2-30, 3-17, 3-27, 3-35, 4-3 Optimization, 2-32, 3-18 Program Option, 2-15 Resources, 2-33, 3-36 Tile command, 5-10 TIMEGRP attributes, table, 4-17 primitive, 4-10 symbols, 4-5 TIMEGRP attribute, 4-10 combining multiple groups, 4-11 grouping by exclusion, 4-11 syntax, 4-10, 4-20 TIMESPEC attributes table, 4-18 TIMESPEC primitive, 4-4 basic groups, 4-5 FROM-TO statement, 4-4 syntax, 4-4 Timespec Report, 6-17 Example, 6-17 Timing Analyzer, 1-6, 2-2 icon, 5-2 procedure, 5-1 reports, 5-3 Timing Analyzer command, 2-25 Timing Analyzer tutorial, 1-16 timing control, 4-3 timing driven optimization, 2-32, 3-19 Timing Report, 2-16, 6-15 example, 6-15 Timing Simulation Data, 2-16, 2-18 TNM attribute, 4-5, 4-6 grouping flip-flops, 4-8 incompatible symbols, 4-7 on clock pins, 4-9 on macro symbols, 4-8 on primitive symbols, 4-7

on signal, 4-8 placement on schematic, 4-7 TNM attributes table, 4-17 Tools Menu Flow Engine, 2-25 Partitioner, 2-26 Timing Analyzer, 1-16, 2-25 Translate command, 2-13 Translate Options Window, 1-11 translation design, 1-1, 1-3 TS attribute, 4-4 delay, 4-14 length, 4-4 specifying, 4-14 time delay units, 4-15 T-Specs, 2-30, 2-39, 4-1, 5-1 tutorial, Design Manager, 1-7

### U

UIM attributes, 3-25 controlling optimization, 3-21 optimization, 2-32 UIM\_OPT attribute, 3-21 Utilities command, 2-44 Utilities Menu Command History, 2-27 Project Notes, 2-28 Report Browser, 1-15, 2-26 Template Manager, 2-28

#### V

ViewLogic, 1-10, 3-5

#### X

XACT–Performance, 2-30, 4-1 combinational loops, 4-14 combining multiple groups, 4-11 creating new groups, 4-10 group by exclusion, 4-11 group by signal name, 4-12 ignore selected paths, 4-14 multiple specifications, 4-13 predefined groups, 4-6 sample schematic, 4-16 syntax, 4-17 TIMEGRP attribute, 4-10 TIMEGRP primitive, 4-10 TIMESPEC primitive, 4-4 TNMs, 4-6 TS attribute, 4-4 wildcards, 4-12 Xilinx ABEL, 1-2 **XILINX**°, XACT, XC2064, XC3090, XC4005, and XC-DS501 are registered trademarks of Xilinx. All XC-prefix product designations, XACT-Floorplanner, XACT-Performance, XAPP, XAM, X-BLOX, X-BLOX plus, XChecker, XDM, XDS, XEPLD, XPP, XSI, BITA, Configurable Logic Cell, CLC, Dual Block, FastCLK, HardWire, LCA, Logic Cell, LogicProfessor, MicroVia, PLUSASM, SMARTswitch, UIM, VectorMaze, VersaBlock, VersaRing, and ZERO+ are trademarks of Xilinx. The Programmable Logic Company and The Programmable Gate Array Company are service marks of Xilinx.

IBM is a registered trademark and PC/AT, PC/XT, PS/2 and Micro Channel are trademarks of International Business Machines Corporation. DASH, Data I/O and FutureNet are registered trademarks and ABEL, ABEL-HDL and ABEL-PLA are trademarks of Data I/O Corporation. SimuCad and Silos are registered trademarks and P-Silos and P/C-Silos are trademarks of SimuCad Corporation. Microsoft is a registered trademark and MS-DOS is a trademark of Microsoft Corporation. Centronics is a registered trademark of Centronics Data Computer Corporation. PAL and PALASM are registered trademarks of Advanced Micro Devices, Inc. UNIX is a trademark of AT&T Technologies, Inc. CUPL, PROLINK, and MAKEPRG are trademarks of Logical Devices, Inc. Apollo and AEGIS are registered trademarks of Hewlett-Packard Corporation. Mentor and IDEA are registered trademarks and NETED, Design Architect, QuickSim, QuickSim II, and EXPAND are trademarks of Mentor Graphics, Inc. Sun is a registered trademark of Sun Microsystems, Inc. SCHEMA II+ and SCHEMA III are trademarks of Omation Corporation. OrCAD is a registered trademark of OrCAD Systems Corporation. Viewlogic, Viewsim, and Viewdraw are registered trademarks of Viewlogic Systems, Inc. CASE Technology is a trademark of CASE Technology, a division of the Teradyne Electronic Design Automation Group. DECstation is a trademark of Digital Equipment Corporation. Synopsys is a registered trademark of Synopsys, Inc. Verilog is a registered trademark of Cadence Design Systems, Inc.

Xilinx does not assume any liability arising out of the application or use of any product described or shown herein; nor does it convey any license under its patents, copyrights, or maskwork rights or any rights of others. Xilinx reserves the right to make changes, at any time, in order to improve reliability, function or design and to supply the best product possible. Xilinx will not assume responsibility for the use of any circuitry described herein other than circuitry entirely embodied in its products. Xilinx devices and products are protected under one or more of the following U.S. Patents: 4,642,487; 4,695,740; 4,706,216; 4,713,557; 4,746,822; 4,750,155; 4,758,985; 4,820,937; 4,821,233; 4,835,418; 4,853,626;

4,855,619; 4,855,669; 4,902,910; 4,940,909; 4,967,107; 5,012,135; 5,023,606; 5,028,821; 5,047,710; 5,068,603; 5,140,193; 5,148,390; 5,155,432; 5,166,858; 5,224,056; 5,243,238; 5,245,277; 5,267,187; 5,291,079; 5,295,090; 5,302,866; 5,319,252; 5,319,254; 5,321,704; 5,329,174; 5,329,181; 5,331,220; 5,331,226; 5,332,929; 5,337,255; 5,343,406; 5,349,248; 5,349,249; 5,349,249; 5,349,250; 5,349,691; 5,357,153; 5,360,747; 5,361,229; 5,362,999; 5,365,125; 5,367,207; 5,386,154; 5,394,104; 5,399,924; 5,399,925; 5,410,189; 5,410,194; 5,414,377; RE 34,363, RE 34,444, and RE 34,808. Other U.S. and foreign patents pending. Xilinx, Inc. does not represent that devices shown or products described herein are free from patent infringement or from any other third party right. Xilinx assumes no obligation to correct any errors contained herein or to advise any user of this text of any correction if such be made. Xilinx will not assume any liability for the accuracy or correctness of any engineering or software support or assistance provided to a user.

Xilinx products are not intended for use in life support appliances, devices, or systems. Use of a Xilinx product in such applications without the written consent of the appropriate Xilinx officer is prohibited.