# LogiCORE IP Clocking Wizard v3.3

# User Guide

UG521 January 18, 2012





The information disclosed to you hereunder (the "Materials") is provided solely for the selection and use of Xilinx products. To the maximum extent permitted by applicable law: (1) Materials are made available "AS IS" and with all faults, Xilinx hereby DISCLAIMS ALL WARRANTIES AND CONDITIONS, EXPRESS, IMPLIED, OR STATUTORY, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, NON-INFRINGEMENT, OR FITNESS FOR ANY PARTICULAR PURPOSE; and (2) Xilinx shall not be liable (whether in contract or tort, including negligence, or under any other theory of liability) for any loss or damage of any kind or nature related to, arising under, or in connection with, the Materials (including your use of the Materials), including for any direct, indirect, special, incidental, or consequential loss or damage (including loss of data, profits, goodwill, or any type of loss or damage suffered as a result of any action brought by a third party) even if such damage or loss was reasonably foreseeable or Xilinx had been advised of the possibility of the same. Xilinx assumes no obligation to correct any errors contained in the Materials or to notify you of updates to the Materials or to product specifications. You may not reproduce, modify, distribute, or publicly display the Materials without prior written consent. Certain products are subject to the terms and conditions of the Limited Warranties which can be viewed at <a href="http://www.xilinx.com/warranty.htm">http://www.xilinx.com/warranty.htm</a>. Por use of Yilinx had support terms contained in a license issued to you by Xilinx. Xilinx products are not designed or intended to be fail-safe or for use in any application requiring fail-safe performance; you assume sole risk and liability for use of Xilinx products in Critical Applications: http://www.xilinx.com/warranty.htm#critapps.

© Copyright 2008-2012. Xilinx, Inc. Xilinx, the Xilinx logo, Artix, ISE, Kintex, Spartan, Virtex, Zynq, and other designated brands included herein are trademarks of Xilinx in the United States and other countries. All other trademarks are the property of their respective owners.

## **Revision History**

| Date     | Version | Revision                                                                           |
|----------|---------|------------------------------------------------------------------------------------|
| 12/17/08 | 1.1.1   | Xilinx Confidential DRAFT. Approved for external release under NDS only.           |
| 04/24/09 | 1.1     | Initial major release. Supports core version 1.1 and Xilinx tools 11.1.            |
| 06/24/09 | 1.2     | Supports core version 1.2 and Xilinx tools 11.2.                                   |
| 09/16/09 | 1.3     | Supports core version 1.3 and Xilinx tools 11.3.                                   |
| 12/02/09 | 1.4     | Supports core version 1.4 and Xilinx tools 11.4.                                   |
| 04/19/10 | 1.5     | Supports core version 1.5 and Xilinx tools 12.1.                                   |
| 07/23/10 | 1.6     | Supports core version 1.6 and Xilinx tools 12.2.                                   |
| 09/21/10 | 1.7     | Supports core version 1.7 and Xilinx tools 12.3                                    |
| 12/14/10 | 1.8     | Supports core version 1.8 and Xilinx tools 12.4                                    |
| 03/01/11 | 3.1     | Supports core version 3.1 and Xilinx tools 13.1                                    |
| 06/22/11 | 3.2     | Supports core version 3.2 and Xilinx tools 13.2. Added new 7 series architectures. |
| 01/18/12 | 3.3     | Supports core version 3.3 and Xilinx tools 13.4. Do other document changes.        |

The following table shows the revision history for this document.

# Table of Contents

| Revision History 2             |  |  |  |  |  |
|--------------------------------|--|--|--|--|--|
| <b>Introduction</b>            |  |  |  |  |  |
| <b>Features</b>                |  |  |  |  |  |
| Functional Overview            |  |  |  |  |  |
| Clocking Features              |  |  |  |  |  |
| Input Clocks                   |  |  |  |  |  |
| Input Clock Jitter Option 6    |  |  |  |  |  |
| Output Clocks                  |  |  |  |  |  |
| Clock Buffering and Feedback 7 |  |  |  |  |  |
| Optional Ports                 |  |  |  |  |  |
| Optional Attributes            |  |  |  |  |  |
| Primitive Override             |  |  |  |  |  |
| Summary                        |  |  |  |  |  |
| Design Environment             |  |  |  |  |  |
| I/O Signals                    |  |  |  |  |  |
| <b>Support</b>                 |  |  |  |  |  |
| Ordering Information 11        |  |  |  |  |  |
| <b>References</b>              |  |  |  |  |  |

### **Chapter 1: Introduction**

| System Requirements           | 12       |
|-------------------------------|----------|
| About the Core                | 12       |
| Recommended Design Experience | 12       |
| Additional Core Resources     | 12       |
| Technical Support.            | 13       |
| Feedback                      | 13       |
| Clocking Wizard               | 13<br>13 |

## **Chapter 2: Core Architecture**

| Input Clocks            | 14 |
|-------------------------|----|
| Primitive Instantiation | 14 |
| Feedback                | 14 |
| Output Clocks           | 15 |
| I/O Signals             | 15 |

## **Chapter 3: Generating the Core**

| Clocking Features                        | 16 |
|------------------------------------------|----|
| Selecting Clocking Features              | 17 |
| Clock Manager Type (Primitive Selection) | 17 |
| Configuring Input Clocks                 | 18 |

| Output Clock Settings 19            |
|-------------------------------------|
| Configuring Output Clocks 19        |
| <b>Feedback and I/O</b>             |
| Selecting Optional Ports            |
| Choosing Feedback                   |
| Primitive Overrides                 |
| Overriding Calculated Parameters 22 |
| User Provided Comment               |
| Clock Summary (First Page)          |
| Input Clocking Summary              |
| Output Clocking Summary             |
| Port Names                          |
| Core Summary (Second Page)          |
| Resource Estimate Summary           |
| XPower Estimator Summary            |
| File Report Summary                 |

## Chapter 4: Detailed Example Design

| Directory and File Contents                                                    |
|--------------------------------------------------------------------------------|
| <pre><project directory=""> 27</project></pre>                                 |
| <pre><project directory="">/<component name=""> 27</component></project></pre> |
| <component name="">/example design</component>                                 |
| <component name="">/doc</component>                                            |
| <component name="">/implement</component>                                      |
| implement/results                                                              |
| <pre><component name="">/simulation</component></pre>                          |
| simulation/functional                                                          |
| simulation/timing 29                                                           |
| Implementation Scripts    29                                                   |
| Simulation Scripts                                                             |
| Functional Simulation                                                          |
| Timing Simulation                                                              |
| Example Design                                                                 |
| Customizing the Example Design 31                                              |
| Demonstration Test Bench                                                       |

## Appendix A: Migration Guide

| Differences between the Clocking Wizard and the Legacy DCM and PLL | Wizards 34 |
|--------------------------------------------------------------------|------------|
| Primitive Selection                                                | 34         |
| Symbol Pin Activation                                              | 34         |
| Parameter Override                                                 | 34         |
| Port Display Conventions                                           | 35         |
| Visibility of Clock Ports                                          | 35         |
| GUI Information Gathering Order                                    | 35         |





UG521 January 18, 2012

**Product Specification** 

#### Introduction

The LogiCORE<sup>™</sup> IP Clocking Wizard core makes it easy to create HDL source code wrappers for clock circuits customized to your clocking requirements. You can either let the wizard select an appropriate clocking primitive for you automatically, then configure buffering, feedback, and timing parameters for your desired clocking network, or you can manually select the primitive and configure all aspects of the primitive and clocking network yourself. The wizard guides you in the setting of the appropriate attributes for your clocking primitive, and at the same time also allows you to override any wizard-calculated parameter.

Besides providing an HDL wrapper to implement the desired clocking circuit, the Clocking Wizard also delivers a timing parameter summary generated by the Xilinx timing tools for the circuit.

#### **Features**

- Accepts up to two input clocks and up to seven output clocks per clock network
- Automatically chooses correct clocking primitive for a selected device
- Automatically configures clocking primitive based on user-selected clocking features
- Automatically calculates Voltage Controlled Oscillator (VCO) frequency for primitives with an oscillator, and provides multiply and divide values based on input and output frequency requirements
- Automatically implements overall configuration that supports phase shift and duty cycle requirements
- Provides the ability to override the selected clock primitive and any calculated attribute
- Optionally buffers clock signals
- Provides timing estimates for the clock circuit and Xilinx® Power Estimator (XPE) parameters
- Provides a synthesizeable example design including the clocking network and a simulation test bench
- Provides optional ports for the selected primitive

| LogiCORE IP Facts                         |                              |                                 |                                               |                                                                       |
|-------------------------------------------|------------------------------|---------------------------------|-----------------------------------------------|-----------------------------------------------------------------------|
| Core Specifics                            |                              |                                 |                                               |                                                                       |
| Supported Device<br>Family <sup>(a)</sup> |                              |                                 | K<br>Zyn                                      | Virtex-7<br>(intex™-7<br>Artix™-7<br>q™-7000<br>Virtex-6<br>Spartan-6 |
| Supported User<br>Interfaces              |                              |                                 | Not A                                         | pplicable                                                             |
| Resources Used                            | I/O                          | LUTs                            | FFs                                           | Block<br>RAMs                                                         |
|                                           | 1-2                          | 0-1                             | 0                                             | 0                                                                     |
| Special Features                          | MN                           | DCI<br>ICM, PLL                 | M, DCM_(<br>PLLE2, N                          | CLKGEN,<br>MMCME2                                                     |
| Pro                                       | vided wi                     | th Core                         |                                               |                                                                       |
| Documentation                             |                              | Pr<br>Ge                        | oduct Spe<br>tting Start<br>Relea             | ecification<br>ed Guide<br>ase Notes                                  |
| Design Files                              | Verilog and VHDL             |                                 |                                               |                                                                       |
| Example Design                            | Verilog and VHDL             |                                 |                                               |                                                                       |
| Test Bench                                | Verilog and VHDL             |                                 |                                               |                                                                       |
| Constraints File                          | .ucf (user constraints file) |                                 |                                               |                                                                       |
| Simulation Model                          | UNISIM                       |                                 |                                               |                                                                       |
| Instantiation Template                    |                              | Verilog a                       | and VHDL                                      | Wrapper                                                               |
| Additional Items                          | 7 Series                     | FPGAs C                         | Clocking R                                    | esources                                                              |
|                                           | Virtex-6                     | and Spa                         | rtan-6 Use                                    | er Guides                                                             |
| Test                                      | ed Desig                     | gn Tools                        |                                               |                                                                       |
| Design Entry Tools                        |                              |                                 | ISE v13.4                                     | software                                                              |
| Simulation <sup>(b)</sup>                 | S                            | Mentor G<br>Cadence<br>Synopsys | iraphics M<br>Incisive E<br>Simula<br>VCS and | lodelSim,<br>Enterprise<br>Itor (IES),<br>VCS MX,                     |
| Synthesis Teels                           |                              |                                 |                                               |                                                                       |
| Synthesis 10015                           | Supro                        |                                 | IU E-2011                                     | 1.03, XS1                                                             |
| Support<br>Brouided by Villay, Inc.       |                              |                                 |                                               |                                                                       |
|                                           |                              |                                 |                                               |                                                                       |

- a. For the complete list of supported devices, see the release notes for this core.
- b. For the supported version of the tool, see the <u>ISE Design Suite 13:</u> <u>Release Notes Guide</u>.

© Copyright 2009-2012. Xilinx, Inc. Xilinx, the Xilinx logo, Artix, ISE, Kintex, Spartan, Virtex, Zynq, and other designated brands included herein are trademarks of Xilinx in the United States and other countries. All other trademarks are the property of their respective owners.

www.xilinx.com

## **Functional Overview**

The Clocking Wizard is an interactive Graphical User Interface (GUI) that creates a clocking network based on design-specific needs. The required clock network parameters are organized in a linear sequence so that you can select only the desired parameters. Using the wizard, experienced users can explicitly configure their chosen clocking primitive, while less experienced users can let the wizard automatically determine the optimal primitive and configuration -- based on the features required for their individual clocking networks.

Users already familiar with the Digital Clock Manager (DCM) and Phase-Locked Loop (PLL) wizards can refer to the Migration Guide Appendix in the Clocking Wizard Getting Started Guide for information on usage differences.

#### **Clocking Features**

Major clocking-related functional features desired and specified by the user can be used by the wizard to select an appropriate primitive. Incompatible features are automatically dimmed out to help the designer evaluate feature trade-offs.

Clocking features include:

- Frequency synthesis
- Phase alignment
- Minimization of output jitter
- Allowance of larger input jitter
- Minimization of power
- Dynamic phase shift
- Dynamic reconfiguration

#### **Input Clocks**

One input clock is the default behavior, but two input clocks can be chosen by selecting a secondary clock source. Only the timing parameters of the input clocks in their specified units is required; the wizard uses these parameters as needed to configure the output clocks.

*Note:* For Spartan<sup>®</sup>-6 FPGA designs, the ISE<sup>®</sup> tool chain infers BUFIO2 for input clock routing which is not part of the generated HDL.

#### **Input Clock Jitter Option**

The wizard allows the user to specify the input clock jitter either in UI or PS units using a radio button.

#### **Output Clocks**

The number of output clocks is user-configurable. The maximum number allowed depends upon the selected device and the interaction of the major clocking features you specify. Users can simply input their desired timing parameters (frequency, phase, and duty cycle) and let the clocking wizard select and configure the clocking primitive and network automatically to comply with the requested characteristics. If it is not possible to comply exactly with the requested parameter settings due to the number of available input clocks, best-attempt settings are provided. When this is the case, the clocks are ordered so that CLK\_OUT1 is the highest-priority clock and is most likely to comply with the requested timing parameters. The wizard prompts you for frequency parameter settings before the phase and duty cycle settings.

Note: The port names in the generated circuit can differ from the port names used on the original primitive.

#### **Clock Buffering and Feedback**

In addition to configuring the clocking primitive within the device, the wizard also assists with constructing the clocking network. Buffering options are provided for both input and output clocks. If a clock output requires special buffers like BUFPLL which the wizard does not generate in the design, alert messages are flagged to the user. Feedback for the primitive can be user-controlled or left to the wizard to automatically connect. If automatic feedback is selected, the feedback path is matched to timing for CLK\_OUT1.

#### **Optional Ports**

All primitive ports are available for user-configuration. You can expose any of the ports on the clocking primitive, and these are provided as well in the source code.

#### **Optional Attributes**

The BUFR\_DIVIDE attribute of BUFR is available for the user as a generic parameter in the HDL when the output driver is chosen as BUFR. The user can change the divide value of the BUFR while instantiating the design.

#### **Primitive Override**

All configuration parameters are also user-configurable. In addition, should a provided value be undesirable, any of the calculated parameters can be overridden with the desired settings.

#### Summary

The Clocking Wizard provides a summary for the created network. Input and output clock settings are provided both visually and as constraint files. In addition, jitter numbers for the created network are provided along with a resource estimate. Lastly, the wizard provides the input setting for PLL and MMCM based designs for Xilinx Power Estimator (XPE) in an easy-to-use table.

#### **Design Environment**

Figure 1 shows the design environment provided by the wizard to assist in integrating the generated clocking network into a design. The wizard provides a synthesizable and downloadable example design to demonstrate how to use the network and allows you to place a very simple clocking network in your device. A sample simulation test bench, which simulates the example design and illustrates output clock waveforms with respect to input clock waveforms, is also provided.



Figure 1: Clocking Network and Support Modules Provided to the User

## I/O Signals

Table 1 describes the input and output ports provided from the clocking network. All ports are optional, with the exception being that at least one input and one output clock are required. The options selected by the user determine which ports are actually available to be configured. For example, when Dynamic Reconfiguration is selected, these ports are exposed to the user. Any port that is not exposed is appropriately tied off or connected to a signal labeled *unused* in the delivered source code. Not all ports are available for all devices or primitives; for example, Dynamic Reconfiguration is a feature only available in Virtex®-6 FPGA Mixed-Mode Clock Manager (MMCM), Spartan-6 FPGA DCM\_CLKGEN and 7 series FPGAs MMCME2 primitives.

| Port <sup>(10)</sup>  | I/O    | Description                                                                                                                                                                                                                     |
|-----------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input Clock Ports (1) |        |                                                                                                                                                                                                                                 |
| CLK_IN1               | Input  | <b>Clock in 1</b> : Single-ended primary input clock port. Available when single-ended primary clock source is selected.                                                                                                        |
| CLK_IN1_P             | Input  | Clock in 1 Positive and Negative: Differential primary input clock port pair. Available when a                                                                                                                                  |
| CLK_IN1_N             |        |                                                                                                                                                                                                                                 |
| CLK_IN2               | Input  | <b>Clock in 2:</b> Single-ended secondary input clock port. Available when a single-ended secondary clock source is selected.                                                                                                   |
| CLK_IN2_P             | Input  | Clock in 2 Positive and Negative: Differential secondary input clock port pair. Available when                                                                                                                                  |
| CLK_IN2_N             |        | a differential secondary clock source is selected.                                                                                                                                                                              |
| CLK_IN_SEL            | Input  | <b>Clock in Select:</b> When '1', selects the primary input clock; When '0', the secondary input clock is selected. Available when two input clocks are specified.                                                              |
| CLKFB_IN              | Input  | <b>Clock Feedback in</b> : Single-ended feedback in port of the clocking primitive. Available when user-controlled on-chip, user controller-off chip, or automatic control off-chip feedback option is selected.                |
| CLKFB_IN_P            | Input  | <b>Clock Feedback in: Positive and Negative:</b> Differential feedback in port of the clocking primitive. Available when the automatic control off-chip feedback and differential feedback option is selected                   |
| CLKFB_IN_N            | Input  |                                                                                                                                                                                                                                 |
|                       |        | Output Clock Ports                                                                                                                                                                                                              |
| CLK_OUT1              | Output | Clock Out 1: Output clock of the clocking network. CLK_OUT1 is not optional.                                                                                                                                                    |
| CLK_OUT1_CE           | Input  | <b>Clock Enable:</b> Chip enable pin of the output buffer. Available when BUFGCE or BUFHCE or BUFR buffers are used as output clock drivers.                                                                                    |
| CLK_OUT1_CLR          | Input  | <b>Counter reset for divided clock output:</b> Available when BUFR buffer is used as output clock driver.                                                                                                                       |
| CLK_OUT2-n            | Output | <b>Clock Out 2 - n:</b> Optional output clocks of the clocking network that are user-specified. For an MMCM, up to seven are available. For a PLL or DCM, up to six are available. For a DCM_CLKGEN, up to three are available. |
| CLK_OUT[2-n]_CE       | Input  | <b>Clock Enable:</b> Chip enable pin of the output buffer. Available when BUFGCE or BUFHCE or BUFR buffers are used as output clock drivers.                                                                                    |
| CLK_OUT[2-n]_CLR      | Input  | <b>Counter reset for divided clock output:</b> Available when BUFR buffer is used as output clock driver.                                                                                                                       |
| CLKFB_OUT             | Output | <b>Clock Feedback Out:</b> Single ended feedback port of the clocking primitive. Available when the user-controlled feedback or automatic control off chip with single ended feedback option is selected.                       |

#### Table 1: Clocking Wizard IO

#### Table 1: Clocking Wizard IO (Cont'd)

| Port <sup>(10)</sup>                                        | I/O              | Description                                                                                                                                                                                                       |
|-------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CLKFB_OUT_P<br>CLKFB_OUT_N                                  | Output<br>Output | <b>Clock Feedback Out: Positive and Negative:</b> Differential feedback output port of the clocking primitive. Available when the user-controlled off-chip feedback and differential feedback option is selected. |
|                                                             |                  |                                                                                                                                                                                                                   |
|                                                             | 1                | Dynamic Reconfiguration Ports for MMCM / MMCME2                                                                                                                                                                   |
| DADDR[6:0]                                                  | Input            | <b>Dynamic Reconfiguration Address:</b> Address port for use in dynamic reconfiguration; active when DEN is asserted                                                                                              |
| DCLK                                                        | Input            | Dynamic Reconfiguration Clock: Clock port for use in dynamic reconfiguration                                                                                                                                      |
| DEN                                                         | Input            | Dynamic Reconfiguration Enable: Starts a dynamic reconfiguration transaction                                                                                                                                      |
| DI[15:0]                                                    | Input            | <b>Dynamic Reconfiguration Data in:</b> Input data for a dynamic reconfiguration write transaction; active when DEN is asserted                                                                                   |
| DO[15:0]                                                    | Output           | <b>Dynamic Reconfiguration Data Out:</b> Output data for a dynamic reconfiguration read transaction; active when DRDY is asserted                                                                                 |
| DRDY                                                        | Output           | Dynamic Reconfiguration Ready: Completes a dynamic reconfiguration transaction                                                                                                                                    |
| DWE                                                         | Input            | <b>Dynamic Reconfiguration Write Enable:</b> When asserted, indicates that the dynamic reconfiguration transaction is a write; active when DEN is asserted                                                        |
| Dynamic Reconfiguration Ports for DCM_CLKGEN <sup>(2)</sup> |                  |                                                                                                                                                                                                                   |
| PROGCLK                                                     | Input            | Program Clock: Clock port for use in dynamic reconfiguration                                                                                                                                                      |
| PROGEN                                                      | Input            | Program Enable: Starts a dynamic reconfiguration transaction                                                                                                                                                      |
| PROGDATA                                                    | Input            | Program Data: Serial data stream to reprogram primitive settings                                                                                                                                                  |
| PROGDONE                                                    | Output           | Program Done: When asserted, indicates that the reconfiguration transaction is complete                                                                                                                           |
|                                                             |                  | Dynamic Phase Shift Ports <sup>(3)</sup>                                                                                                                                                                          |
| PSCLK                                                       | Input            | Dynamic Phase Shift Clock: Clock for use in dynamic phase shifting                                                                                                                                                |
| PSEN                                                        | Input            | Dynamic Phase Shift Enable: Starts a dynamic phase shift transaction                                                                                                                                              |
| PSINCDEC                                                    | Input            | <b>Dynamic Phase Shift increment/decrement:</b> When '1'; increments the phase shift of the output clock, when '0', decrements the phase shift                                                                    |
| PSDONE                                                      | Output           | Dynamic Phase Shift Done: Completes a dynamic phase shift transaction                                                                                                                                             |
| Status and Control Ports <sup>(4)</sup>                     |                  |                                                                                                                                                                                                                   |
| RESET                                                       | Input            | <b>Reset:</b> When asserted, asynchronously clears the internal state of the primitive, and causes the primitive to re-initiate the locking sequence when released                                                |
| POWER_DOWN <sup>(5)</sup>                                   | Input            | <b>Power Down:</b> When asserted, places the clocking primitive into low power state, which stops the output clocks                                                                                               |
| STATUS[2:0] <sup>(6)</sup>                                  | Output           | <b>Status:</b> Contains information about the state of the primitive. See the user guide for specific bit descriptions                                                                                            |
| FREEZE <sup>(7)</sup>                                       | Input            | Freeze: When asserted, prevents tap adjustment in the event that the input clock is lost                                                                                                                          |
| INPUT_CLK_<br>STOPPED <sup>(8)</sup>                        | Output           | <b>Input Clock Stopped:</b> When asserted, indicates that the selected input clock is no longer toggling                                                                                                          |
| LOCKED                                                      | Output           | <b>Locked:</b> When asserted, indicates that the output clocks are stable and usable by downstream circuitry                                                                                                      |

#### Table 1: Clocking Wizard IO (Cont'd)

| Port <sup>(10)</sup>     | I/O    | Description                                                                                                                                                                                                                                                                                      |
|--------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CLK_VALID <sup>(9)</sup> | Output | <b>Clock Output Valid:</b> The CLK_VALID output is a logical combination of the DCM status ports which give the best indication that the input clock has been locked to, the DCM is functioning properly, and the output clocks are valid. When asserted, indicates the output clocks are valid. |

#### Notes:

- 1. At least one input clock is required; any design has at least a CLK\_IN1 or a CLK\_IN1\_P/CLK\_IN1\_N port. A secondary input clock is supported for 7 series and Virtex-6 FPGAs only.
- 2. Dynamic reconfiguration ports are available for MMCM, MMCME2, PLLE2 or Spartan-6 FPGA DCM\_CLKGEN primitives.
- 3. Dynamic phase shift ports are available for MMCM, MMCME2 or Spartan-6 FPGA DCM primitives.
- 4. Exposure of every status and control port is individually selectable.
- 5. The power-down port is available for the 7 series MMCME2 and PLLE2 and Virtex-6 FPGA MMCM primitives.
- 6. The status port is available for the Spartan-6 FPGA DCM and DCM\_CLKGEN primitives.
- 7. The freeze port is available for the Spartan-6 FPGA DCM\_CLKGEN primitive.
- 8. The input clock stopped port is available for the MMCM, MMCME2 and Spartan-6 FPGA DCM and DCM\_CLKGEN primitives.
- 9. clk\_valid port is available for DCM and DCM\_CLKGEN.
- 10. This version of clocking wizard supports naming of ports as per requirements. The list mentioned in Table 1 is the default port list.

Table 2: Optional Attributes in HDL

| Attribute             | Description                                                                   |
|-----------------------|-------------------------------------------------------------------------------|
| CLK_OUT[1-7]_BUFR_DIV | The BUFR_DIVIDE attribute of clock outputs which have BUFR as output drivers. |

#### Support

Xilinx provides technical support for this LogiCORE IP product when used as described in the product documentation. Xilinx cannot guarantee timing, functionality, or support of product if implemented in devices that are not defined in the documentation, if customized beyond that allowed in the product documentation, or if changes are made to any section of the design labeled *DO NOT MODIFY*.

### **Ordering Information**

The LogiCORE IP Clocking Wizard core is provided free of charge under the terms of the <u>Xilinx End User License</u> <u>Agreement</u>. The core can be generated using the Xilinx ISE CORE Generator<sup>™</sup> software, which is a standard component of the Xilinx ISE Design Suite. This version of the core can be generated using the ISE software CORE Generator system v13.4.

For details, visit the <u>Clocking Wizard product web page</u>. Information about additional Xilinx LogiCORE IP modules is available at the <u>Xilinx IP Center</u>. For pricing and availability of other Xilinx LogiCORE IP modules and software, contact your local Xilinx <u>sales representative</u>.

#### References

For more Xilinx documentation, see <a href="http://www.xilinx.com/support/documentation/index.htm">www.xilinx.com/support/documentation/index.htm</a>.



# Chapter 1

# Introduction

This chapter introduces the Clocking Wizard core and provides related information, including recommended design experience, additional resources, technical support, and ways of submitting feedback to Xilinx. The Clocking Wizard core generates source Register Transfer Level (RTL) code to implement a clocking network matched to your requirements. Both Verilog and VHDL design environments are supported.

### **System Requirements**

For a list of System Requirements, see the ISE Design Suite 13.4: Release Notes Guide.

### About the Core

The Clocking Wizard is an ISE® CORE Generator<sup>™</sup> IP core, included with the latest ISE Design Suite release in the Xilinx® Download Center. The core is licensed under the terms of the Xilinx End User License and no FLEX license key is required.

### **Recommended Design Experience**

The Clocking Wizard is designed for users with any level of experience. Using the wizard automates the process of creating your clocking network and is highly recommended. The wizard guides users to the proper primitive configuration and allows advanced users to override and manually set any attribute. Although the Clocking Wizard provides a fully verified clocking network, understanding the Xilinx clocking primitives will aid users in making design trade-off decisions.

## **Additional Core Resources**

For details about the Clocking Wizard, perform these steps:

- Go to the Clocking Wizard section of the Architecture Wizards page: (www.xilinx.com/products/design\_resources/conn\_central/solution\_kits/wizards/ index.htm#clocking).
- 2. In the Clocking Wizards table, select **Documents** link in the column labeled Documents. The Clocking Wizard documents are listed.

## **Technical Support**

For technical support, go to <u>www.xilinx.com/support</u>. Questions are routed to a team with expertise using the Clocking Wizard core.

Xilinx provides technical support for use of this product as described in the *Clocking Wizard Getting Started Guide*. Xilinx cannot guarantee timing, functionality, or support of this product for designs that do not follow these guidelines.

## Feedback

Xilinx welcomes comments and suggestions about the Clocking Wizard and the accompanying documentation.

#### **Clocking Wizard**

For comments or suggestions about the Clocking Wizard, submit a WebCase from <u>www.xilinx.com/support/clearexpress/websupport.htm</u>. Be sure to include the following information:

- Product name
- Core version number
- Explanation of your comments

#### Document

For comments or suggestions about the Clocking Wizard core, submit a WebCase from <u>www.xilinx.com/support/clearexpress/websupport.htm</u>. Be sure to include the following information:

- Document title
- Document number
- Page number(s) to which your comments refer
- Explanation of your comments

## **XILINX**<sub>®</sub>

# Chapter 2

# Core Architecture

The Clocking Wizard generates source code HDL to implement a clocking network. The generated clocking network typically consists of a clocking primitive (DCM\_SP, DCM\_CLKGEN, PLL\_BASE, or MMCM\_ADV) plus some additional circuitry which typically includes buffers and clock pins. The network is divided into segments as illustrated in Figure 2-1. Details of these segments are described in the following sections.



Figure 2-1: Provided Clocking Network

### **Input Clocks**

Up to two input clocks are available for the clocking network. Buffers are optionally inserted on the input clock paths based on the buffer type that is selected.

## **Primitive Instantiation**

The primitive, either user or wizard selected, is instantiated into the network. Parameters on primitives are set by the wizard, and can be overridden by you. Unused input ports are tied to the appropriate values. Unused output ports are labeled as such.

## Feedback

If phase alignment is not selected, the feedback output port on the primitive is automatically tied to the feedback input port. If phase alignment with automatic feedback is selected, the connection is made, but the path delay is matched to that of CLK\_OUT1. If user-controlled feedback is selected, the feedback ports are exposed.

## **Output Clocks**

Buffers that are user-selected are added to the output clock path, and these clocks are provided to the user.

## I/O Signals

All ports are optional, with the exception that at least one input and one output clock are required. Availability of ports is controlled by user-selected parameters. For example, when Dynamic Reconfiguration is selected, only those ports related to Dynamic Reconfiguration are exposed to the user. Any port that is not exposed is either tied off or connected to a signal labeled *unused* in the delivered source code. Not all ports are available for all devices or primitives; for example, Dynamic Reconfiguration is a feature only available in Virtex<sup>®</sup>-6 FPGA Mixed-Mode Clock Manager (MMCM), 7 series FPGA MMCME2, PLLE2 or Spartan<sup>®</sup>-6 FPGA DCM\_CLKGEN primitives. See Table 1 for descriptions of the input and output ports provided from the clocking network and Table 2 for the optional HDL attributes.



# Chapter 3

# Generating the Core

This chapter describes the GUI and follows the same flow required to set up the clocking network requirements. Tool tips are available in the GUI for most features; place your mouse over the relevant text, and additional information is provided in a pop-up dialog.

### **Clocking Features**

The first page of the GUI allows you to identify the required features of the clocking network and configure the input clocks.

| uments View |               |                    |                  |                            |                 |                                  |             |                    |
|-------------|---------------|--------------------|------------------|----------------------------|-----------------|----------------------------------|-------------|--------------------|
| ymbol       | ₽ ×           | IndiCORE           |                  | locking M                  | lizard          |                                  |             |                    |
|             |               | LUYICA.            |                  |                            | rizai u         |                                  | xili        | inx.com:ip:clk_wiz |
|             |               | Component name     |                  | dk                         | uiz v2 2        |                                  | Clocki      | ing Feature        |
|             |               | Component name     |                  | CIK_                       | wiz_v3_5        |                                  | /1          | Input Clock        |
|             |               | Clashing Frankris  | _                |                            |                 |                                  |             |                    |
| CLK IN2     |               |                    | s                |                            |                 |                                  |             |                    |
|             | CLK_OUT2_CE   | Frequency sy       | nthesis          |                            |                 |                                  |             |                    |
|             | CLK_OUT2_CLR  | Phase alignm       | ent (known i     | nhase relationshin to in   | nut clock)      |                                  |             |                    |
|             |               | ridse diigini      | ienc (known j    | phase relationship to in   | put clock)      |                                  |             |                    |
|             | CLK_OUT3_CE   | Minimize pov       | ver              |                            |                 |                                  |             |                    |
|             | CLK_OUT3_CLR  | Dynamic nha        | co chift         |                            |                 | Primitive                        |             | – Input Jitter Un  |
| CLKFB_IN_N  |               | Dynamic pha        | ac anne          |                            |                 |                                  | 52 ADV      |                    |
|             | CLK_OUT4_CE   | Dynamic record     | onfiguration (   | in system output freq r    | nodification)   | MIMICMEZ_ADV O PL                | LEZ_AUV     |                    |
| RESET       | CLK_OUT4_CLR  | Jitter Optimiza    | tion             |                            |                 |                                  |             |                    |
| POWER_DOWN  |               |                    |                  |                            |                 |                                  |             |                    |
|             | CLK_OUT5_CE   | Balanced           |                  |                            |                 |                                  |             |                    |
|             | CLK_OUT5_CLR  | Minimize o         | utput jitter (le | ow clock jitter filtering) |                 |                                  |             |                    |
| DADDR[6:0]  |               | Maximize in        | nput jitter filt | ering (allow larger inpu   | t jitter)       |                                  |             |                    |
|             | CLK_OUT8_CE   |                    |                  |                            |                 |                                  |             |                    |
| DEN>        | CLK_OUT8_CLR  | Input Clock Infor  | mation           |                            |                 |                                  |             |                    |
|             |               |                    | Inn              | ut Frog (MHz)              |                 |                                  |             |                    |
|             |               | Input Clock        | шр               |                            | Input Jitter    | Source                           |             |                    |
| DWE         | CER_DON_CER   |                    | Value            | Valid Range                |                 |                                  |             |                    |
| UNC         |               | primary            | 100.000          | 10.000 - 1066.000          | 0.010           | Single ended clock capable pin   | •           |                    |
|             | CLKFB STOPPED | secondary          | 100.000          | 37.500 - 266.667           | 0.010           | Single ended clock capable pin   | -           |                    |
| PSCLK       |               |                    |                  |                            |                 |                                  |             |                    |
| PSEN>       |               |                    |                  |                            |                 |                                  |             |                    |
| PSINCDEC    |               |                    |                  |                            |                 |                                  |             |                    |
|             |               |                    |                  |                            |                 |                                  |             |                    |
|             |               | The IP Symbol sho  | own on the le    | ft describes the input a   | nd output ports | provided from the clocking netwo | rk. Note th | hat the names of   |
|             |               | these ports do not | necessarily      | match the pins of an M     | MCM.            |                                  |             |                    |
|             |               |                    |                  |                            |                 |                                  |             |                    |
|             |               | Datasheet          |                  |                            | < Back Pa       | ge 1 of 6 Next > Genera          | ite Ca      | ancel Hel          |

Figure 3-1: Main Screen - Clocking Features (7 Series FPGA Version Depicted)

### **Selecting Clocking Features**

The available clocking features are shown for the selected target device. You can select as many features as desired; however, some features consume additional resources, and some can result in increased power consumption. Additionally, certain combinations of features are not allowed. The GUI will either dim out or hide features which are unavailable.

For example, the Dynamic Reconfiguration Port checkbox is not available for selection in the case of DCM and PLL\_BASE as both of these do not support this feature.

Clocking features include:

- **Frequency synthesis**. This feature allows output clocks to have different frequencies than the active input clock.
- **Phase alignment**. This feature allows the output clock to be phase locked to a reference, such as the input clock pin for a device.
- **Minimize power**. This features minimizes the amount of power needed for the primitive at the possible expense of frequency, phase offset, or duty cycle accuracy.
- **Dynamic phase shift**. This feature allows you to change the phase relationship on the output clocks.
- **Dynamic reconfiguration**. This feature allows you to change the programming of the primitive after device configuration. When this option is chosen, the clocking wizard uses only integer values for M, D and CLKOUT[0:6]\_DIVIDE.
- **Balanced**. Selecting Balanced results in the software choosing the correct BANDWIDTH for jitter optimization.
- **Minimize output jitter.** This feature minimizes the jitter on the output clocks, but at the expense of power and possibly output clock phase error. This feature is not available with 'Maximize input jitter filtering'.
- Maximize input jitter filtering. This feature allows for larger input jitter on the input clocks, but can negatively impact the jitter on the output clocks. This feature is not available with 'Minimize output jitter'.

#### Clock Manager Type (Primitive Selection)

7 series devices contain MMCME2 and PLLE2 primitives for the clocking needs. The user has the option to configure either of these by selecting the primitive.Virtex®-6 devices contain MMCM primitives, which encapsulate all clocking needs. Therefore, the Clock Manager Type option is not available for a Virtex-6 FPGA based project. For a Spartan®-6 FPGA based project, the wizard automatically picks the appropriate primitive (DCM\_SP, DCM\_CLKGEN, or PLL\_BASE), based on the other clocking features you select. You can force the use of a specific primitive by selecting "Manual Selection" and choosing the desired primitive. Functionality not available for that primitive, such as specific clocking features, is shown as unavailable.

For Spartan-6 devices, the wizard supports DCM to PLL and PLL to DCM cascades. To have the cascading implemented, the user has to manually select the "DCM\_SP" primitive and them choose the type of cascading needed. The Wizard allows only one clock to be configured when DCM to PLL cascade is chosen. The user can configure up to six clocks when PLL to DCM cascade is chosen. In both the cases, the PLL is used only to reduce the clock jitter. PLL does not do any frequency synthesis.

#### **Configuring Input Clocks**

For Virtex-6 and 7 series FPGAs, you can enable an additional input clock. Select the box next to the secondary input clock to enable the additional input clock. Depending on the frequency of the secondary input clock, this can cause a less ideal network to be created than might be possible if just the primary input clock was present (more output jitter, higher power, etc.)

Enter the frequency and peak-to-peak period (cycle) jitter for the input clocks. The wizard then uses this information to create the clocking network. Additionally, a UCF (user constraint file) is created using the values entered. For the best calculated clocking parameters, it is best to fully specify the values. For example, for a clock requirement of 33 1/3 MHz, enter 33.333 MHz rather than 33 MHz.

You can select which buffer type drives your input clock, and this is then instantiated in the provided source code. If your input buffers are located externally, selecting "No buffer" leaves the connection blank. If Phase Alignment is selected, you do not have access to pins that are not dedicated clock pins, because the skew introduced by a non-clock pin is not matched by the primitive.

You can choose the units for input clock jitter by selecting either the UI or PS radio button. The input jitter box accepts the values based on this selection.

For Spartan-6 FPGA designs, the ISE® tool chain infers BUFIO2 for input clock routing which is not part of the generated HDL.

## **Output Clock Settings**

The second page of the GUI (Figure 3-2) configures requirements for the output clocks. Each selected output clock can be configured on this screen.

| Clocking wizan | d                  |              |                    |                   |               |                       |           |               |         |              |                    |
|----------------|--------------------|--------------|--------------------|-------------------|---------------|-----------------------|-----------|---------------|---------|--------------|--------------------|
| Documents Vie  | ew                 |              |                    |                   |               |                       |           |               |         |              |                    |
| IP Symbol      |                    | e ×          | CORE               |                   | lock          | na 14/i-              | ond       |               |         |              |                    |
|                |                    |              | logic              | , c               | JOCKI         |                       | aru       |               |         | xili         | nx.com:ip:clk_wiz: |
|                |                    |              |                    |                   |               |                       |           |               |         |              | Output             |
|                |                    |              |                    |                   |               |                       |           |               |         |              | Clock              |
|                |                    |              | The abase is cal   | والمتعاور المعقار |               | to a state of a state |           |               |         |              | Settings           |
|                |                    |              | i ne pnase is cale | culated relative  | to the active | е прит сюск.          |           |               |         |              | Sectings           |
|                | CLK_IN2            |              | Output Clock       | Output Fre        | eq (MHz)      | Phase (d              | egrees)   | Duty Cy       | cle (%) | Drives       | Use                |
|                |                    | CLK_OUT2_CE  | output clock       | Requested         | Actual        | Requested             | Actual    | Requested     | Actual  | Dives        | Fine Ps            |
|                |                    | CLK_OUT2_CLR | CLK_OUT1           | 100.000           | 100.000       | 0.000                 | 0.000     | 50.000        | 50.0    | BUFG 👻       |                    |
|                |                    |              |                    | 100.000           | NI/A          | 0.000                 | NI/A      | E0.000        | NI/A    | PUEC -       |                    |
|                |                    | CLK_OUT3_CE  | CLK_0012           | 100.000           | N/A           | 0.000                 | N/A       | 50.000        | N/A     | burg +       |                    |
|                |                    | CLK_OUT3_CLR | CLK_OUT3           | 100.000           | N/A           | 0.000                 | N/A       | 50.000        | N/A     | BUFG 👻       |                    |
|                | CLKFB_IN_N>        |              | CLK_OUT4           | 100.000           | N/A           | 0.000                 | N/A       | 50.000        | N/A     | BUFG 👻       |                    |
|                | RESET              |              |                    | 100.000           | NI/A          | 0.000                 | NI/A      | E0 000        | N1/A    | PUEC -       |                    |
|                | POWER_DOWN         |              | CLK_0015           | 100.000           | N/A           | 0.000                 | N/A       | 50.000        | N/A     | BUFG +       |                    |
|                |                    | CLK_OUT5_CE  | CLK_OUT6           | 100.000           | N/A           | 0.000                 | N/A       | 50.000        | N/A     | BUFG 👻       |                    |
|                |                    | CLK_OUT5_CLR | CLK_OUT7           | 100.000           | N/A           | 0.000                 | N/A       | 50.000        | N/A     | BUFG 👻       |                    |
|                | DADDR[6:0]         |              |                    |                   |               |                       |           |               |         |              |                    |
|                |                    | CLK_OUT8_CE  |                    |                   |               |                       |           |               |         |              |                    |
|                | DEN>               | CLK_OUT8_CLR |                    |                   |               |                       |           |               |         |              |                    |
|                | DIN[15:0]          |              |                    |                   |               |                       |           |               |         |              |                    |
|                | DOUT[15:0]         | CLK_OUT7_CE  |                    |                   |               |                       |           |               |         |              |                    |
|                |                    | CLK_OUT/_CLR |                    |                   |               |                       |           |               |         |              |                    |
|                | DWE                |              |                    |                   |               |                       |           |               |         |              |                    |
|                |                    |              |                    |                   |               |                       |           |               |         |              |                    |
|                | PSCLK              | · _          |                    |                   |               |                       |           |               |         |              |                    |
|                | PSEN               |              |                    |                   |               |                       |           |               |         |              |                    |
|                | PSINCDEC           |              |                    |                   |               |                       |           |               |         |              |                    |
|                |                    |              |                    |                   |               |                       |           |               |         |              |                    |
|                |                    |              |                    |                   |               |                       |           |               |         |              |                    |
|                |                    |              |                    |                   |               |                       |           |               |         |              |                    |
|                |                    |              | Detectorst         |                   |               |                       | De els De |               |         |              |                    |
| 🏺 IP Symbol    | 🧳 Resource Estimat | ion          | Datasneet          |                   |               | <                     | васк Ра   | ige 2 01 6 Ne | ext >   | Sellerate Ca | псеі неір          |

Figure 3-2: Output Clock Settings Screen (7 Series FPGA Version Depicted)

#### **Configuring Output Clocks**

To enable an output clock, click on the box located next to it. Output clocks must be enabled sequentially.

You can specify values for the output clock frequency, phase shift, and duty cycle assuming that the primary input clock is the active input clock. The clocking wizard attempts to derive a clocking network that meets your criteria exactly. In the event that a solution cannot be found, best attempt values are provided and are shown in the actual value column. Achieving the specified output frequency takes precedence over implementing the specified phase, and phase in turn takes higher precedence in the clock network derivation process than duty cycle. The precedence of deriving the circuits for the CLK\_OUT signals is CLK\_OUT1 > CLKOUT2 > CLKOUT3, and so on. Therefore, finding a solution for CLK\_OUT1 frequency has a higher priority. Values are recalculated every time an input changes. Because of this, it is best to enter the requirements from top to bottom and left to right. This helps to pinpoint requested values that cannot be supported exactly.

If phase alignment is selected, the phase shift is with respect to the active input clock. If phase alignment is not selected, phase shift is with respect to CLK\_OUT1.

Not all primitives allow duty- cycle specification. For example, a DCM\_SP is restricted to a 50/50 duty cycle. In the event that duty cycle cannot be specified, the requested column is dimmed.

You can choose which type of buffer is instantiated to drive the output clocks, or "No buffer" if the buffer is already available in external code. The buffers available depend on your device family. For all outputs that have BUFR as the output driver, the "BUFR\_DIVIDE" attribute is available as a generic parameter in the HDL. The user can change the divide value of the BUFR while instantiating the design.

If you choose the **Dynamic phase shift** clocking feature in a 7 series and Virtex-6 FPGA design, the 'Use Fine Ps' check boxes are available. 'Use Fine Ps' allows you to enable the Variable Fine Phase Shift on MMCM and MMCME2. Select the appropriate check box for any clock that requires dynamic phase shift. The wizard resets the requested phase field to "0.000" when 'Use Fine Ps' is selected. See the <u>Virtex-6 FPGA Clocking Resources User</u> <u>Guide</u> for more details.

## Feedback and I/O

The third GUI screen (Figure 3-3) provides information to configure the rest of the clocking network.

| Documents View                        |                           |                                  |                                  |
|---------------------------------------|---------------------------|----------------------------------|----------------------------------|
| IP Symbol 🗗                           | × PE                      |                                  |                                  |
|                                       | Logic Nart                | locking wizard                   | xilinx.com:ip:clk_wiz:3.3        |
|                                       | Optional Inputs / Outputs | Clock Feedback Source            | I/O and                          |
|                                       |                           | Automatic control on-chip        | Feedback                         |
| CLK_OUT1_CE                           | RESET                     | Automatic control off chip       |                                  |
| CLK_OUT1_CLR                          |                           | Automatic control on-chip        |                                  |
| $CLK_IN2 \longrightarrow CLK_OUT2$    |                           | Our User-controlled on-chip      |                                  |
| ( CLK_OUT2_CE                         |                           | User-controlled off-chip         |                                  |
| CLK_OUT2_CLR                          |                           |                                  |                                  |
|                                       | INFOT_CEK_STOFFED         | Clock Feedback Signaling         |                                  |
| CLK_OUT3_CE                           |                           |                                  |                                  |
| CLK_OUT3_CLR                          | POWER_DOWN                | Single-ended                     |                                  |
| $CLKFB_IN_N \longrightarrow CLK_OUT4$ |                           |                                  |                                  |
| KCLK_OUT4_CE                          | CLKFBSTOPPED              | <ul> <li>Differential</li> </ul> |                                  |
| RESET CLK_OUT4_CLR                    |                           |                                  |                                  |
| POWER_DOWN                            |                           |                                  |                                  |
| K CLK_OUT5_CE                         |                           |                                  |                                  |
| ( CLK_OUT5_CLR                        |                           |                                  |                                  |
|                                       |                           |                                  |                                  |
|                                       |                           |                                  |                                  |
|                                       |                           |                                  |                                  |
| DIN[15:0]> CLK_OUT7                   |                           |                                  |                                  |
|                                       |                           |                                  |                                  |
|                                       |                           |                                  |                                  |
| DWE>                                  |                           |                                  |                                  |
| INPUT_CLK_STOPPED                     |                           |                                  |                                  |
|                                       |                           |                                  |                                  |
| PSCLK                                 |                           |                                  |                                  |
|                                       |                           |                                  |                                  |
|                                       |                           |                                  |                                  |
|                                       |                           |                                  |                                  |
|                                       |                           |                                  |                                  |
|                                       |                           |                                  |                                  |
|                                       | Datasheet                 | < Back Page 3 of 6               | Next > Cenerate Cancel Help      |
| 🍕 IP Symbol 🍕 Resource Estimation     | Dutasitet                 | - Dack Tage 5 of 0               | itext / Generate / Cancer / Help |

Figure 3-3: Feedback, and I/O Configuration Screen (7 Series FPGA Version Depicted)

#### Selecting Optional Ports

All other optional ports that are not handled by selection of specific clocking features are listed under Optional Inputs/Outputs. Click to select the ports that you wish to make visible; inputs that are unused are tied off appropriately, and outputs that are unused are labeled as such in the provided source code.

#### **Choosing Feedback**

Feedback selection is only available when phase alignment is selected. When phase alignment is not selected, the output feedback is directly connected to the input feedback. For designs with phase alignment, choose automatic control on-chip if you want the feedback path to match the insertion delay for CLK\_OUT1. You can also select user-controlled feedback if the feedback is in external code. If the path is completely on the FPGA, select on-chip; otherwise, select off-chip.

For designs that require external feedback and related I/O logic, choose automatic control off-chip feedback. You can choose either single-ended or differential feedback in this mode. The wizard generates the core logic and logic required to route the feedback signals to the I/O.

## **Primitive Overrides**

One or more pages of device and primitive specific parameter overrides are displayed, as shown in Figure 3-4.

| Clocking Wizard                 |                |                                                              |                                              |                                                                            |                           |
|---------------------------------|----------------|--------------------------------------------------------------|----------------------------------------------|----------------------------------------------------------------------------|---------------------------|
| Documents View                  |                |                                                              |                                              |                                                                            |                           |
| IP Symbol                       | 8 ×            | Logi CRE                                                     | Clocking                                     | Wizard                                                                     | xilinx.com:ip:clk_wiz:3.3 |
| cuk_in1→                        |                | These are the settings based settings found by the wizard, a | on your input. If you<br>and selections made | change them, you may lose the optimal<br>on previous pages will not apply. | MMCM_ADV<br>Settings      |
| 0.11.110                        | CLK_OUT1_CLR   | Allow override mode (mail                                    | nual edits to MMCM a                         | attributes)                                                                |                           |
|                                 |                | Attribute                                                    | Value                                        |                                                                            |                           |
|                                 |                | BANDWIDTH                                                    | OPTIMIZED -                                  |                                                                            |                           |
|                                 | → CLK_OUT3     | CLKFBOUT_MULT_F                                              | 10.000                                       |                                                                            |                           |
|                                 | CLK OUT3 CE    | CLKFBOUT_PHASE                                               | 0.000                                        |                                                                            |                           |
|                                 | CLK_OUT3_CLR   | CLKFBOUT_USE_FINE_PS                                         |                                              |                                                                            |                           |
| CLKFB_IN_N                      |                | CLKIN1 PERIOD                                                | 10.000                                       |                                                                            |                           |
|                                 | CLK_OUT4_CE    | CLKIN2 PERIOD                                                | 10.000                                       |                                                                            |                           |
| RESET                           | CLK_OUT4_CLR   | CLKOUT4_CASCADE                                              |                                              |                                                                            |                           |
| POWER_DOWN                      |                |                                                              |                                              | -                                                                          |                           |
|                                 | CLK_OUT5_CE    | COMPENSATION                                                 | 74010 *                                      |                                                                            |                           |
|                                 | CLK_OUT5_CLR   |                                                              | 1                                            |                                                                            |                           |
| DADDR[6:0]                      |                |                                                              | 1 0.010                                      |                                                                            |                           |
|                                 | CLK_OUT8_CE    | REF_JITTERI                                                  | 0.010                                        |                                                                            |                           |
| DEN>                            | CLK_OUT8_CLR   | REF_JITTERZ                                                  | 0.010                                        |                                                                            |                           |
| DIN[15:0]                       |                | STARTUP_WAIT                                                 |                                              |                                                                            |                           |
| DOUT[15:0]                      | CLK_OUT7_CE    | CLKOUT0_DIVIDE_F                                             | 10.000                                       |                                                                            |                           |
| DRDY                            | CLK_OUT7_CLR   | CLKOUT0_DUTY_CYCLE                                           | 0.500                                        |                                                                            |                           |
| DWE                             |                | CLKOUT0_PHASE                                                | 0.000                                        |                                                                            |                           |
|                                 |                | CLKOUT0_USE_FINE_PS                                          |                                              |                                                                            |                           |
| PSCI K                          | J GERE STOFFED |                                                              |                                              |                                                                            |                           |
| PSEN                            |                |                                                              |                                              |                                                                            |                           |
| PSINCDEC                        |                | Notes to be included in the co                               | mments of the gener                          | rated component:                                                           |                           |
|                                 |                | None                                                         |                                              |                                                                            |                           |
|                                 |                |                                                              |                                              |                                                                            |                           |
|                                 |                |                                                              |                                              |                                                                            |                           |
|                                 |                |                                                              |                                              |                                                                            |                           |
| 🍯 IP Symbol 🦉 Resource Estimati | ion            | Datasheet                                                    |                                              | Sack Page 4 of 6 Next > G                                                  | enerate Cancel Help       |
| V I Symbol V Resource Estimat   |                |                                                              |                                              |                                                                            |                           |

Figure 3-4: Primitive Override Screen (7 Series FPGA Version Depicted)

#### **Overriding Calculated Parameters**

The clocking wizard selects optimal settings for the parameters of the clocking primitive. You can override any of these calculated parameters if you wish. By selecting "Allow override mode," the overridden values are used rather than the calculated values as primitive parameters. The wizard uses the settings as shown on this screen for any timing calculations, and any settings changed here are reflected in the summary pages. It is important to verify that the values you are choosing to override are correct because the wizard implements what you have chosen even if it causes issues with the generated network. Parameters listed are relevant for the physical clocks on the primitive, rather than the logical clocks created in the source code. For example, to modify the settings calculated for the highest priority CLK\_OUT1, you actually need to modify CLKOUT0\* parameters, and not the CLKOUT1\* parameters for a MMCM or PLL.

*Note:* For Virtex-6 FPGA designs, certain combinations of CLKIN frequency and DIVCLK\_DIVIDE are not allowed when the BANDWIDTH chosen is HIGH. In such cases, the wizard automatically sets the BANDWIDTH to OPTIMIZED.

### **User Provided Comment**

The generated source code contains the input and output clock summaries shown in the next summary page (Figure 3-5). You can manually add an additional comment in the box at the bottom of the page. Use underscores in place of spaces.

## **Clock Summary (First Page)**

The first summary page (Figure 3-5) displays summary information about the input and output clocks. This information is also provided as comments in the generated source code, and in the provided UCF.

| 🍳 Clocking Wizard                 |              |                 |             |              |             |            |             |             |                           |
|-----------------------------------|--------------|-----------------|-------------|--------------|-------------|------------|-------------|-------------|---------------------------|
| Documents View                    |              |                 |             |              |             |            |             |             |                           |
| IP Symbol                         | 8 ×          | allow           |             |              |             |            |             |             |                           |
|                                   |              | [ogiC??K⊏       |             | Clocki       | ng Wiz      | ard        |             |             | xilinx.com:in:clk_wiz:3.3 |
|                                   |              |                 |             |              |             |            |             |             |                           |
|                                   |              |                 |             |              |             |            |             |             | Clock                     |
|                                   |              | Input Clock Sur | nmary       |              |             |            |             |             | Summary,                  |
|                                   | CLK_OUT1_CE  | Transfer Claude | Death Name  | Input Freq I | nput Jitter |            |             |             | Port                      |
|                                   | CLK_OUT1_CLR | приссюск        | Port Name   | (MHz)        | (UI)        |            |             |             | Naming                    |
| CLK_IN2                           | → CLK_OUT2   | primary         | CLK_IN1     | 100.000      | 0.010       |            |             |             |                           |
|                                   | CLK_OUT2_CE  |                 |             |              |             |            |             |             |                           |
|                                   | CLK_OUT2_CLR |                 |             |              |             |            |             |             |                           |
|                                   | → CLK_OUT3   |                 |             |              |             |            |             |             |                           |
|                                   | CLK_OUT3_CE  | Output Clock Si | ummary      |              |             |            |             |             |                           |
|                                   | CLK_OUT3_CLR |                 | 000 000 MU  |              |             |            |             |             |                           |
|                                   | → CLK_OUT4   | VCO Freq = 1    | 000.000 MHz |              |             |            |             |             |                           |
|                                   | CLK_OUT4_CE  |                 |             |              |             |            |             |             |                           |
| RESET                             | CLK_OUT4_CLR |                 |             | Output Fr    | Phase       | Duty Cycle | Pk-to-Pk    | Phase Error |                           |
| POWER_DOWN                        |              | Output Cloc     | k Port Nam  | e (MHz)      | (degrees)   | (%)        | Jitter (ps) | (ps)        |                           |
|                                   | CLK_OUT5_CE  |                 |             |              |             |            |             |             |                           |
|                                   | CLK_OUT5_CLR | CLK_OUT1        | CLK_0011    | 100.000      | 0.000       | 50.0       | 130.958     | 98.575      |                           |
| DADDR[6:0]                        | > CLK_OUT8   |                 |             |              |             |            |             |             |                           |
|                                   | CLK_OUT8_CE  |                 |             |              |             |            |             |             |                           |
|                                   | CLK_OUT8_CLR |                 |             |              |             |            |             |             |                           |
| DIN[15:0]                         | → CLK_OUT7   |                 |             |              |             |            |             |             |                           |
| DOUT[15:0]                        | CLK_OUT7_CE  |                 |             |              |             |            |             |             |                           |
|                                   | CLK_OUT7_CLR |                 |             |              |             |            |             |             |                           |
| DWE                               |              |                 |             |              |             |            |             |             |                           |
|                                   |              |                 |             |              |             |            |             |             |                           |
|                                   |              |                 |             |              |             |            |             |             |                           |
| PSCLK                             |              | Other Pir       | ns Port     | Name         |             |            |             |             |                           |
| PSEN                              |              | DECET           | DECET       |              |             |            |             |             |                           |
| PSINCDEC                          |              | RESET           | KESEI       |              |             |            |             |             |                           |
| PSDONE -                          |              | LOCKED          | LOCKE       | D            |             |            |             |             |                           |
|                                   |              |                 |             |              |             |            |             |             |                           |
|                                   |              |                 |             |              |             |            |             |             |                           |
|                                   |              |                 |             |              | _           |            |             |             |                           |
| 🍯 IP Symbol 🔇 Resource Estimation |              | Datasheet       |             |              | <           | Back Page  | 5 of 6 Next | > Generate  | Cancel Help               |
| / moor                            |              |                 |             |              |             |            |             |             |                           |

Figure 3-5: Clock Summary Screen

#### Input Clocking Summary

Information entered on the first page of the GUI (Figure 3-1) is shown for the input clocks.

#### **Output Clocking Summary**

Derived timing information for the output clocks is shown. If the chosen primitive has an oscillator, the VCO frequency is provided as reference. If you have a secondary input clock enabled, you can choose which clock is used to calculate the derived values.

#### **Port Names**

The Wizard allows users to name the ports according to their needs. If users want to name the HDL port for primary clock input, they should simply type in the necessary port name in the adjacent text box. The text boxes have the default names in them.

In the case of Primary clock input the default name is CLK\_IN1.

**Note:** Be careful. Changing the port names could result in syntax errors if the port name entered is any reserved word of VHDL or Verilog or if that signal is already declared in the module.

## **Core Summary (Second Page)**

The second summary page (Figure 3-6) contains general summary information.

| Documents View                    |            |                          |                    |                    |                                                     |                                          |                    |                    |                    |                           |
|-----------------------------------|------------|--------------------------|--------------------|--------------------|-----------------------------------------------------|------------------------------------------|--------------------|--------------------|--------------------|---------------------------|
|                                   |            |                          |                    |                    |                                                     |                                          |                    |                    |                    |                           |
| ? Symbol                          | ₽×         |                          | -                  |                    |                                                     |                                          |                    |                    |                    |                           |
|                                   | LogiC      |                          | C                  | OCKI               | ng W                                                | zard                                     |                    |                    |                    | xilinx.com:ip:clk_wiz:3.3 |
|                                   |            |                          |                    |                    |                                                     |                                          |                    |                    |                    | <b>C</b>                  |
|                                   | XPower Es  | timator inp              | ut paramete        | ers                |                                                     |                                          |                    |                    |                    | Core                      |
|                                   | Cor        | e Name                   | Input C            | lock (MHz)         | Phase Shi                                           | ft                                       |                    |                    |                    | Summary                   |
|                                   | clky       | viz v3 3                 | 10                 | 0 000              | None                                                |                                          |                    |                    |                    |                           |
|                                   | CIK_V      | viz_v3_3                 | 10                 | 0.000              | None                                                |                                          |                    |                    |                    |                           |
| CLK_OUT2_CE                       |            |                          |                    |                    |                                                     |                                          |                    |                    |                    |                           |
| CLK_OUT2_CLR                      | Divide     | Mult                     | CLKOUTO<br>Divider | CLKOUT1<br>Divider | CLKOUT2<br>Divider                                  | CLKOUT3<br>Divider                       | CLKOUT4<br>Divider | CLKOUT5<br>Divider | CLKOUT6<br>Divider |                           |
| > CLK_OUT3                        | 1          | 10.000                   | 10.000             | off                | off                                                 | off                                      | off                | off                | off                |                           |
| CLK_OUT3_CE                       | -          | 10.000                   | 10.000             | UII                | UII                                                 | on                                       | 011                | on                 | UII                |                           |
| CLK_OUT3_CLR                      | Congrated  | filoc                    |                    |                    |                                                     |                                          |                    |                    |                    |                           |
| CLKFB_IN_N                        | Generated  | nies                     |                    |                    |                                                     |                                          |                    |                    |                    |                           |
| ( CLK_OUT4_CE                     |            | File N                   | lame               |                    | Description                                         |                                          |                    |                    |                    |                           |
| RESET                             | clk_wiz_v  | 3_3. (v   v              | hd)                |                    | Verilog or VH                                       | IDL clocking                             | network so         | urce               |                    |                           |
| POWER_DOWN -> CLK_OUTS            | clk_wiz_v  | 3_3. (veo                | vho)               | 1                  | Verilog or VH                                       | IDL instantia                            | iation template    |                    |                    |                           |
|                                   | clk_wiz_v  | 3_3/clk_wi               | iz_v3_3.ucf        | 1                  | Example con                                         | ple constraints file                     |                    |                    |                    |                           |
|                                   | clk_wiz_v  | 3_3/clk_wi               | iz_readme.t        | xt I               | README file                                         | ME file for the core                     |                    |                    |                    |                           |
|                                   | clk_wiz_v  | 3_3.xco                  |                    |                    | CORE Genera                                         | ORE Generator file used to recreate core |                    |                    |                    |                           |
|                                   | clk wiz v  | 3 3 flist.tx             | đ                  |                    | Synthesis tools integration file for the core       |                                          |                    |                    |                    |                           |
| DIN[15:0]                         | clk wiz v  | 2 2 ymdft                | tel                |                    | Project Navigator integration file for the core     |                                          |                    |                    |                    |                           |
|                                   | cik_vviz_v | 0_0/dee                  | ici -              |                    | Dina stars for                                      | decuments                                |                    | d with the         |                    |                           |
|                                   | CIK_WIZ_V  | 3_3/00C                  |                    |                    | Directory for                                       | documenta                                | uon delivere       | a with the i       | tore               |                           |
| DWE                               | clk_wiz_v  | clk_wiz_v3_3/example_des |                    |                    | Directory for synthesizable example design          |                                          |                    |                    |                    |                           |
| → INPUT_CLK_STOPPED               |            | 3_3/impler               | ment               |                    | Directory for files to implement the example design |                                          |                    | sign               |                    |                           |
|                                   | clk_wiz_v  | 3_3/simula               | ation              | I                  | Directory tree                                      | e for simula                             | table test b       | ench and co        | ntrol              |                           |
|                                   |            |                          |                    |                    |                                                     |                                          |                    |                    |                    |                           |
|                                   |            |                          |                    |                    |                                                     |                                          |                    |                    |                    |                           |
|                                   |            |                          |                    |                    |                                                     |                                          |                    |                    |                    |                           |
|                                   |            |                          |                    |                    |                                                     |                                          |                    |                    |                    |                           |
|                                   |            |                          |                    |                    |                                                     |                                          |                    |                    |                    |                           |
|                                   |            |                          |                    |                    | _                                                   |                                          |                    |                    |                    |                           |
| 🖞 IP Symbol 🐧 Resource Estimation | Datasheet  | J                        |                    |                    |                                                     | < Back                                   | Page 6 of 6        | Next >             | Generate           | e Cancel Help             |

*Figure 3-6:* Core Summary Screen

#### **Resource Estimate Summary**

A resource estimate is provided based on the chosen clocking features.

#### **XPower Estimator Summary**

Input parameters to the Xpower tool are provided.

### File Report Summary

A summary of created output files is provided. See Chapter 4, Detailed Example Design.



# Chapter 4

## Detailed Example Design

This chapter provides detailed information about the example design, including a description of files and the directory structure generated by the Xilinx<sup>®</sup> CORE Generator<sup>TM</sup> software, the purpose and contents of the provided scripts, the contents of the example HDL wrappers, and the operation of the demonstration test bench.

#### interfect directory>

Top-level project directory; name is user-defined

| ò | <pre><pre>Core</pre></pre> | ject directory>/ <component name=""><br/>e release notes file</component>                                                                             |
|---|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | ò                          | <component name="">/doc<br/>Product documentation</component>                                                                                         |
|   | ò                          | <component name="">/example design<br/>Verilog and VHDL design files</component>                                                                      |
|   |                            | <component name="">/implement<br/>Implementation script files</component>                                                                             |
|   |                            | <ul> <li>implement/results</li> <li>Results directory, created after implementation scripts are run, and contains implement script results</li> </ul> |
|   |                            | <component name="">/simulation<br/>Simulation scripts</component>                                                                                     |
|   |                            | imulation/functional<br>Functional simulation files                                                                                                   |
|   |                            | simulation/timing Timing simulation files                                                                                                             |

## **Directory and File Contents**

The clocking wizard core directories and their associated files are defined in the following sections.

#### <project directory>

The <project directory> contains all the CORE Generator software project files.

#### Table 4-1: Project Directory

| Name                                             | Description                                                                                                          |
|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| <project_d:< th=""><th>ir&gt;</th></project_d:<> | ir>                                                                                                                  |
| <component_name>.v[hd]</component_name>          | Verilog or VHDL source code.                                                                                         |
| <component_name>.xco</component_name>            | CORE Generator software project-<br>specific option file; can be used as an<br>input to the CORE Generator software. |
| <component_name>_flist.txt</component_name>      | List of files delivered with the core.                                                                               |
| <component_name>.{veo   vho}</component_name>    | VHDL or Verilog instantiation template.                                                                              |
| <component_name>.ise</component_name>            | Files used to incorporate the core into an $ISE^{\mathbb{R}}$ software project.                                      |

Back to Top

#### <project directory>/<component name>

The <component name> directory contains the readme file provided with the core, which can include last-minute changes and updates.

#### Table 4-2: Component Name Directory

| Name                                                                    | Description                                                                                                                                                                                                                 |
|-------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <project_dir>/<co< td=""><td>omponent_name&gt;</td></co<></project_dir> | omponent_name>                                                                                                                                                                                                              |
| clocking_wizard_v3_3_readme.txt                                         | Clocking Wizard v3.3 readme file.                                                                                                                                                                                           |
| <component_name>.ucf</component_name>                                   | Constraint files containing the timing<br>parameters for the created clock network.<br>The output clock constraints are commented<br>out, but can be cut and pasted into constraint<br>files for use in downstream modules. |

Back to Top

#### <component name>/example design

The example design directory contains the example design files provided with the core.

Table 4-3: Example Design Directory

| Name                                                                                         | Description                                                                              |  |  |  |  |
|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|--|--|--|--|
| <project_dir>/<componer< td=""><td>nt_name&gt;/example_design</td></componer<></project_dir> | nt_name>/example_design                                                                  |  |  |  |  |
| <component_name>_exdes.v[hd]</component_name>                                                | Implementable Verilog or VHDL example design, with all created clocks driving a counter. |  |  |  |  |

Back to Top

#### <component name>/doc

The doc directory contains the PDF documentation provided with the core.

#### Table 4-4: Doc Directory

| Name                                                              | Description                     |  |  |  |  |  |
|-------------------------------------------------------------------|---------------------------------|--|--|--|--|--|
| <project_dir>/<component_name>/doc</component_name></project_dir> |                                 |  |  |  |  |  |
| ug521_clk_wiz.pdf                                                 | Clocking Wizard v3.3 User Guide |  |  |  |  |  |

Back to Top

#### <component name>/implement

The implement directory contains the core implementation script files for ISE as well as PlanAhead<sup>TM</sup> software.

#### Table 4-5: Implement Directory

| Name                                                                    | Description |  |
|-------------------------------------------------------------------------|-------------|--|
| <project_dir>/<component_name>/implement</component_name></project_dir> |             |  |
| Scripts and projects to implement the example design                    |             |  |

Back to Top

#### implement/results

The results directory is created by the implement script, after which the implement script results are placed in the results directory.

#### Table 4-6: Results Directory

| Name                                                                            | Description |  |
|---------------------------------------------------------------------------------|-------------|--|
| <project_dir>/<component_name>/implement/results</component_name></project_dir> |             |  |
| Implement script result files.                                                  |             |  |

Back to Top

#### <component name>/simulation

The simulation directory contains the simulation test bench and environment for the

#### example design. *Table 4-7:* **Simulation Directory**

| Name                                                                     | Description              |  |
|--------------------------------------------------------------------------|--------------------------|--|
| <project_dir>/<component_name>/simulation</component_name></project_dir> |                          |  |
| <component_name>_tb.v[hd]</component_name>                               | Demonstration test bench |  |

Back to Top

#### simulation/functional

The functional directory contains functional simulation scripts. *Table 4-8:* **Functional Directory** 

| Name                                                                                | Description |  |
|-------------------------------------------------------------------------------------|-------------|--|
| <project_dir>/<component_name>/simulation/functional</component_name></project_dir> |             |  |
| Contains simulation scripts and waveform formats.                                   |             |  |

Back to Top

#### simulation/timing

The timing directory contains timing simulation scripts. *Table 4-9:* **Functional Directory** 

| Name                                                                            | Description |  |
|---------------------------------------------------------------------------------|-------------|--|
| <project_dir>/<component_name>/simulation/timing</component_name></project_dir> |             |  |
| Contains simulation scripts and waveform formats.                               |             |  |

Back to Top

## **Implementation Scripts**

The implementation script is either a shell script or batch file that processes the example design through the Xilinx tool flow. It is located at:

#### LINUX

<project\_dir>/<component\_name>/implement/implement.sh <project\_dir>/<component\_name>/implement/planAhead\_rdn.sh

#### Windows

<project\_dir>/<component\_name>/implement/implement.bat</project\_dir>/component\_name>/implement/planAhead\_rdn.bat

The implement script performs these steps:

- Synthesizes the HDL example design files using XST or Synplicity Synplify Pro
- Runs NGDBuild to consolidate the core netlist and the example design netlist into the NGD file containing the entire design
- Maps the design to the target technology
- Place-and-routes the design on the target device
- Performs static timing analysis on the routed design using Timing Analyzer (TRCE)
- Generates a bitstream
- Enables Netgen to run on the routed design to generate a VHDL or Verilog netlist (as appropriate for the Design Entry project setting)

The Xilinx tool flow generates several output and report files. These are saved in the following directory which is created by the implement script:

<project\_dir>/<component\_name>/implement/results

## **Simulation Scripts**

#### **Functional Simulation**

The test scripts are a ModelSim, IES, VCS or ISim macro that automate the simulation of the test bench. They are available from this location:

```
<project_dir>/<component_name>/simulation/functional/
```

The test scripts perform these tasks:

- Compiles the structural UNISIM simulation model
- Compiles HDL Example Design source code
- Compiles the demonstration test bench
- Starts a simulation of the test bench
- Opens a Wave window and adds signals of interest
- Runs the simulation to completion

#### Timing Simulation

The test scripts are a ModelSim, IES that automate the simulation of the test bench. They are available from this location:

<project\_dir>/<component\_name>/simulation/timing/

The test scripts perform these tasks:

- Compile the structural SIMPRIM simulation model
- Compile routed HDL Example Design
- Compile the demonstration test bench
- Start a simulation of the test bench
- Open a Wave window and adds signals of interest
- Run the simulation to completion

## **Example Design**

The following files describe the example design for the Clocking Wizard core.

VHDL

<project\_dir>/<component\_name>/example\_design/<component\_name>\_exdes.vhd

Verilog

<project\_dir>/<component\_name>/example\_design/<component\_name>\_exdes.v

The top-level example designs adds clock buffers where appropriate to all of the input and output clocks. All generated clocks drive counters, and the high bits of each of the counters are routed to a pin. This allows the entire design to be synthesized and implemented in a target device to provide post place-and-route gate-level *simulation*.

### Customizing the Example Design

The widths of the counter in the example design can be modified to make the counters wider or narrower. When the correct width is combined with the frequencies of the output clocks, this allows the high bits of the counters to be connected to a visible indicator, such as an LED.

## **Demonstration Test Bench**





The following files describe the demonstration test bench.

VHDL

cproject\_dir>/<component\_name>/simulation/<component\_name>\_tb.vhd
...

Verilog

<project\_dir>/<component\_name>/simulation/<component\_name>\_tb.v

The demonstration test bench is a simple VHDL or Verilog program to exercise the example design and the core.

The demonstration test bench performs these tasks:

- Generates input clock signals
- Runs the clocking primitive through the locking procedure
- In the event that a secondary input clock is enabled, changes the input clock from the primary source to the secondary source



# Appendix A

# Migration Guide

This information is provided to assist those designers who are experienced with the DCM and PLL Architecture Wizards. It highlights the differences between the old and new cores.

# Differences between the Clocking Wizard and the Legacy DCM and PLL Wizards

There are several changes to the GUI and the wizard use model as described in the following subsections.

#### **Primitive Selection**

The old wizard required you to choose the correct GUI (DCM or PLL) before configuring the desired primitive.

The new wizard automatically selects the appropriate primitive and configures it based on desired parameters. You can choose to override this choice in the event that multiple primitives are available, as is the case for the Spartan<sup>®</sup>-6 device family.

#### Symbol Pin Activation

The old wizard had a symbol with clickable pins to enable a port.

For the new wizard, the symbol shows the ports that are currently active. To enable a port, enable the appropriate feature in the GUI. For example, enabling the secondary input clock enables the CLK\_IN2 and CLK\_IN\_SEL ports and activates those ports in the symbol.

#### Parameter Override

The new wizard allows you to override any calculated parameter within the wizard by switching to override mode.

### Port Display Conventions

The new wizard displays the superset of ports covering all device families. Ports that are not available for the selected target device are dimmed out. For example, if a Virtex®-6 device is selected, the STATUS port is dimmed out because it is not available for devices in that family. Information on the legal ports for a specific primitive can be found in the device family-specific FPGA or clocking resources User Guide at www.xilinx.com/support/documentation/index.htm.

### Visibility of Clock Ports

The new wizard provides a clocking network that matches your requirements rather than making clock ports visible. As a result, your clock names will not match the exact names for the primitive. For example, while the "first" clock available for the Virtex-6 FPGA MMCM is CLKOUT0, the highest priority clock available to you is actually named CLK\_OUT1. This change in numbering is especially important to consider if parameter overriding is desired.

### **GUI Information Gathering Order**

Some of the information-gathering ordering has changed. For the new wizard the general flow is:

- 1. Select the clocking features.
- 2. Configure the input clock parameters.
- 3. Configure the output clock parameters.
- 4. Choose feedback and optional ports
- 5. View (and optionally override) calculated parameters.
- 6. Final summary pages.

For cascading clocking components, non-buffered input and output clocks are available for easy connection.