Revision History

The following table summarizes changes made to each version of this document.

<table>
<thead>
<tr>
<th>Date</th>
<th>Version</th>
<th>Revision</th>
</tr>
</thead>
<tbody>
<tr>
<td>01/31/02</td>
<td>1.0</td>
<td>Initial Xilinx release.</td>
</tr>
<tr>
<td>10/14/02</td>
<td>2.0</td>
<td>Updated and reprinted. New Virtex-II Pro family members and packages. Revised I/O support information.</td>
</tr>
</tbody>
</table>
Contents

About This Handbook ........................................................................................................................................ 7

Introduction to the Virtex-II Pro™ FPGA Family .................................................................................. 11

Part 1: Virtex-II Pro™ Data Sheet

Virtex-II Pro Platform FPGAs: Introduction and Overview

Summary of Virtex-II Pro Features ........................................................................................................ 19
General Description .................................................................................................................................. 20
Architecture ................................................................................................................................................ 21
IP Core and Reference Support .................................................................................................................. 24
Virtex-II Pro Device/PKG Package Combinations and Maximum I/Os .................................................. 24
Maximum Performance .............................................................................................................................. 25
Virtex-II Pro Ordering Information ........................................................................................................... 25
Revision History ......................................................................................................................................... 25
Virtex-II Pro Data Sheet Modules ................................................................................................................ 25

Virtex-II Pro Platform FPGAs: Functional Description

Virtex-II Pro Array Functional Description .............................................................................................. 27
Functional Description: RocketIO Multi-Gigabit Transceiver (MGT) ...................................................... 27
Functional Description: Processor Block .................................................................................................. 33
Functional Description: Embedded PowerPC 405 Core ........................................................................ 36
Functional Description: FPGA .................................................................................................................. 39
Revision History ......................................................................................................................................... 71
Virtex-II Pro Data Sheet Modules ................................................................................................................ 71

Virtex-II Pro Platform FPGAs: DC and Switching Characteristics

Virtex-II Pro Electrical Characteristics ..................................................................................................... 73
Virtex-II Pro Performance Characteristics ................................................................................................. 81
Virtex-II Pro Switching Characteristics ...................................................................................................... 83
Virtex-II Pro Pin-to-Pin Output Parameter Guidelines ................................................................................ 107
Virtex-II Pro Pin-to-Pin Input Parameter Guidelines .................................................................................. 109
DCM Timing Parameters ............................................................................................................................ 111
Source-Synchronous Switching Characteristics .......................................................................................... 115
Revision History ......................................................................................................................................... 117
Virtex-II Pro Data Sheet Modules ................................................................................................................ 118
Part 2: Virtex-II Pro™ User Guide

Chapter 1: Timing Models

Summary ............................................................................................................................ 121
Introduction ...................................................................................................................... 121
CLB / Slice Timing Models .......................................................................................... 122
Block SelectRAM Timing Model ................................................................................ 131
Embedded Multiplier Timing Model .......................................................................... 134
IOB Timing Models ...................................................................................................... 137
Pin-to-Pin Timing Models ............................................................................................ 149
Digital Clock Manager Timing Model ........................................................................ 152
Additional Timing Models in Other Publications:
PPC405 Processor Block and RocketIO Transceiver ................................................ 157

Chapter 2: Design Considerations

Summary ............................................................................................................................ 159
Introduction ...................................................................................................................... 159
RocketIO Transceiver ................................................................................................... 160
Processor Block ............................................................................................................. 160
Global Clock Networks ............................................................................................... 160
Digital Clock Managers (DCMs) ................................................................................ 180
Block SelectRAM™ Memory ..................................................................................... 201
Distributed SelectRAM Memory ................................................................................. 218
Look-Up Tables as Shift Registers (SRLs) ................................................................. 227
Large Multiplexers ....................................................................................................... 237
Sum of Products (SOP) Logic ...................................................................................... 247
Embedded Multipliers ................................................................................................. 254
Single-Ended SelectIO™-Ultra Resources ................................................................. 261
Digitally Controlled Impedance (DCI) .................................................................... 294
Double-Data-Rate (DDR) I/O ................................................................................... 310
LVDS I/O ......................................................................................................................... 324
LVPECL I/O ...................................................................................................................... 330
Bitstream Encryption .................................................................................................. 332
CORE Generator System ............................................................................................. 336

Chapter 3: Configuration

Summary ............................................................................................................................ 353
Introduction ...................................................................................................................... 353
Configuration Solutions .............................................................................................. 360
Software Support and Data Files ............................................................................... 367
Master Serial Programming Mode ............................................................................ 368
Slave Serial Programming Mode ............................................................................... 369
Master SelectMAP Programming Mode ................................................................... 371
Slave SelectMAP Programming Mode ...................................................................... 373
Chapter 4: PCB Design Considerations

Summary............................................................................................................................ 409
Pinout Information .......................................................................................................... 409
Pinout Diagrams .............................................................................................................. 421
Package Specifications ................................................................................................. 487
Flip-Chip Packages ......................................................................................................... 497
Thermal Data .................................................................................................................. 498
Printed Circuit Board Considerations ............................................................................ 500
Board Routability Guidelines .......................................................................................... 506
XPower ............................................................................................................................ 512
IBIS Models .................................................................................................................... 512
BSDL and Boundary Scan Models .................................................................................. 517

Appendix A: BitGen and PROMGen Switches and Options

Using BitGen .................................................................................................................. 519
Using PROMGen ............................................................................................................. 525

Appendix B: XC18V00 Series PROMs

PROM Package Specifications ......................................................................................... 531

XC18V00 Series of In-System Programmable Configuration PROMs

Features ......................................................................................................................... 535
Description .................................................................................................................... 535
Pinout and Pin Description ............................................................................................. 536
Pinout Diagrams ............................................................................................................ 538
Xilinx FPGAs and Compatible PROMs ......................................................................... 539
Capacity ......................................................................................................................... 540
In-System Programming ............................................................................................... 540
External Programming .................................................................................................... 540
Reliability and Endurance ............................................................................................... 540
Design Security .............................................................................................................. 540
IEEE 1149.1 Boundary-Scan (JTAG) ............................................................................ 541
Instruction Register ......................................................................................................... 541
XC18V00 TAP Characteristics ....................................................................................... 542
TAP AC Parameters ....................................................................................................... 543
Connecting Configuration PROMs .................................................................................. 543
Master Serial Mode Summary ....................................................................................... 544
Reset Activation ............................................................................................................. 547
Standby Mode ................................................................................................................ 547
5V Tolerant I/Os .............................................................................................................. 547
Customer Control Bits .................................................................................................... 547
About This Handbook

This document describes the function and operation of Virtex-II Pro devices and also includes information on FPGA configuration techniques and PCB design considerations. For Virtex-II Pro device specifications, refer to the Virtex-II Pro Data Sheet modules in Part I of this handbook:

- Virtex-II Pro™ Platform FPGAs: Introduction and Overview (Module 1)
- Virtex-II Pro™ Platform FPGAs: Functional Description (Module 2)
- Virtex-II Pro™ Platform FPGAs: DC and Switching Characteristics (Module 3)

For details on the following topics, see the Virtex-II Pro Platform FPGA User Guide in Part II of this handbook:

- Chapter 1: Timing Models
- Chapter 2: Design Considerations
- Chapter 3: Configuration
- Chapter 4: PCB Design Considerations
- Appendix A: BitGen and PROMGen Switches and Options
- Appendix B: XC18V00 Series PROMs

The Data Sheet in Part I, together with Chapter 2 in Part II, provide an overview of the RocketIO multi-gigabit transceiver and PowerPC 405 processor. For details, the following documents, available at www.xilinx.com/virtex2pro, offer in-depth technical design information:

- RocketIO Transceiver User Guide
- PPC405 User Manual
- Processor Block Manual

Additional Resources

<table>
<thead>
<tr>
<th>Resource</th>
<th>Description/URL</th>
</tr>
</thead>
<tbody>
<tr>
<td>Application Notes</td>
<td>This site contains device-specific design techniques and approaches: <a href="http://www.xilinx.com/apps/appsweb.htm">http://www.xilinx.com/apps/appsweb.htm</a></td>
</tr>
<tr>
<td>Xcell Journals</td>
<td>This site contains quarterly journals for Xilinx programmable logic users: <a href="http://www.xilinx.com/xcell/xcell.htm">http://www.xilinx.com/xcell/xcell.htm</a></td>
</tr>
</tbody>
</table>
Typographical Conventions

The following typographical conventions are used in this manual:

- **Red text** indicates a cross-reference to information within the document set you are currently reading. Click the red text to go to the referenced item. To return to the original page, right-click anywhere on the current page and select Back.

- **Blue-underlined text** indicates a link to a Web page. Click blue-underlined text to browse the specified Web site.

- The *Courier* (monospaced) typeface indicates prompts or program outputs displayed by the system:

  ```
  speed grade: 5
  ```

- The *Courier bold* typeface indicates literal commands that you enter in a syntactical statement. However, braces “{ }” in Courier bold are not literal, and square brackets “[ ]” in Courier bold are literal only in the case of bus specifications, such as `bus[7:0]`.

  ```
  rpt_del_net=
  ```

- *Courier bold* also indicates menu command sequences:

  File → Open

- *Courier bold* also indicates filenames, file extensions, and/or file system paths:

  ```
  ... delete testfile.s ...
  ... and all *.p files ...
  ... in the \web\docs\source\ folder ...
  ```

- **Bold** in the normal body text typeface indicates names of graphical user interface (GUI) items.

  ```
  ... mark the Use All Search Terms checkbox and click OK ...
  ```

- **Italic** denotes the following items:

  - Inside angle brackets “< >”, variables in command strings that are substituted with user-defined values:

    ```
    edif2ngd <design_name>
    ```

  - References to other documents:

    See the Libraries Guide for more information.

  - Emphasis in text:

    If a wire is drawn so that it overlaps the pin of a symbol, the two nets are not connected.
• Square brackets “[ ]” indicate an optional entry or parameter. The brackets are not typed when entering the parameter in the command string. However, in bus specifications, such as bus [7:0], they are required.

`edif2ngd [option_name] <design_name>`

• Braces “{ }” enclose a list of items from which you must choose one or more; a vertical bar “|” separates items in a list of choices:

`lowpwr = {on|off}`

• A vertical ellipsis indicates repetitive material that has been omitted.

`IOB #1: Name = QOUT'`
`IOB #2: Name = CLKIN'`
```
```

• A horizontal ellipsis “...” indicates that an item can be repeated one or more times.

`allow block <block_name> <loc1> <loc2> ... <locn>;`
Introduction to the Virtex-II Pro™ FPGA Family

The Next Logical Revolution

The Virtex-II Pro Platform FPGA solution is the most technically sophisticated silicon and software product development in the history of the programmable logic industry. The goal was to revolutionize system architecture "from the ground up." To achieve that objective, the best circuit engineers and system architects from IBM, Mindspeed, and Xilinx co-developed the world’s most advanced Platform FPGA silicon product. Leading teams from top embedded systems companies worked together with Xilinx software teams to develop the systems software and IP solutions that enabled this new system architecture paradigm. The result is the first Platform FPGA solution capable of implementing high performance system-on-a-chip designs previously the exclusive domain of custom ASICs, yet with the flexibility and low development cost of programmable logic. The Virtex-II Pro family marks the first paradigm change from programmable logic to programmable systems, with profound implications for leading-edge system architectures in networking applications, deeply embedded systems, and digital signal processing systems. It allows custom user-defined system architectures to be synthesized, next-generation connectivity standards to be seamlessly bridged, and complex hardware and software systems to be co-developed rapidly with in-system debug at system speeds. Together, these capabilities usher in the next programmable logic revolution.

Built for Bandwidth

The Virtex-II Pro family consists of ten members, each with four to twenty-four RocketIO™ multi-gigabit transceivers based on the Mindspeed SkyRail™ technology. Each Xilinx RocketIO transceiver block contains a complete set of user-configurable supporting circuitry that address real-life, system-level challenges. These include standard 8B/10B encode/decode, programmable signal integrity adjustments for varying PCB trace lengths and materials, support for synchronization of multiple channels, and programmable support for channel control commands. In addition, the RocketIO blocks are the first FPGA-embedded transceivers to reach a baud rate of 3.125 Gb/s. Four RocketIO transceivers, employing 16 PCB traces, can be used to support a full-duplex 10 Gb/s channel by way of the RocketIO channel-bonding feature. This is equivalent to 256 traces of typical LVTTL buses, or 68 traces of a high-speed, source-synchronous parallel LVDS bus. It allows a PCB trace reduction of up to 16X over conventional parallel buses, resulting in significant reductions in PCB complexity and EMI system noise. The RocketIO technology fulfills higher bandwidth system requirements than currently possible, with cost savings coming from faster time-to-market, reduced printed circuit board (PCB) complexity, and lower component count.

The Virtex-II Pro members also incorporate small yet powerful IBM® PowerPC™ processor cores. Each of the larger Virtex-II Pro devices incorporates one to four
PowerPC 405 processor cores, each capable of more than 300 MHz clock frequency and 420 Dhrystone MIPS. While the processor cores occupy a small area of the die, they provide tremendous system flexibility where they are used. The PowerPC 405 cores are fully embedded within the FPGA fabric, where all processor nodes are controlled by the FPGA routing resources. This provides the utmost architectural capability, where complex applications may be efficiently divided between high-speed logic implementation and high-flexibility software implementations. For example, a packet processing application using only the FPGA logic today for high-speed packet routing may be augmented to include a slave high-performance processor for exception handling or in-system statistics monitoring. In contrast, using a separate processor externally requires hundreds of additional interface pins, which degrades system performance and significantly increases FPGA I/O requirements and overall board costs.

The Virtex-II Pro products are based on the most advanced FPGA fabric available: the Virtex-II architecture with IP-Immersion™ technology, which was developed to offer significant improvements in engineering productivity, silicon efficiency, and system flexibility. Unique features common in the Virtex-II Series—consisting of the Virtex-II and Virtex-II Pro families—include powerful SystemIO™ system connectivity solutions, digitally controlled impedance (DCI) technology, comprehensive clocking solutions, high-speed Active Interconnect™ routing architecture, and bitstream encryption. These features together constitute the most complete Platform FPGA solution available, optimized for high performance system-level applications. The upward compatibility of the Virtex Series of products ensures benefits in engineering productivity, performance, design longevity, and continuing cost reduction.

Legacy of Leadership

Each of the Virtex families of FPGAs has been the most successful programmable product family in its class, starting with the introduction of the original Virtex family in 1998. The Virtex and Virtex-E families were recognized by the industry as the highest technology products available when they were first introduced. The Virtex-II family, which again achieved technology leadership in density, performance, and features, ushered in the era of Platform FPGAs—programmable devices with the system-level capability and performance to implement systems functionality. The Virtex-II Pro family continues the tradition of technology leadership as the most sophisticated Platform FPGA yet, again breaking the technology barrier for the benefit of leading-edge system architects.

The Virtex-II Pro family is the first FPGA family to incorporate both serial transceiver technology and a hard processor core within a general-purpose FPGA device. This is significant for new high-bandwidth embedded processing applications such as packet processing, where both high device I/O bandwidth and high performance processor cores are needed together.

The Virtex-II Pro devices are the industry’s first FPGAs in a 0.13-micron process. The IBM nine-layer metal, all-copper, low-k process technology is among the most advanced in the semiconductor industry. The combination of advanced Active Interconnect™ architecture and advanced process technology makes the Virtex-II Pro family the highest performance FPGA in the world.

The RocketIO multi-gigabit transceiver (MGT), based on industry-leading SkyRail™ technology, is the highest performance, most complete embedded serial transceiver available. It is user-configurable for up to 3.125 Gb/s baud rate per channel, which is over twice the performance of other embedded transceivers at 1.25 Gb/s. Each RocketIO transceiver provides a complete set of common functionality available in standard SerDes transceivers. In contrast, “programmable ASSP” products with clock/data recovery (CDR) provide only the most basic transceiver capability.

The IBM PowerPC 405 processor core used in the Virtex-II Pro family is the highest performance embedded core available in FPGAs. The PowerPC architecture is used in
many markets including communications, industrial control, test and measurement systems, and other performance-oriented markets. It is currently the most popular processor architecture in embedded applications.

Packets Everywhere

The Virtex-II Pro family provides a powerful new paradigm for network processing where low latency is required, such as storage area networks, wireless infrastructure, and voice-over-IP networks. The digital convergence phenomenon drives the need for packet routing based on type and priority. For example, live voice and video data packets require significantly lower latency than data file packets. New data networking applications must now handle higher bandwidth traffic as well as more complex types of prioritized packets. In many cases, Virtex-II Pro devices can offer higher overall performance than other solutions, including specialized network processors (NPs). Using the Virtex-II Pro architecture, the most common packets may be quickly read and routed using FPGA logic, without incurring the lengthy software run-time needed by NPs. The FPGA logic interrupts the PowerPC processor core only when processor instructions are needed for special packet types. For example, packets may be stored into a 16 KB dual-port memory area accessible by both the FPGA logic and the PowerPC 405 on-chip memory (OCM) port, allowing rapid change of control and packet disposition. By using the FPGA logic to process the most common packet types while the processor core handles the more specialized ones as a slave to the logic, the Virtex-II Pro architecture can provide higher overall performance than NPs, as well as more sophisticated processing capabilities than FPGA logic alone.

Bridge, Anyone?

Powerful protocol bridges for tying together disparate data stream formats are well-suited for the Virtex-II Pro solution. New interface standards and protocols include 3GIO, Infiniband, Gigabit Ethernet, XAUI/10 Gigabit Ethernet, RapidIO, and HyperTransport. These must interface seamlessly to one another, as well as to other standards such as PCI, Fibre Channel, POS Phy Level 4, Flexbus 4, and others. This presents a significant challenge to system developers because of changing standards, scarcity of off-the-shelf interface components, and the inflexibility of available solutions. System designers have had to assemble their own blend of FPGAs, discrete physical transceivers, and discrete communications processors to solve their complex system challenges. Even newer "programmable ASSPs" (application-specific standard products) with built-in serial transceivers fall short, because they frequently require companion FPGAs to supplement their logic capacity. The Virtex-II Pro solution, using the powerful Xilinx SystemIO™ capability to fully integrate silicon, software, and IP capabilities, provides the most flexible pre-engineered protocol bridge solutions available for fast time-to-market and low development cost.

Simplifying Complexity

The Virtex-II Pro solution offers a powerful paradigm for complex embedded systems found in signal processing, industrial control, image processing, networking, communications, and aeronautic applications. For the first time, complex embedded systems traditionally involving sophisticated hardware and software may be developed concurrently, emulated in actual hardware at speed, debugged in-system, and re-architected for performance within weeks, rather than months or years. In addition, full systems can be remotely upgraded as easily as software-only upgrades are performed today, using Compact Flash, CDROM, Internet, wireless transmission, or other flexible means. Hardware design is simplified using powerful development software and a large soft IP library to assemble logic- and processor-based platforms. Software development
may be started earlier using the actual device in preconfigured sample platforms, without waiting for the new system board to be developed. In many cases, higher density Virtex-II Pro components may be used for early system development, whereby extra resources (including additional PowerPC processor cores) may be used to easily emulate board-level components yet to be developed. This flexibility, obviously unavailable in custom ASICs or ASSPs, allows systems to be emulated at speed, rather than simulated using software simulators at 100 or 1000 times slower. In-system debugging is further enhanced by the Xilinx ChipScope Pro tool, which provides comprehensive logic analysis—from probing internal nodes to full bus analysis with bus protocol adherence checks using an external logic analyzer via the IEEE 1149.1 (JTAG) test access port. Using ChipScope Pro can result in orders of magnitude of improvement in engineering productivity.

Complex systems can be optimally repartitioned between FPGA logic and processor cores, allowing a continuum of possible trade-offs between the speed of logic and the flexibility of software code. For example, a first implementation of an echo cancellation algorithm might be all-software in compiled C code running on a PowerPC core, in order to allow the system software development to start. As the system is further optimized, part of the DSP algorithm could be retargeted using Matlab Simulink into FPGA logic to achieve a significantly faster but functionally identical system for production release. In another example, an encryption application might implement the Diffie-Hellman key exchange algorithm, whereby exponentiation and message management could be optimally partitioned into FPGA logic and an embedded processor, respectively. In this way, the programmable systems paradigm offers tremendous flexibility to allow system designers and architects to optimize the trade-offs in development time, system performance, and system costs.

It is significant that the embedded systems enabled by Virtex-II Pro solutions are "all-soft," in that both logic and software code are controlled by a soft data file. Because of this, the low cost of design maintenance and degree of design reuse is greatly enhanced. Whole system upgrades, including both hardware and software, can now be accomplished with one unified soft file using System ACE™ configuration solutions, offering the same low cost and ease of use as software-only upgrades.

**Time Is Money**

The Virtex-II Series, comprising both the Virtex-II and Virtex-II Pro families, offers significantly faster time-to-market and lower development costs than ASICs. Compared to a full-custom ASIC, the Virtex-II Pro solution eliminates the need for exhaustive verification during development, and allows hardware-software debug at system speeds rather than at slow software simulation speeds. In addition, the Virtex-II Pro features of signal integrity, pre-engineered clocking capabilities, and an abundance of soft IP cores, significantly reduce development time.

The Virtex-II Series offers significantly lower development costs than ASICs, due to lower tool costs, lower third-party IP costs, and absence of NRE costs. The Virtex-II Series also increases engineering productivity by accelerating hardware availability for software development and increasing software debug speed. In addition, the availability of powerful development tools enables straightforward retargeting of other embedded processors into the PowerPC platform. Compared to other processor architectures, the PowerPC 405 core in most cases allows higher performance and more powerful capabilities, and thus can be used to accelerate preproduction of performance-sensitive applications.
Flexibility Is Money

The flexibility inherent in the Virtex-II Series allows system architects to fine-tune their architectural partitioning after the initial prototype is developed. That is, each subsystem function can be freely implemented as hardware only, software only, or any combination within the hardware-software continuum, depending on the trade-off between performance and complexity. For example, a wireless infrastructure system might initially implement a rake filter function in hardware, and then change to a firmware implementation as more software control is necessary during later development. This repartitioning would be impossible in custom ASICs without significant time and cost penalties.

The Virtex-II Series offers significantly more flexibility than fixed chip sets and ASSPs, allowing end user product differentiation and future-proofing. For a design requirement that can generally be met either by ASSPs or by Virtex-II Platform FPGAs, the initial design investment for an FPGA implementation may be higher. However, the advantages for Platform FPGA implementations include customizing of functionality, ease of design reuse, ability to fix design bugs, differentiation of user end products, and ownership and control of the entire system. These are important advantages in highly competitive markets where ASSPs have standing errata lists and unpredictable future availability. In contrast, properly developed Platform FPGA designs are soft designs that may be readily maintained and reused as needed. Therefore, FPGA methodologies can provide system manufacturers with greater competitive advantage in the short term, and greater ownership and control over their products in the long term.

Not Being Discrete

Many high-bandwidth systems today use large FPGAs together with discrete SerDes transceivers, discrete communications processors, or other discrete components. The Virtex-II Pro family can eliminate the need for many of these external components, enhancing time-to-market and performance, even providing system cost benefits in many cases. Multi-chip solutions using FPGAs typically require over a hundred I/O pins to interface to each discrete quad 3.125 Gb/s SerDes transceiver or discrete microprocessor. The result is increased PCB complexity to accommodate the hundreds of traces, reduced system performance due to on-chip/off-chip connections, and higher overall system costs. In some cases, the increased FPGA pin-count requirement may force a higher-density FPGA to be used, again increasing the overall cost. In these cases, the Virtex-II Pro devices can integrate the discrete components to achieve faster system development, higher system performance, and lower costs.
Part I: Virtex-II Pro Data Sheet

This section contains the Virtex-II Pro Platform FPGA Advance Product Specification (Data Sheet DS083). The latest version of this publication is available online at http://www.xilinx.com/publications/products/v2pro/ds_pdf/ds083.htm.
Summary of Virtex-II Pro Features

- High-Performance Platform FPGA Solution, Including
  - Up to twenty-four RocketIO™ embedded multi-gigabit transceivers
  - Up to four IBM® PowerPC® RISC processor blocks
- Based on Virtex™-II Platform FPGA Technology
  - Flexible logic resources
  - SRAM-based in-system configuration
  - Active Interconnect technology
- SelectRAM™+ memory hierarchy
- Dedicated 18-bit x 18-bit multiplier blocks
- High-performance clock management circuitry
- SelectIO™-Ultra technology
- XCITE Digitally Controlled Impedance (DCI) I/O

Virtex-II Pro family members and resources are shown in Table 1.

Table 1: Virtex-II Pro FPGA Family Members

<table>
<thead>
<tr>
<th>Device</th>
<th>RocketIO Transceiver Blocks</th>
<th>PowerPC Processor Blocks</th>
<th>Logic Cells(1)</th>
<th>CLB (1 = 4 slices = max 128 bits)</th>
<th>18 X 18 Bit Multiplier Blocks</th>
<th>Block SelectRAM+</th>
<th>Maximum User I/O Pads</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Slices</td>
<td>Max Distr RAM (Kb)</td>
<td>18 Kb Blocks</td>
<td>Max Block RAM (Kb)</td>
</tr>
<tr>
<td>XC2VP2</td>
<td>4</td>
<td>0</td>
<td>3,168</td>
<td>1,408</td>
<td>44</td>
<td>12</td>
<td>12</td>
</tr>
<tr>
<td>XC2VP4</td>
<td>4</td>
<td>1</td>
<td>6,768</td>
<td>3,008</td>
<td>94</td>
<td>28</td>
<td>28</td>
</tr>
<tr>
<td>XC2VP7</td>
<td>8</td>
<td>1</td>
<td>11,088</td>
<td>4,928</td>
<td>154</td>
<td>44</td>
<td>44</td>
</tr>
<tr>
<td>XC2VP20</td>
<td>8</td>
<td>2</td>
<td>20,880</td>
<td>9,280</td>
<td>290</td>
<td>88</td>
<td>88</td>
</tr>
<tr>
<td>XC2VP30</td>
<td>8</td>
<td>2</td>
<td>30,816</td>
<td>13,696</td>
<td>428</td>
<td>136</td>
<td>136</td>
</tr>
<tr>
<td>XC2VP40</td>
<td>0(2) or 12</td>
<td>2</td>
<td>43,632</td>
<td>19,392</td>
<td>606</td>
<td>192</td>
<td>192</td>
</tr>
<tr>
<td>XC2VP50</td>
<td>0(2) or 16</td>
<td>2</td>
<td>53,136</td>
<td>23,616</td>
<td>738</td>
<td>232</td>
<td>232</td>
</tr>
<tr>
<td>XC2VP70</td>
<td>16 or 20</td>
<td>2</td>
<td>74,448</td>
<td>33,088</td>
<td>1,034</td>
<td>328</td>
<td>328</td>
</tr>
<tr>
<td>XC2VP100</td>
<td>0(2) or 20</td>
<td>2</td>
<td>99,216</td>
<td>44,096</td>
<td>1,378</td>
<td>444</td>
<td>444</td>
</tr>
<tr>
<td>XC2VP125</td>
<td>0(2), 20, or 24</td>
<td>4</td>
<td>125,136</td>
<td>55,616</td>
<td>1,738</td>
<td>556</td>
<td>556</td>
</tr>
</tbody>
</table>

Notes:
1. Logic Cell = (1) 4-input LUT + (1) FF + Carry Logic
2. These devices can be ordered in a configuration without RocketIO transceivers. See Table 3 for package configurations.

RocketIO Transceiver Features

- Full-Duplex Serial Transceiver (SERDES) Capable of Baud Rates from 622 Mb/s to 3.125 Gb/s
- 120 Gb/s Duplex Data Rate (24 Channels)
- Monolithic Clock Synthesis and Clock Recovery (CDR)
- Fibre Channel, Gigabit Ethernet, 10 Gb Attachment Unit Interface (XAUI), and Infiniband-Compliant Transceivers
- 8-, 16-, or 32-bit Selectable Internal FPGA Interface
- 8B/10B Encoder and Decoder (optional)
- 50Ω/75Ω on-chip Selectable Transmit and Receive Terminations
- Programmable Comma Detection
- Channel Bonding Support (from 2 to 24 Channels)
- Rate Matching via Insertion/Deletion Characters
- Four Levels of Selectable Pre-Emphasis
- Five Levels of Output Differential Voltage
- Per-Channel Internal Loopback Modes
- 2.5V Transceiver Supply Voltage
PowerPC RISC Block Features
- Embedded 300+ MHz Harvard Architecture Block
- Low Power Consumption: 0.9 mW/MHz
- Five-Stage Data Path Pipeline
- Hardware Multiply/Divide Unit
- Thirty-Two 32-bit General Purpose Registers
- 16 KB Two-Way Set-Associative Instruction Cache
- 16 KB Two-Way Set-Associative Data Cache
- Memory Management Unit (MMU)
  - 64-entry unified Translation Look-aside Buffers (TLB)
  - Variable page sizes (1 KB to 16 MB)
- Dedicated On-Chip Memory (OCM) Interface
- Supports IBM CoreConnect™ Bus Architecture
- Debug and Trace Support
- Timer Facilities

Virtex-II Pro Platform FPGA Technology
- SelectRAM+ Memory Hierarchy
  - Up to 10 Mb of True Dual-Port RAM in 18 Kb block
  - SelectRAM+ resources
  - Up to 1,738 Kb of distributed SelectRAM+ resources
  - High-performance interfaces to external memory
- Arithmetic Functions
  - Dedicated 18-bit x 18-bit multiplier blocks
  - Fast look-ahead carry logic chains
- Flexible Logic Resources
  - Up to 111,232 internal registers/latches with Clock Enable
  - Up to 111,232 look-up tables (LUTs) or cascadable variable (1 to 16 bits) shift registers
  - Wide multiplexers and wide-input function support
  - Horizontal cascade chain and Sum-of-Products support
  - Internal 3-state busing
- High-Performance Clock Management Circuitry
  - Up to twelve Digital Clock Manager (DCM) modules
    - Precise clock de-skew
    - Flexible frequency synthesis
    - High-resolution phase shifting
  - 16 global clock multiplexer buffers in all parts
- Active Interconnect Technology
  - Fourth-generation segmented routing structure
  - Fast, predictable routing delay, independent of fanout
  - Deep sub-micron noise immunity benefits
- SelectIO™-Ultra Technology
  - Up to 1,200 user I/Os
  - Nineteen single-ended standards and six differential standards

- Programmable LVCMOS sink/source current (2 mA to 24 mA) per I/O
- XCITE Digitally Controlled Impedance (DCI) I/O
- PCI support (1)
- Differential signaling
  - 840 Mb/s Low-Voltage Differential Signaling I/O (LVDS) with current mode drivers
  - Bus LVDS I/O
  - HyperTransport (LDT) I/O with current driver buffers
  - Built-in DDR input and output registers
- Proprietary high-performance SelectLink technology for communications between Xilinx devices
  - High-bandwidth data path
  - Double Data Rate (DDR) link
  - Web-based HDL generation methodology
- SRAM-Based In-System Configuration
  - Fast SelectMAP™ configuration
  - Triple Data Encryption Standard (DES) security option (bitstream encryption)
  - IEEE 1532 support
  - Partial reconfiguration
  - Unlimited reprogrammability
  - Readback capability
- Supported by Xilinx Foundation™ and Alliance Series™ Development Systems
  - Integrated VHDL and Verilog design flows
  - ChipScope™ Integrated Logic Analyzer
- 0.13 µm Nine-Layer Copper Process with 90 nm High-Speed Transistors
- 1.5V (VCCINT) core power supply, dedicated 2.5V VCCAUX auxiliary and VCCO I/O power supplies
- IEEE 1149.1 Compatible Boundary-Scan Logic Support
- Flip-Chip and Wire-Bond Ball Grid Array (BGA) Packages in Standard 1.00 mm Pitch
- Each Device 100% Factory Tested

General Description
The Virtex-II Pro family contains platform FPGAs for designs that are based on IP cores and customized modules. The family incorporates multi-gigabit transceivers and PowerPC CPU blocks in Virtex-II Pro Series FPGA architecture. It empowers complete solutions for telecommunications, wireless, networking, video, and DSP applications. The leading-edge 0.13 µm CMOS nine-layer copper process and Virtex-II Pro architecture are optimized for high performance designs in a wide range of densities. Combining a wide variety of flexible features and IP cores, the Virtex-II Pro family enhances programmable logic design capabilities and is a powerful alternative to mask-programmed gate arrays.

1. Refer to XAPP646 and XAPP653 for more information.
Architecture

Virtex-II Pro Array Overview

Virtex-II Pro devices are user-programmable gate arrays with various configurable elements and embedded blocks optimized for high-density and high-performance system designs. Virtex-II Pro devices implement the following functionality:

- Embedded high-speed serial transceivers enable data bit rate up to 3.125 Gb/s per channel.
- Embedded IBM PowerPC 405 RISC processor blocks provide performance of 300+ MHz.
- SelectIO-Ultra blocks provide the interface between package pins and the internal configurable logic. Most popular and leading-edge I/O standards are supported by the programmable IOBs.
- Configurable Logic Blocks (CLBs) provide functional elements for combinatorial and synchronous logic, including basic storage elements. BUFTs (3-state buffers) associated with each CLB element drive dedicated segmentable horizontal routing resources.
- Block SelectRAM+ memory modules provide large 18 Kb storage elements of True Dual-Port RAM.
- Embedded multiplier blocks are 18-bit x 18-bit dedicated multipliers.
- Digital Clock Manager (DCM) blocks provide self-calibrating, fully digital solutions for clock distribution delay compensation, clock multiplication and division, and coarse- and fine-grained clock phase shifting.

A new generation of programmable routing resources called Active Interconnect Technology interconnects all of these elements. The general routing matrix (GRM) is an array of routing switches. Each programmable element is tied to a switch matrix, allowing multiple connections to the general routing matrix. The overall programmable interconnection is hierarchical and designed to support high-speed designs.

All programmable elements, including the routing resources, are controlled by values stored in static memory cells. These values are loaded in the memory cells during configuration and can be reloaded to change the functions of the programmable elements.

Virtex-II Pro Features

This section briefly describes Virtex-II Pro features. For more details, refer to Virtex-II Pro™ Platform FPGAs: Functional Description (Module 2).

RocketIO Multi-Gigabit Transceivers

The RocketIO Multi-Gigabit Transceiver, based on Mind-speed’s SkyRail technology, is a flexible parallel-to-serial and serial-to-parallel embedded transceiver used for high-bandwidth interconnection between buses, backplanes, or other subsystems.

Multiple user instantiations in an FPGA are possible, providing up to 120 Gb/s of full-duplex raw data transfer. Each channel can be operated at a maximum data transfer rate of 3.125 Gb/s.

Each RocketIO transceiver implements:
- Serializer and deserializer (SERDES)
- Monolithic clock synthesis and clock recovery (CDR)
- Fibre Channel, Gigabit Ethernet, XAUI, and Infiniband compliant transceivers
- 8-, 16-, or 32-bit selectable FPGA interface
- 8B/10B encoder and decoder with bypassing option on each channel
- Channel bonding support (2 to 24 channels)
- Elastic buffers for inter-chip deskewing and channel-to-channel alignment
- Receiver clock recovery tolerance of up to 75 non-transitioning bits
- 50Ω/75Ω on-chip selectable transmit and receive terminations
- Programmable comma detection
- Rate matching via insertion/deletion characters
- Automatic lock-to-reference function
- Optional transmit and receive data inversion
- Four levels of pre-emphasis support
- Per-channel serial and parallel transmitter-to-receiver internal loopback modes
- Cyclic Redundancy Check (CRC) support

PowerPC 405 Processor Block

The PPC405 RISC CPU can execute instructions at a sustained rate of one instruction per cycle. On-chip instruction and data cache reduce design complexity and improve system throughput.

The PPC405 features include:
- PowerPC RISC CPU
  - Implements the PowerPC User Instruction Set Architecture (UISA) and extensions for embedded applications
  - Thirty-two 32-bit general purpose registers (GPRs)
  - Static branch prediction
  - Five-stage pipeline with single-cycle execution of most instructions, including loads/stores
  - Unaligned and aligned load/store support to cache, main memory, and on-chip memory
  - Hardware multiply/divide for faster integer arithmetic (4-cycle multiply, 35-cycle divide)
  - Enhanced string and multiple-word handling
  - Big/little endian operation support
- Storage Control
  - Separate instruction and data cache units, both two-way set-associative and non-blocking
- Eight words (32 bytes) per cache line
- 16 KB array Instruction Cache Unit (ICU), 16 KB array Data Cache Unit (DCU)
- Operand forwarding during instruction cache line fill
- Copy-back or write-through DCU strategy
- Doubleword instruction fetch from cache improves branch latency
- Virtual mode memory management unit (MMU)
  - Translation of the 4 GB logical address space into physical addresses
  - Software control of page replacement strategy
  - Supports multiple simultaneous page sizes ranging from 1 KB to 16 MB
- OCM controllers provide dedicated interfaces between Block SelectRAM+ memory and processor block instruction and data paths for high-speed access
- PowerPC timer facilities
  - 64-bit time base
  - Programmable interval timer (PIT)
  - Fixed interval timer (FIT)
  - Watchdog timer (WDT)
- Debug Support
  - Internal debug mode
  - External debug mode
  - Debug Wait mode
  - Real Time Trace debug mode
  - Enhanced debug support with logical operators
  - Instruction trace and trace-back support
  - Forward or backward trace
- Two hardware interrupt levels support
- Advanced power management support

**Input/Output Blocks (IOBs)**

IOBs are programmable and can be categorized as follows:
- Input block with an optional single data rate (SDR) or double data rate (DDR) register
- Output block with an optional SDR or DDR register and an optional 3-state buffer to be driven directly or through an SDR or DDR register
- Bidirectional block (any combination of input and output configurations)

These registers are either edge-triggered D-type flip-flops or level-sensitive latches.

IOBs support the following single-ended I/O standards:
- LVCMOS (2.5V, 1.8V, and 1.5V)
- PCI (33 and 66 MHz)
- GTL and GTP
- HSTL (1.5V and 1.8V, Class I, II, III, and IV)
- SSTL (1.8V and 2.5V, Class I and II)

The DCI I/O feature automatically provides on-chip termination for each single-ended I/O standard.

The IOB elements also support the following differential signaling I/O standards:
- LVDS and Extended LVDS (2.5V)
- BLVDS (Bus LVDS)
- ULVDS
- LDVDS
- LVPECL (2.5V)

Two adjacent pads are used for each differential pair. Two or four IOB blocks connect to one switch matrix to access the routing resources.

**Configurable Logic Blocks (CLBs)**

CLB resources include four slices and two 3-state buffers. Each slice is equivalent and contains:
- Two function generators (F & G)
- Two storage elements
- Arithmetic logic gates
- Large multiplexers
- Wide function capability
- Fast carry look-ahead chain
- Horizontal cascade chain (OR gate)

The function generators F & G are configurable as 4-input look-up tables (LUTs), as 16-bit shift registers, or as 16-bit distributed SelectRAM+ memory.

In addition, the two storage elements are either edge-triggered D-type flip-flops or level-sensitive latches.

Each CLB has internal fast interconnect and connects to a switch matrix to access general routing resources.

**Block SelectRAM+ Memory**

The block SelectRAM+ memory resources are 18 Kb of True Dual-Port RAM, programmable from 16K x 1 bit to 512 x 36 bit, in various depth and width configurations. Each port is totally synchronous and independent, offering three “read-during-write” modes. Block SelectRAM+ memory is cascadable to implement large embedded storage blocks. Supported memory configurations for dual-port and single-port modes are shown in Table 2.

<table>
<thead>
<tr>
<th>Dual-Port and Single-Port Configurations</th>
</tr>
</thead>
<tbody>
<tr>
<td>16K x 1 bit</td>
</tr>
<tr>
<td>8K x 2 bits</td>
</tr>
</tbody>
</table>

**18 X 18 Bit Multipliers**

A multiplier block is associated with each SelectRAM+ memory block. The multiplier block is a dedicated 18 x 18-bit 2s complement signed multiplier, and is optimized for operations based on the block SelectRAM+ content on one port. The 18 x 18 multiplier can be used independently of the block SelectRAM+ resource. Read/multiply/accumulate operations and DSP filter structures are extremely efficient.
Both the SelectRAM+ memory and the multiplier resource are connected to four switch matrices to access the general routing resources.

**Global Clocking**

The DCM and global clock multiplexer buffers provide a complete solution for designing high-speed clock schemes. Up to eight DCM blocks are available. To generate deskewed internal or external clocks, each DCM can be used to eliminate clock distribution delay. The DCM also provides 90-, 180-, and 270-degree phase-shifted versions of its output clocks. Fine-grained phase shifting offers high-resolution phase adjustments in increments of $1/256$ of the clock period. Very flexible frequency synthesis provides a clock output frequency equal to a fractional or integer multiple of the input clock frequency. For exact timing parameters, see Virtex-II Pro™ Platform FPGAs: DC and Switching Characteristics.

Virtex-II Pro devices have 16 global clock MUX buffers, with up to eight clock nets per quadrant. Each clock MUX buffer can select one of the two clock inputs and switch glitch-free from one clock to the other. Each DCM can send up to four of its clock outputs to global clock buffers on the same edge. Any global clock pin can drive any DCM on the same edge.

**Routing Resources**

The IOB, CLB, block SelectRAM+, multiplier, and DCM elements all use the same interconnect scheme and the same access to the global routing matrix. Timing models are shared, greatly improving the predictability of the performance of high-speed designs.

There are a total of 16 global clock lines, with eight available per quadrant. In addition, 24 vertical and horizontal long lines per row or column, as well as massive secondary and local routing resources, provide fast interconnect. Virtex-II Pro buffered interconnects are relatively unaffected by net fanout, and the interconnect layout is designed to minimize crosstalk.

Horizontal and vertical routing resources for each row or column include:

- 24 long lines
- 120 hex lines
- 40 double lines
- 16 direct connect lines (total in all four directions)

**Boundary Scan**

Boundary-scan instructions and associated data registers support a standard methodology for accessing and configuring Virtex-II Pro devices, complying with IEEE standards 1149.1 and 1532. A system mode and a test mode are implemented. In system mode, a Virtex-II Pro device will continue to function while executing non-test boundary-scan instructions. In test mode, boundary-scan test instructions control the I/O pins for testing purposes. The Virtex-II Pro Test Access Port (TAP) supports BYPASS, PRELOAD, SAMPLE, IDCODE, and USERCODE non-test instructions. The EXTEST, INTEST, and HIGHZ test instructions are also supported.

**Configuration**

Virtex-II Pro devices are configured by loading the bitstream into internal configuration memory using one of the following modes:

- Slave-serial mode
- Master-serial mode
- Slave SelectMAP mode
- Master SelectMAP mode
- Boundary-Scan mode (IEEE 1532)

A Data Encryption Standard (DES) decryptor is available on-chip to secure the bitstreams. One or two triple-DES key sets can be used to optionally encrypt the configuration data.

The Xilinx System Advanced Configuration Enviornment (System ACE) family offers high-capacity and flexible solution for FPGA configuration as well as program/data storage for the processor. See DS080, System ACE CompactFlash Solution for more information.

**Readback and Integrated Logic Analyzer**

Configuration data stored in Virtex-II Pro configuration memory can be read back for verification. Along with the configuration data, the contents of all flip-flops/latches, distributed SelectRAM+, and block SelectRAM+ memory resources can be read back. This capability is useful for real-time debugging.

The Xilinx ChipScope Integrated Logic Analyzer (ILA) cores and Integrated Bus Analyzer (IBA) cores, along with the ChipScope Pro Analyzer software, provide a complete solution for accessing and verifying user designs within Virtex-II Pro devices.
IP Core and Reference Support

Intellectual Property is part of the Platform FPGA solution. In addition to the existing FPGA fabric cores, the list below shows some of the currently available hardware and software intellectual properties specially developed for Virtex-II Pro by Xilinx. Each IP core is modular, portable, Real-Time Operating System (RTOS) independent, and CoreConnect compatible for ease of design migration. Refer to www.xilinx.com for the latest and most complete list of cores.

Hardware Cores
- Bus Infrastructure cores ( arbiters, bridges, and more)
- Memory cores (DDR, Flash, and more)
- Peripheral cores (UART, IIC, and more)
- Networking cores (ATM, Ethernet, and more)

Software Cores
- Boot code
- Test code
- Device drivers
- Protocol stacks
- RTOS integration
- Customized board support package

Virtex-II Pro Device/Package Combinations and Maximum I/Os

Offerings include ball grid array (BGA) packages with 1.0 mm pitch. In addition to traditional wire-bond interconnects, flip-chip interconnect is used in some of the BGA offerings. The use of flip-chip interconnect offers more I/Os than are possible in wire-bond versions of the similar packages. Flip-chip construction offers the combination of high pin count and excellent power dissipation.

The Virtex-II Pro device/package combination table (Table 3) details the maximum number of I/Os for each device and package using wire-bond or flip-chip technology.

<table>
<thead>
<tr>
<th>Pkg</th>
<th>Pitch (mm)</th>
<th>Size (mm)</th>
<th>Available User I/Os / Available RocketIO Transceivers</th>
</tr>
</thead>
<tbody>
<tr>
<td>FG256</td>
<td>1.00</td>
<td>17 x 17</td>
<td>140 / 4 140 / 4</td>
</tr>
<tr>
<td>FG456</td>
<td>1.00</td>
<td>23 x 23</td>
<td>156 / 4 248 / 4 248 / 8</td>
</tr>
<tr>
<td>FF672</td>
<td>1.00</td>
<td>27 x 27</td>
<td>204 / 4 348 / 4 396 / 8</td>
</tr>
<tr>
<td>FF896</td>
<td>1.00</td>
<td>31 x 31</td>
<td>396 / 8 556 / 8 556 / 8</td>
</tr>
<tr>
<td>FF1152</td>
<td>1.00</td>
<td>35 x 35</td>
<td>564 / 8 644 / 8 692 / 12 692 / 16</td>
</tr>
<tr>
<td>FF1148</td>
<td>1.00</td>
<td>35 x 35</td>
<td>564 / 8 644 / 8 804 / 0(1) 812 / 0(1)</td>
</tr>
<tr>
<td>FF1517</td>
<td>1.00</td>
<td>40 x 40</td>
<td>804 / 12 852 / 16 964 / 16</td>
</tr>
<tr>
<td>FF1704</td>
<td>1.00</td>
<td>42.5 x 42.5</td>
<td>996 / 20 1,040 / 20 1,040 / 20</td>
</tr>
<tr>
<td>FF1696</td>
<td>1.00</td>
<td>42.5 x 42.5</td>
<td>1,164 / 0(1) 1,200 / 0(1)</td>
</tr>
</tbody>
</table>

Notes:
1. The RocketIO transceivers in devices in the FF1148 and FF1696 packages are not bonded out to the package pins.
2. Consult Xilinx for package options supporting 24 RocketIO transceivers.

Table 3: Virtex-II Pro Device/Package Combinations and Maximum Number of Available I/Os
(Advance Information)
Maximum Performance

Maximum RocketIO transceiver and PowerPC processor block performance varies, depending on the package style and speed grade. See Table 4 for details. Virtex-II Pro™ Platform FPGAs: DC and Switching Characteristics (Module 3) contains the rest of the FPGA fabric performance parameters.

### Table 4: Maximum RocketIO Transceiver and Processor Block Performance

<table>
<thead>
<tr>
<th>Speed Grade</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>-7</td>
<td>2.5 Gb/s</td>
</tr>
<tr>
<td>-6</td>
<td>2.5 Gb/s</td>
</tr>
<tr>
<td>-5</td>
<td>2.0 Gb/s</td>
</tr>
</tbody>
</table>

Virtex-II Pro Ordering Information

Virtex-II Pro ordering information is shown in Figure 1.

Example: XC2VP7-7FG456C

- **Device Type:**
- **Speed Grade:** (-5, -6, -7)
- **Temperature Range:**
  - C = Commercial (Tj = 0˚C to +85˚C)
  - I = Industrial (Tj = -40˚C to +100˚C)
- **Number of Pins**
- **Package Type**

**Figure 1:** Virtex-II Pro Ordering Information

Revision History

This section records the change history for this module of the data sheet.

<table>
<thead>
<tr>
<th>Date</th>
<th>Version</th>
<th>Revision</th>
</tr>
</thead>
<tbody>
<tr>
<td>01/31/02</td>
<td>1.0</td>
<td>Initial Xilinx release.</td>
</tr>
<tr>
<td>06/13/02</td>
<td>2.0</td>
<td>New Virtex-II Pro family members. New timing parameters per speedsfile v1.62.</td>
</tr>
<tr>
<td>09/03/02</td>
<td>2.1</td>
<td>Updates to Table 1 and Table 3. Processor Block information added to Table 4.</td>
</tr>
<tr>
<td>09/27/02</td>
<td>2.2</td>
<td>In Table 1, corrected max number of XC2VP30 I/Os to 644.</td>
</tr>
</tbody>
</table>

Virtex-II Pro Data Sheet Modules

The Virtex-II Pro Data Sheet contains the following modules:

- Virtex-II Pro Platform FPGAs: Introduction and Overview (Module 1)
- Virtex-II Pro™ Platform FPGAs: Functional Description (Module 2)
- Virtex-II Pro™ Platform FPGAs: DC and Switching Characteristics (Module 3)
- Virtex-II Pro Platform FPGAs: Pinout Information (Module 4)
Virtex-II Pro Array Functional Description

This module describes the following Virtex-II Pro functional components, as shown in Figure 1:

- Embedded RocketIO™ Multi-Gigabit Transceiver (MGT)
- Processor block containing embedded IBM® PowerPC™ 405 RISC CPU (PPC405) core and integration circuitry.
- FPGA fabric based on Virtex-II architecture.

For a description of PPC405 embedded core programming models and internal core operations, refer to the PPC405 User Manual and the PPC405 Processor Block Manual. For detailed RocketIO transceiver digital/analog design considerations, refer to the RocketIO Transceiver User Guide.

All of the documents above, as well as a complete listing and description of Xilinx-developed Intellectual Property cores for Virtex-II Pro, are available on the Xilinx website at www.xilinx.com/virtex2pro.

Virtex-II Pro Compared to Virtex-II Devices

Virtex-II Pro devices are built on the Virtex-II FPGA architecture. Most FPGA features are identical to Virtex-II devices. Differences are described below:

- The Virtex-II Pro FPGA family is the first to incorporate embedded PPC405 cores and RocketIO MGTs.
- VCCAUX, the auxiliary supply voltage, is 2.5V instead of 3.3V as for Virtex-II devices. Advanced processing at 0.13 µm has resulted in a smaller die, faster speed, and lower power consumption.
- Virtex-II Pro devices are neither bitstream-compatible nor pin-compatible with Virtex-II devices. However, Virtex-II designs can be compiled into Virtex-II Pro devices.
- All banks support 2.5V (and below) I/O standards. LVDCI_33, PCI33_3 and PCI66_3 are supported in designated 3.3V I/O banks only. (Refer to the Virtex-II Pro User Guide for more information on 3.3V I/O support.)

Functional Description: RocketIO Multi-Gigabit Transceiver (MGT)

This section summarizes the features of the RocketIO multi-gigabit transceiver. For an in-depth discussion of the RocketIO MGT, including digital and analog design considerations, refer to the RocketIO Transceiver User Guide.

Overview

The embedded RocketIO multi-gigabit transceiver is based on Mindspeed’s SkyRail™ technology. Up to twenty-four transceivers are available. The transceiver is designed to operate at any baud rate in the range of 622 Mb/s to 3.125 Gb/s per channel. This includes specific baud rates used by various standards as listed in Table 1.

Table 1: Protocols Supported by the RocketIO Transceiver

<table>
<thead>
<tr>
<th>Protocol</th>
<th>Channels (Lanes)</th>
<th>I/O Baud Rate (Gb/s)</th>
<th>Internal Clock Rate (REFCLK) (MHz)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Fibre Channel</td>
<td>1</td>
<td>1.06</td>
<td>53</td>
</tr>
<tr>
<td></td>
<td></td>
<td>2.12</td>
<td>106</td>
</tr>
<tr>
<td>Gigabit Ethernet</td>
<td>1</td>
<td>1.25</td>
<td>62.5</td>
</tr>
<tr>
<td>10Gbit Ethernet</td>
<td>4</td>
<td>3.125</td>
<td>156.25</td>
</tr>
<tr>
<td>Infiniband</td>
<td>1, 4, 12</td>
<td>2.5</td>
<td>125</td>
</tr>
<tr>
<td>Aurora</td>
<td>1, 2, 3, 4, ...</td>
<td>0.840 – 3.125</td>
<td>42.00 – 156.25</td>
</tr>
<tr>
<td>Custom Protocol</td>
<td>1, 2, 3, 4, ...</td>
<td>up to 3.125</td>
<td>up to 156.25</td>
</tr>
</tbody>
</table>
The serial bit rate need not be configured in the transceiver, as the operating frequency is implied by the received data and reference clock applied.

The RocketIO transceiver consists of the Physical Media Attachment (PMA) and Physical Coding Sublayer (PCS). The PMA contains the serializer and deserializer. The PCS contains the bypassable 8B/10B encoder/decoder, elastic buffers, and Cyclic Redundancy Check (CRC) units. The encoder and decoder handle the 8B/10B coding scheme. The elastic buffers support the clock correction (rate matching) and channel bonding features. The CRC units perform CRC generation and checking.

Figure 2 shows a high-level block diagram of the RocketIO transceiver and its FPGA interface signals.

---

Figure 2: RocketIO Transceiver Block Diagram
Clock Synthesizer

Synchronous serial data reception is facilitated by a clock/data recovery circuit. This circuit uses a fully monolithic Phase Lock Loop (PLL), which does not require any external components. The clock/data recovery circuit extracts both phase and frequency from the incoming data stream. The recovered clock is presented on output RXRECCCLK at 1/20 of the serial received data rate.

The gigabit transceiver multiplies the reference frequency provided on the reference clock input (REFCLK) by 20. The multiplication of the clock is achieved by using a fully monolithic PLL that does not require any external components.

No fixed phase relationship is assumed between REFCLK, RXRECCCLK, and/or any other clock that is not tied to either of these clocks. When the 4-byte or 1-byte receiver data path is used, RXUSRCLK and RXUSRCLK2 have different frequencies, and each edge of the slower clock is aligned to a falling edge of the faster clock. The same relationships apply to TXUSRCLK and TXUSRCLK2.

Clock and Data Recovery

The clock/data recovery (CDR) circuits will lock to the reference clock automatically if the data is not present. For proper operation, the frequency of the reference clock must be within ±100 ppm of the nominal frequency.

It is critical to keep power supply noise low in order to minimize common and differential noise modes into the clock/data recovery circuitry. Refer to the RocketIO Transceiver User Guide for more details.

Transmitter

FPGA Transmit Interface

The FPGA can send either one, two, or four characters of data to the transmitter. Each character can be either 8 bits or 10 bits wide. If 8-bit data is applied, the additional inputs become control signals for the 8B/10B encoder. When the 8B/10B encoder is bypassed, the 10-bit character order is generated as follows:

- TXCHARDISPMODE[0] (first bit transmitted)
- TXCHARDISPVAL[0]
- TXDATA[7:0] (last bit transmitted is TXDATA[0])

8B/10B Encoder

A bypassable 8B/10B encoder is included. The encoder uses the same 256 data characters and 12 control characters that are used for Gigabit Ethernet, Fibre Channel, and InfiniBand.

The encoder accepts 8 bits of data along with a K-character signal for a total of 9 bits per character applied, and generates a 10 bit character for transmission. If the K-character signal is High, the data is encoded into one of the twelve possible K-characters available in the 8B/10B code. If the K-character input is Low, the 8 bits are encoded as standard data. If the K-character input is High, and a user applies other than one of the twelve possible combinations, TXKERR indicates the error.

Disparity Control

The 8B/10B encoder is initialized with a negative running disparity. Unique control allows forcing the current running disparity state.

TXRUNDISP signals its current running disparity. This may be useful in those cases where there is a need to manipulate the initial running disparity value.

Bits TXCHARDISPMODE and TXCHARDISPVAL control the generation of running disparity before each byte.

For example, the transceiver can generate the sequence

K28.5+ K28.5+ K28.5– K28.5–

or

K28.5– K28.5– K28.5+ K28.5+

by specifying inverted running disparity for the second and fourth bytes.

Transmit FIFO

Proper operation of the circuit is only possible if the FPGA clock (TXUSRCLK) is frequency-locked to the reference clock (REFCLK). Phase variations up to one clock cycle are allowable. The FIFO has a depth of four. Overflow or underflow conditions are detected and signaled at the interface. Bypassing of this FIFO is programmable.

Serializer

The multi-gigabit transceiver multiplies the reference frequency provided on the reference clock input (REFCLK) by 20. Clock multiplication is achieved by using a fully monolithic PLL requiring no external components. Data is converted from parallel to serial format and transmitted on the TXP and TXN differential outputs. Bit 0 is transmitted first and bit 19 is transmitted last.

The electrical connection of TXP and TXN can be interchanged through configuration. This option can be controlled by an input (TXPOLARITY) at the FPGA transmitter interface. This facilitates recovery from situations where printed circuit board traces have been reversed.

Transmit Termination

On-chip termination is provided at the transmitter, eliminating the need for external termination. Programmable options exist for 50Ω (default) and 75Ω termination.

Pre-Emphasis Circuit and Swing Control

Four selectable levels of pre-emphasis (10% [default], 20%, 25%, and 33%) are available. Optimizing this setting allows the transceiver to drive up to 20 inches of FR4 at the maximum baud rate.

The programmable output swing control can adjust the differential output level between 400 mV and 800 mV in four increments of 100 mV.
Receiver

Deserializer

The RocketIO transceiver accepts serial differential data on its RXP and RXN inputs. The clock/data recovery circuit extracts the clock and retimes incoming data to this clock. It uses a fully monolithic PLL requiring no external components. The clock/data recovery circuitry extracts both phase and frequency from the incoming data stream. The recovered clock is presented on output RXRECLK at 1/20 of the received serial data rate.

The receiver is capable of handling either transition-rich 8B/10B streams or scrambled streams, and can withstand a string of up to 75 non-transitioning bits without an error.

Word alignment is dependent on the state of comma detect bits. If comma detect is enabled, the transceiver recognizes up to two 10-bit preprogrammed characters. Upon detection of the character or characters, the comma detect output is driven high and the data is synchronously aligned. If a comma is detected and the data is aligned, no further alignment alteration takes place. If a comma is received and realignment is necessary, the data is realigned and an indication is given at the receiver interface. The realignment indicator is a distinct output.

The transceiver continuously monitors the data for the presence of the 10-bit character(s). Upon each occurrence of a 10-bit character, the data is checked for word alignment. If comma detect is disabled, the data is not aligned to any particular pattern. The programmable option allows a user to align data on comma+, comma−, both, or a unique user-defined and programmed sequence.

The receiver can be configured to reverse the RXP and RXN inputs. This can be useful in the event that printed circuit board traces have been reversed.

Receiver Termination

On-chip termination is provided at the receiver, eliminating the need for external termination. The receiver includes programmable on-chip termination circuitry for 50Ω (default) or 75Ω impedance.

8B/10B Decoder

An optional 8B/10B decoder is included. A programmable option allows the decoder to be bypassed. When the 8B/10B decoder is bypassed, the 10-bit character order is, for example,

RXCHARISK[0] (first bit received)
RXRUNDISP[0]
RXDATA[7:0] (last bit received is RXDATA[0])

The decoder uses the same table that is used for Gigabit Ethernet, Fibre Channel, and InfiniBand. In addition to decoding all data and K-characters, the decoder has several extra features. The decoder separately detects both “disparity errors” and “out-of-band” errors. A disparity error is the reception of 10-bit character that exists within the 8B/10B table but has an incorrect disparity. An out-of-band error is the reception of a 10-bit character that does not exist within the 8B/10B table. It is possible to obtain an out-of-band error without having a disparity error. The proper disparity is always computed for both legal and illegal characters. The current running disparity is available at the RXRUNDISP signal.

The 8B/10B decoder performs a unique operation if out-of-band data is detected. If out-of-band data is detected, the decoder signals the error and passes the illegal 10-bits through and places them on the outputs. This can be used for debugging purposes if desired.

The decoder also signals the reception of one of the 12 valid K-characters. In addition, a programmable comma detect is included. The comma detect signal registers a comma on the receipt of any comma+, comma−, or both. Since the comma is defined as a 7-bit character, this includes several out-of-band characters. Another option allows the decoder to detect only the three defined commas (K28.1, K28.5, and K28.7) as comma+, comma−, or both. In total, there are six possible options, three for valid commas and three for “any comma.”

Note that all bytes (1, 2, or 4) at the RX FPGA interface each have their own individual 8B/10B indicators (K-character, disparity error, out-of-band error, current running disparity, and comma detect).

Loopback

In order to facilitate testing without having the need to either apply patterns or measure data at GHz rates, two programmable loop-back features are available.

One option, serial loopback, places the gigabit transceiver into a state where transmit data is directly fed back to the receiver. An important point to note is that the feedback path is at the output pads of the transmitter. This tests the entirety of the transmitter and receiver.

The second option, parallel loopback, checks the digital circuitry. When parallel loopback is enabled, the serial loopback path is disabled. However, the transmitter outputs remain active, and data can be transmitted. If TXINHIBIT is asserted, TXP is forced to 0 until TXINHIBIT is de-asserted.

Elastic and Transmitter Buffers

Both the transmitter and the receiver include buffers (FIFOs) in the datapath. This section gives the reasons for including the buffers and outlines their operation.

Receiver Buffer

The receiver buffer is required for two reasons:

- Clock correction to accommodate the slight difference in frequency between the recovered clock RXRECLK and the internal FPGA user clock RXUSRCLK

- Channel bonding to allow realignment of the input stream to ensure proper alignment of data being read through multiple transceivers
The receiver uses an *elastic buffer*, where "elastic" refers to the ability to modify the read pointer for clock correction and channel bonding.

**Clock Correction**

Clock RXRECCLK (the recovered clock) reflects the data rate of the incoming data. Clock RXUSRCLK defines the rate at which the FPGA fabric consumes the data. Ideally, these rates are identical. However, since the clocks typically have different sources, one of the clocks will be faster than the other. The receiver buffer accommodates this difference between the clock rates. See Figure 3.

Clock Correction in Receiver

Nominally, the buffer is always half full. This is shown in the top buffer, Figure 3, where the shaded area represents buffered data not yet read. Received data is inserted via the write pointer under control of RXRECCLK. The FPGA fabric reads data via the read pointer under control of RXUSRCLK. The half full/half empty condition of the buffer gives a cushion for the differing clock rates. This operation continues indefinitely, regardless of whether or not “meaningful” data is being received. When there is no meaningful data to be received, the incoming data will consist of IDLE characters or other padding.

If RXUSRCLK is faster than RXRECCLK, the buffer becomes more empty over time. The clock correction logic corrects for this by decrementing the read pointer to reread a repeatable byte sequence. This is shown in the middle buffer, Figure 3, where the solid read pointer decrements to the value represented by the dashed pointer. By decrementing the read pointer instead of incrementing it in the usual fashion, the buffer is partially refilled. The transceiver design will repeat a single repeatable byte sequence when necessary to refill a buffer. If attribute CLK_COR_REPEAT_WAIT is 0, the transceiver may also skip two consecutive removable byte sequences in one step to further empty the buffer when necessary.

These operations require the clock correction logic to recognize a byte sequence that can be freely repeated or omitted in the incoming data stream. This sequence is generally an IDLE sequence, or other sequence comprised of special values that occur in the gaps separating packets of meaningful data. These gaps are required to occur sufficiently often to facilitate the timely execution of clock correction.

**Channel Bonding**

Some gigabit I/O standards such as Infiniband specify the use of multiple transceivers in parallel for even higher data rates. Words of data are split into bytes, with each byte sent over a separate channel (transceiver). See Figure 4.

Channel Bonding (Alignment)

The top half of the figure shows the transmission of words split across four transceivers (channels or lanes). PPPP, QQQQ, RRRR, SSSS, and TTTT represent words sent over the four channels.

The bottom-left portion of Figure 4 shows the initial situation in the FPGA’s receivers at the other end of the four channels. Due to variations in transmission delay—especially if the channels are routed through repeaters—the FPGA fabric might not correctly assemble the bytes into complete...
words. The bottom-left illustration shows the incorrect assembly of data words PQPP, QRQQ, RSRR, and so forth. To support correction of this misalignment, the data stream includes special byte sequences that define corresponding points in the several channels. In the bottom half of Figure 4, the shaded "P" bytes represent these special characters. Each receiver recognizes the "P" channel bonding character, and remembers its location in the buffer. At some point, one transceiver designated as the master instructs all the transceivers to align to the channel bonding character "P" (or to some location relative to the channel bonding character). After this operation, words transmitted to the FPGA fabric are properly aligned: RRRR, SSSS, TTTT, and so forth, as shown in the bottom-right portion of Figure 4. To ensure that the channels remain properly aligned following the channel bonding operation, the master transceiver must also control the clock correction operations described in the previous section for all channel-bonded transceivers.

Transmitter Buffer

The transmitter's buffer write pointer (TXUSRCLK) is frequency-locked to its read pointer (REFCLK). Therefore, clock correction and channel bonding are not required. The purpose of the transmitter's buffer is to accommodate a phase difference between TXUSRCLK and REFCLK. A simple FIFO suffices for this purpose. A FIFO depth of four will permit reliable operation with simple detection of overflow or underflow, which could occur if the clocks are not frequency-locked.

CRC

The RocketIO transceiver CRC logic supports the 32-bit invariant CRC calculation used by Infiniband, FibreChannel, and Gigabit Ethernet.

On the transmitter side, the CRC logic recognizes where the CRC bytes should be inserted and replaces four placeholder bytes at the tail of a data packet with the computed CRC. For Gigabit Ethernet and FibreChannel, transmitter CRC may adjust certain trailing bytes to generate the required running disparity at the end of the packet. On the receiver side, the CRC logic verifies the received CRC value, supporting the same standards as above. The CRC logic also supports a user mode, with a simple data packet structure beginning and ending with user-defined SOP and EOP characters.

Configuration

This section outlines functions that can be selected or controlled by configuration. Xilinx implementation software supports 16 transceiver primitives, as shown in Table 2.

<table>
<thead>
<tr>
<th>Table 2: Supported RocketIO Transceiver Protocol Primitives</th>
</tr>
</thead>
<tbody>
<tr>
<td>GT_CUSTOM</td>
</tr>
<tr>
<td>GT_FIBRE_CHAN_1</td>
</tr>
<tr>
<td>GT_FIBRE_CHAN_2</td>
</tr>
<tr>
<td>GT_FIBRE_CHAN_4</td>
</tr>
<tr>
<td>GT_ETHERNET_1</td>
</tr>
<tr>
<td>GT_ETHERNET_2</td>
</tr>
<tr>
<td>GT_ETHERNET_4</td>
</tr>
<tr>
<td>GT_XAUI_1</td>
</tr>
<tr>
<td>GT_XAUI_2</td>
</tr>
<tr>
<td>GT_XAUI_4</td>
</tr>
<tr>
<td>GT_INFINIBAND_1</td>
</tr>
<tr>
<td>GT_INFINIBAND_2</td>
</tr>
<tr>
<td>GT_INFINIBAND_4</td>
</tr>
<tr>
<td>GT_AURORA_1(1)</td>
</tr>
<tr>
<td>GT_AURORA_2(1)</td>
</tr>
<tr>
<td>GT_AURORA_4(1)</td>
</tr>
</tbody>
</table>

Notes:
1. For more information on the Aurora protocol, visit [http://www.xilinx.com](http://www.xilinx.com).

Reset

The receiver and transmitter have their own synchronous reset inputs. The transmitter reset centers the transmission FIFO, and resets all transmitter registers and the 8B/10B decoder. The receiver reset centers the receiver elastic buffer, and resets all receiver registers and the 8B/10B encoder. Neither reset has any effect on the PLLs.

Power

All RocketIO transceivers in the FPGA, whether instantiated in the design or not, must be connected to power and ground. Unused transceivers can be powered by any 2.5V source, and passive filtering is not required.

Power Down

The Power Down module is controlled by the transceiver's POWERDOWN input pin. The Power Down pin on the FPGA package has no effect on the transceiver.

Power Sequencing

Although applying power in a random order does not damage the device, it is recommended to apply power in the following sequence to minimize power-on current:
1. Apply FPGA fabric power supplies (VCCINT and VCCAUX) in any order.
2. Apply AVCCAUXRX.
3. Apply AVCCAUTX, VTXT, and VTRX in any order.
Functional Description: Processor Block

This section briefly describes the interfaces and components of the Processor Block. The subsequent section, Functional Description: Embedded PowerPC 405 Core beginning on page 36, offers a summary of major PPC405 core features. For an in-depth discussion on both the Processor Block and PPC405, see PPC405 User Manual and PPC405 Processor Block Manual, available at http://www.xilinx.com.

Processor Block Overview

Figure 5 shows the internal architecture of the Processor Block.

Within the Virtex-II Pro Processor Block, there are four components:

- Embedded IBM PowerPC 405-D5 RISC CPU core
- On-Chip Memory (OCM) controllers and interfaces
- Clock/control interface logic
- CPU-FPGA Interfaces

Embedded PowerPC 405 RISC Core

The PowerPC 405D5 core is a 0.13 µm implementation of the IBM PowerPC 405D4 core. The advanced process technology enables the embedded PowerPC 405 (PPC405) core to operate at 300+ MHz while maintaining low power consumption. Specially designed interface logic integrates the core with the surrounding CLBs, block RAMs, and general routing resources. Up to four Processor Blocks can be available in a single Virtex-II Pro device.

The embedded PPC405 core implements the PowerPC User Instruction Set Architecture (UISA), user-level registers, programming model, data types, and addressing modes for 32-bit fixed-point operations. 64-bit operations, auxiliary processor operations, and floating-point operations are trapped and can be emulated in software.

Most of the PPC405 core features are compatible with the specifications for the PowerPC Virtual Environment Architecture (VEA) and Operating Environment Architecture (OEA). They also provide a number of optimizations and extensions to the lower layers of the PowerPC Architecture. The full architecture of the PPC405 is defined by the PowerPC Embedded Environment and PowerPC UISA documentation, available from IBM.

On-Chip Memory (OCM) Controllers

Introduction

The OCM controllers serve as dedicated interfaces between the block RAMs in the FPGA fabric (see 18 Kb Block SelectRAM+ Resources, page 58) and OCM signals available on the embedded PPC405 core. The OCM signals on the PPC405 core are designed to provide very quick access to a fixed amount of instruction and data memory space. The OCM controller provides an interface to both the 64-bit Instruction-Side Block RAM (ISBRAM) and the 32-bit Data-Side Block RAM (DSBRAM). The designer can choose to implement:

- ISBRAM only
- DSBRAM only
- Both ISBRAM and DSBRAM
- No ISBRAM and no DSBRAM

One of OCM’s primary advantages is that it guarantees a fixed latency of execution for a higher level of determinism. Additionally, it reduces cache pollution and thrashing, since the cache remains available for caching code from other memory resources.

Typical applications for DSOCM include scratch-pad memory, as well as use of the dual-port feature of block RAM to enable bidirectional data transfer between processor and FPGA. Typical applications for ISOCM include storage of interrupt service routines.

Functional Features

Common Features

- Separate Instruction and Data memory interface between processor core and BRAMs in FPGA
- Dedicated interface to Device Control Register (DCR) bus for ISOCM and DSOCM
• Single-cycle and multi-cycle mode option for I-side and D-side interfaces
• Single cycle = one CPU clock cycle; multi-cycle = minimum of two and maximum of eight CPU clock cycles
• FPGA configurable DCR addresses within DSOCM and ISOCM.
• Independent 16 MB logical memory space available within PPC405 memory map for each of the DSOCM and ISOCM. The number of block RAMs in the device might limit the maximum amount of OCM supported.
• Maximum of 64K and 128K bytes addressable from DSOCM and ISOCM interfaces, respectively, using address outputs from OCM directly without additional decoding logic.

Data-Side OCM (DSOCM)
• 32-bit Data Read bus and 32-bit Data Write bus
• Byte write access to DSBRAM support
• Second port of dual port DSBRAM is available to read/write from an FPGA interface
• 22-bit address to DSBRAM port
• 8-bit DCR Registers: DSCNTL, DSARC
• Three alternatives to write into DSBRAM: BRAM initialization, CPU, FPGA H/W using second port

Instruction-Side OCM (ISOCM)
The ISOCM interface contains a 64-bit read only port, for instruction fetches, and a 32-bit write only port, to initialize or test the ISBRAM. When implementing the read only port, the user must deassert the write port inputs. The preferred method of initializing the ISBRAM is through the configuration bitstream.
• 64-bit Data Read Only bus (two instructions per cycle)
• 32-bit Data Write Only bus (through DCR)
• Separate 21-bit address to ISBRAM
• 8-bit DCR Registers: ISCNTL, ISARC
• 32-bit DCR Registers: ISINIT, ISFILL
• Two alternatives to write into ISBRAM: BRAM initialization, DCR and write instruction

Clock/Control Interface Logic
The clock/control interface logic provides proper initialization and connections for PPC405 clock/power management, resets, PLB cycle control, and OCM interfaces. It also couples user signals between the FPGA fabric and the embedded PPC405 CPU core.
The processor clock connectivity is similar to CLB clock pins. It can connect either to global clock nets or general routing resources. Therefore the processor clock source can come from DCM, CLB, or user package pin.

CPU-FPGA Interfaces
All Processor Block user pins link up with the general FPGA routing resources through the CPU-FPGA interface. Therefore processor signals have the same routability as other non-Processor Block user signals. Longlines and hex lines travel across the Processor Block both vertically and horizontally, allowing signals to route through the Processor Block.

Processor Local Bus (PLB) Interfaces
The PPC405 core accesses high-speed system resources through PLB interfaces on the instruction and data cache controllers. The PLB interfaces provide separate 32-bit address/64-bit data buses for the instruction and data sides. The cache controllers are both PLB masters. PLB arbiters are implemented in the FPGA fabric and are available as soft IP cores.

Device Control Register (DCR) Bus Interface
The device control register (DCR) bus has 10 bits of address space for components external to the PPC405 core. Using the DCR bus to manage status and configuration registers reduces PLB traffic and improves system integrity. System resources on the DCR bus are protected or isolated from wayward code since the DCR bus is not part of the system memory map.

On-Chip Memory (OCM) Interfaces
Access to optional, user-configurable direct-mapped memory is through the OCM interfaces. The OCM interfaces can have the same access time as a cache hit, depending on the CPU clock frequency and block RAM size. OCM may be attached to the PPC405 core through the instruction OCM interface and/or the data OCM interface.
Instruction side OCM is often used to hold critical code such as an interrupt handler that requires guaranteed low-latency deterministic access. Data side OCM offers the same fixed low-latency access and is used to hold critical data such as filter coefficients for a DSP application or packets for fast processing. Refer to On-Chip Memory (OCM) Controllers, page 33, for more information.

External Interrupt Controller (EIC) Interface
Two level-sensitive user interrupt pins (critical and non-critical) are available. They can be either driven by user defined logic or Xilinx soft interrupt controller IP core outside the Processor Block.

Clock/Power Management (CPM) Interface
The CPM interface supports several methods of clock distribution and power management. Three modes of operation that reduce power consumption below the normal operational level are available.
Reset Interface

There are three user reset input pins (core, chip, and system) and three user reset output pins for different levels of reset, if required.

Debug Interface

Debugging interfaces on the embedded PPC405 core, consisting of the JTAG and Trace ports, offer access to resources internal to the core and assist in software development. The JTAG port provides basic JTAG chip testing functionality as well as the ability for external debug tools to gain control of the processor for debug purposes. The Trace port furnishes programmers with a mechanism for acquiring instruction execution traces.

The JTAG port complies with IEEE Std 1149.1, which defines a test access port (TAP) and boundary scan architecture. Extensions to the JTAG interface provide debuggers with processor control that includes stopping, starting, and stepping the PPC405 core. These extensions are compliant with the IEEE 1149.1 specifications for vendor-specific extensions.

The Trace port provides instruction execution trace information to an external trace tool. The PPC405 core is capable of back trace and forward trace. Back trace is the tracing of instructions prior to a debug event while forward trace is the tracing of instructions after a debug event.

The processor JTAG port and the FPGA JTAG port can be accessed independently, or the two can be programmatically linked together and accessed via the dedicated FPGA JTAG pins.

CoreConnect™ Bus Architecture

The Processor Block is compatible with the CoreConnect™ bus architecture. Any CoreConnect compliant cores including Xilinx soft IP can integrate with the Processor Block through this high-performance bus architecture implemented on FPGA fabric.

The CoreConnect architecture provides three buses for interconnecting Processor Blocks, Xilinx soft IP, third party IP, and custom logic, as shown in Figure 6:

- Processor Local Bus (PLB)
- On-Chip Peripheral Bus (OPB)
- Device Control Register (DCR) bus

High-performance peripherals connect to the high-bandwidth, low-latency PLB. Slower peripheral cores connect to the OPB, which reduces traffic on the PLB, resulting in greater overall system performance.

For more information, refer to:
Functional Description: Embedded PowerPC 405 Core

This section offers a brief overview of the various functional blocks shown in Figure 7.

Figure 7: Embedded PPC405 Core Block Diagram

Embedded PPC405 Core

The embedded PPC405 core is a 32-bit Harvard architecture processor. Figure 7 illustrates its functional blocks:

- Cache units
- Memory Management unit
- Fetch Decode unit
- Execution unit
- Timers
- Debug logic unit

It operates on instructions in a five stage pipeline consisting of a fetch, decode, execute, write-back, and load write-back stage. Most instructions execute in a single cycle, including loads and stores.

Instruction and Data Cache

The embedded PPC405 core provides an instruction cache unit (ICU) and a data cache unit (DCU) that allow concurrent accesses and minimize pipeline stalls. The instruction and data cache array are 16 KB each. Both cache units are two-way set associative. Each way is organized into 256 lines of 32 bytes (eight words). The instruction set provides a rich assortment of cache control instructions, including instructions to read tag information and data arrays.

The PPC405 core accesses external memory through the instruction (ICU) and data cache units (DCU). The cache units each include a 64-bit PLB master interface, cache arrays, and a cache controller. The ICU and DCU handle cache misses as requests over the PLB to another PLB device such as an external bus interface unit. Cache hits are handled as single cycle memory accesses to the instruction and data caches.

Instruction Cache Unit (ICU)

The ICU provides one or two instructions per cycle to the instruction queue over a 64-bit bus. A line buffer (built into the output of the array for manufacturing test) enables the ICU to be accessed only once for every four instructions, to reduce power consumption by the array.

The ICU can forward any or all of the four or eight words of a line fill to the EXU to minimize pipeline stalls caused by cache misses. The ICU aborts speculative fetches abandoned by the EXU, eliminating unnecessary line fills and enabling the ICU to handle the next EXU fetch. Aborting abandoned requests also eliminates unnecessary external bus activity, thereby increasing external bus utilization.

Data Cache Unit (DCU)

The DCU transfers one, two, three, four, or eight bytes per cycle, depending on the number of byte enables presented by the CPU. The DCU contains a single-element command and store data queue to reduce pipeline stalls; this queue enables the DCU to independently process load/store and cache control instructions. Dynamic PLB request prioritization reduces pipeline stalls even further. When the DCU is busy with a low-priority request while a subsequent storage operation requested by the CPU is stalled; the DCU automatically increases the priority of the current request to the PLB.
The DCU provides additional features that allow the programmer to tailor its performance for a given application. The DCU can function in write-back or write-through mode, as controlled by the Data Cache Write-through Register (DCWR) or the Translation Look-aside Buffer (TLB); the cache controller can be tuned for a balance of performance and memory coherency. Write-on-allocate, controlled by the store word on allocate (SWOA) field of the Core Configuration Register 0 (CCRO), can inhibit line fills caused by store misses, to further reduce potential pipeline stalls and unwanted external bus traffic.

**Fetch and Decode Logic**

The fetch/decode logic maintains a steady flow of instructions to the execution unit by placing up to two instructions in the fetch queue. The fetch queue consists of three buffers: pre-fetch buffer 1 (PFB1), pre-fetch buffer 0 (PFBO), and decode (DCD). The fetch logic ensures that instructions proceed directly to decode when the queue is empty.

Static branch prediction as implemented on the PPC405 core takes advantage of some standard statistical properties of code. Branches with negative address displacement are by default assumed taken. Branches that do not test the condition or count registers are also predicted as taken. The PPC405 core bases branch prediction upon these default conditions when a branch is not resolved and speculatively fetches along the predicted path. The default prediction can be overridden by software at assembly or compile time.

Branches are examined in the decode and pre-fetch buffer 0 fetch queue stages. Two branch instructions can be handled simultaneously. If the branch in decode is not taken, the fetch logic fetches along the predicted path of the branch instruction in pre-fetch buffer 0. If the branch in decode is taken, the fetch logic ignores the branch instruction in pre-fetch buffer 0.

**Execution Unit**

The embedded PPC405 core has a single issue execution unit (EXU) containing the register file, arithmetic logic unit (ALU), and the multiply-accumulate (MAC) unit. The execution unit performs all 32-bit PowerPC integer instructions in hardware.

The register file is comprised of thirty-two 32-bit general purpose registers (GPR), which are accessed with three read ports and two write ports. During the decode stage, data is read out of the GPRs and fed to the execution unit. Likewise, during the write-back stage, results are written to the GPR. The use of the five ports on the register file enables either a load or a store operation to execute in parallel with an ALU operation.

**Memory Management Unit (MMU)**

The embedded PPC405 core has a 4 GB address space, which is presented as a flat address space.

The MMU provides address translation, protection functions, and storage attribute control for embedded applications. The MMU supports demand-paged virtual memory and other management schemes that require precise control of logical-to-physical address mapping and flexible memory protection. Working with appropriate system-level software, the MMU provides the following functions:

- Translation of the 4 GB effective address space into physical addresses
- Independent enabling of instruction and data translation/protection
- Page-level access control using the translation mechanism
- Software control of page replacement strategy
- Additional control over protection using zones
- Storage attributes for cache policy and speculative memory access control

The MMU can be disabled under software control. If the MMU is not used, the PPC405 core provides other storage control mechanisms.

**Translation Look-Aside Buffer (TLB)**

The Translation Look-Aside Buffer (TLB) is the hardware resource that controls translation and protection. It consists of 64 entries, each specifying a page to be translated. The TLB is fully associative; a given page entry can be placed anywhere in the TLB. The translation function of the MMU occurs pre-cache. Cache tags and indexing use physical addresses.

Software manages the establishment and replacement of TLB entries. This gives system software significant flexibility in implementing a custom page replacement strategy. For example, to reduce TLB thrashing or translation delays, software can reserve several TLB entries in the TLB for globally accessible static mappings. The instruction set provides several instructions used to manage TLB entries. These instructions are privileged and require the software to be executing in supervisor state. Additional TLB instructions are provided to move TLB entry fields to and from GPRs.

The MMU divides logical storage into pages. Eight page sizes (1 KB, 4 KB, 16 KB, 64 KB, 256 KB, 1 MB, 4 MB, and 16 MB) are simultaneously supported, such that, at any given time, the TLB can contain entries for any combination of page sizes. In order for a logical to physical translation to exist, a valid entry for the page containing the logical address must be in the TLB. Addresses for which no TLB entry exists cause TLB-Miss exceptions.

To improve performance, four instruction-side and eight data-side TLB entries are kept in shadow arrays. The shadow arrays allow single-cycle address translation and also help to avoid TLB contention between load/store and instruction fetch operations. Hardware manages the
replacement and invalidation of shadow-TLB entries; no system software action is required.

**Memory Protection**

When address translation is enabled, the translation mechanism provides a basic level of protection.

The Zone Protection Register (ZPR) enables the system software to override the TLB access controls. For example, the ZPR provides a way to deny read access to application programs. The ZPR can be used to classify storage by type; access by type can be changed without manipulating individual TLB entries.

The PowerPC Architecture provides WIUOG (write-back/write-through, cacheability, user-defined, guarded, endian) storage attributes that control memory accesses, using bits in the TLB or, when address translation is disabled, storage attribute control registers.

When address translation is enabled, storage attribute control bits in the TLB control the storage attributes associated with the current page. When address translation is disabled, bits in each storage attribute control register control the storage attributes associated with storage regions. Each storage attribute control register contains 32 fields. Each field sets the associated storage attribute for a 128 MB memory region.

**Timers**

The embedded PPC405 core contains a 64-bit time base and three timers, as shown in Figure 8:

- Programmable Interval Timer (PIT)
- Fixed Interval Timer (FIT)
- Watchdog Timer (WDT)

The time base counter increments either by an internal signal equal to the CPU clock rate or by a separate external timer clock signal. No interrupts are generated when the time base rolls over. The three timers are synchronous with the time base.

The PIT is a 32-bit register that decrements at the same rate as the time base is incremented. The user loads the PIT register with a value to create the desired delay. When the register reaches zero, the timer stops decrementing and generates a PIT interrupt. Optionally, the PIT can be programmed to auto-reload the last value written to the PIT register, after which the PIT continues to decrement.

The FIT generates periodic interrupts based on one of four selectable bits in the time base. When the selected bit changes from 0 to 1, the PPC405 core generates a FIT interrupt.

The WDT provides a periodic critical-class interrupt based on a selected bit in the time base. This interrupt can be used for system error recovery in the event of software or system lockups. Users may select one of four time periods for the interval and the type of reset generated if the WDT expires twice without an intervening clear from software. If enabled, the watchdog timer generates a reset unless an exception handler updates the WDT status bit before the timer has completed two of the selected timer intervals.

Figure 8: Relationship of Timer Facilities to Base Clock

**Interrupts**

The PPC405 provides an interface to an interrupt controller that is logically outside the PPC405 core. This controller combines the asynchronous interrupt inputs and presents them to the embedded core as a single interrupt signal. The sources of asynchronous interrupts are external signals, the JTAG/debug unit, and any implemented peripherals.

**Debug Logic**

All architected resources on the embedded PPC405 core can be accessed through the debug logic. Upon a debug event, the PPC405 core provides debug information to an external debug tool. Three different types of tools are supported depending on the debug mode: ROM monitors, JTAG debuggers, and instruction trace tools.

In internal debug mode, a debug event enables exception-handling software at a dedicated interrupt vector to take over the CPU core and communicate with a debug tool. The debug tool has read-write access to all registers and can set hardware or software breakpoints. ROM monitors typically use the internal debug mode.

In external debug mode, the CPU core enters stop state (stops instruction execution) when a debug event occurs. This mode offers a debug tool read-write access to all registers in the PPC405 core. Once the CPU core is in stop state,
the debug tool can start the CPU core, step an instruction, freeze the timers, or set hardware or software break points. In addition to CPU core control, the debug logic is capable of writing instructions into the instruction cache, eliminating the need for external memory during initial board bring-up. Communication to a debug tool using external debug mode is through the JTAG port.

Debug wait mode offers the same functionality as external debug mode with one exception. In debug wait mode, the CPU core goes into wait state instead of stop state after a debug event. Wait state is identical to stop state until an interrupt occurs. In wait state, the PPC405 core can vector to an exception handler, service an interrupt and return to wait state. This mode is particularly useful when debugging real-time control systems.

Real-time trace debug mode is always enabled. The debug logic continuously broadcasts instruction trace information to the trace port. When a debug event occurs, the debug logic signals an external debug tool to save instruction trace information before and after the event. The number of instructions traced depends on the trace tool.

Debug events signal the debug logic to stop the CPU core, put the CPU core in debug wait state, cause a debug exception or save instruction trace information.

**Big Endian and Little Endian Support**

The embedded PPC405 core supports big endian or little endian byte ordering for instructions stored in external memory. Since the PowerPC architecture is big endian internally, the ICU rearranges the instructions stored as little endian into the big endian format. Therefore, the instruction cache always contains instructions in big endian format so that the byte ordering is correct for the execution unit. This feature allows the 405 core to be used in systems designed to function in a little endian environment.

### Functional Description: FPGA

#### Input/Output Blocks (IOBs)

Virtex-II Pro I/O blocks (IOBs) are provided in groups of two or four on the perimeter of each device. Each IOB can be used as input and/or output for single-ended I/Os. Two IOBs can be used as a differential pair. A differential pair is always connected to the same switch matrix, as shown in Figure 9. IOB blocks are designed for high-performance I/O, supporting 19 single-ended standards, as well as differential signaling with LVDS, LDT, bus LVDS, and LVPECL.

![Switch Matrix and IO Blocks](image)

**Figure 9: Virtex-II Pro Input/Output Tile**

**Note:** Differential I/Os must use the same clock.

#### Supported I/O Standards

Virtex-II Pro IOB blocks feature SelectIO™-Ultra inputs and outputs that support a wide variety of I/O signaling standards. In addition to the internal supply voltage ($V_{CCINT} = 1.5V$), output driver supply voltage ($V_{CCO}$) is dependent on the I/O standard (see Table 3 and Table 4). An auxiliary supply voltage ($V_{CCAUX} = 2.5V$) is required, regardless of the I/O standard used. For exact supply voltage absolute maximum ratings, see Virtex-II Pro™ Platform FPGAs: DC and Switching Characteristics (Module 3).

**Table 3: Supported Single-Ended I/O Standards**

<table>
<thead>
<tr>
<th>I/O Standard</th>
<th>Output $V_{CCO}$</th>
<th>Input $V_{CCO}$</th>
<th>Input $V_{REF}$</th>
<th>Board Termination Voltage ($V_{TT}$)</th>
</tr>
</thead>
<tbody>
<tr>
<td>LVCMOS25</td>
<td>2.5</td>
<td>2.5</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>LVCMOS18</td>
<td>1.8</td>
<td>1.8</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>LVCMOS15</td>
<td>1.5</td>
<td>1.5</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>PCI33_3</td>
<td>3.3</td>
<td>3.3</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>PCI66_3</td>
<td>3.3</td>
<td>3.3</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>GTL</td>
<td>Note (1)</td>
<td>Note (1)</td>
<td>0.8</td>
<td>1.2</td>
</tr>
<tr>
<td>GTLP</td>
<td>Note (1)</td>
<td>Note (1)</td>
<td>1.0</td>
<td>1.5</td>
</tr>
<tr>
<td>HSTL_I</td>
<td>1.5</td>
<td>N/A</td>
<td>0.75</td>
<td>0.75</td>
</tr>
<tr>
<td>HSTL_I_18</td>
<td>1.8</td>
<td>N/A</td>
<td>0.9</td>
<td>0.9</td>
</tr>
<tr>
<td>HSTL_I_18</td>
<td>1.8</td>
<td>N/A</td>
<td>0.9</td>
<td>0.9</td>
</tr>
<tr>
<td>HSTL_III</td>
<td>1.5</td>
<td>N/A</td>
<td>0.9</td>
<td>1.5</td>
</tr>
<tr>
<td>HSTL_III_18</td>
<td>1.8</td>
<td>N/A</td>
<td>1.08</td>
<td>1.8</td>
</tr>
<tr>
<td>HSTL_IV</td>
<td>1.5</td>
<td>N/A</td>
<td>1.08</td>
<td>1.8</td>
</tr>
<tr>
<td>SSSL2_I</td>
<td>2.5</td>
<td>N/A</td>
<td>1.25</td>
<td>1.25</td>
</tr>
<tr>
<td>SSSL2_II</td>
<td>2.5</td>
<td>N/A</td>
<td>1.25</td>
<td>1.25</td>
</tr>
<tr>
<td>SSSL18_1(2)</td>
<td>1.8</td>
<td>N/A</td>
<td>0.9</td>
<td>0.9</td>
</tr>
</tbody>
</table>
All of the user IOBs have fixed-clamp diodes to VCCO and to ground. The IOBs are not compatible or compliant with 5V I/O standards (not 5V-tolerant). The IOBs support 3.3V I/O standards such as PCI33/66, LVTTL, and LVCMOS_33. See XAPP659 for implementation guidelines.

Table 5 lists supported I/O standards with Digitally Controlled Impedance (DCI), page 46.

### Logic Resources

IOB blocks include six storage elements, as shown in Figure 10.

Each storage element can be configured either as an edge-triggered D-type flip-flop or as a level-sensitive latch. On the input, output, and 3-state path, one or two DDR registers can be used.

Double data rate is directly accomplished by the two registers on each path, clocked by the rising edges (or falling edges) from two different clock nets. The two clock signals are generated by the DCM and must be 180 degrees out of phase, as shown in Figure 11. There are two input, output, and 3-state data signals, each being alternately clocked out.
This DDR mechanism can be used to mirror a copy of the clock on the output. This is useful for propagating a clock along the data that has an identical delay. It is also useful for multiple clock generation, where there is a unique clock driver for every clock load. Virtex-II Pro devices can produce many copies of a clock with very little skew.

![Double Data Rate Registers](image)

Each group of two registers has a clock enable signal (ICE for the input registers, OCE for the output registers, and TCE for the 3-state registers). The clock enable signals are active High by default. If left unconnected, the clock enable for that storage element defaults to the active state.

Each IOB block has common synchronous or asynchronous set and reset (SR and REV signals).

SR forces the storage element into the state specified by the SRHIGH or SRLOW attribute. SRHIGH forces a logic 1. SRLOW forces a logic 0. When SR is used, a second input (REV) forces the storage element into the opposite state. The reset condition predominates over the set condition. The initial state after configuration or global initialization state is defined by a separate INIT0 and INIT1 attribute. By default, the SRLOW attribute forces INIT0, and the SRHIGH attribute forces INIT1.

For each storage element, the SRHIGH, SRLOW, INIT0, and INIT1 attributes are independent. Synchronous or asynchronous set / reset is consistent in an IOB block.

All the control signals have independent polarity. Any inverter placed on a control input is automatically absorbed.

Each register or latch, independent of all other registers or latches, can be configured as follows:

- No set or reset
- Synchronous set
- Synchronous reset
- Synchronous set and reset
- Asynchronous set (preset)
- Asynchronous set and reset (clear)
- Asynchronous set and reset (preset and clear)

The synchronous reset overrides a set, and an asynchronous clear overrides a preset.

Refer to Figure 12.
Input/Output Individual Options

Each device pad has optional pull-up/pull-down resistors and weak-keeper circuit in the LVCMOS SelectIO-Ultra configuration, as illustrated in Figure 13. Values of the optional pull-up and pull-down resistors fall within a range of 40 KΩ to 120 KΩ when \( V_{CCO} = 2.5V \) (from 2.38V to 2.63V only). The clamp diode is always present, even when power is not.

The optional weak-keeper circuit is connected to each output. When selected, the circuit monitors the voltage on the pad and weakly drives the pin High or Low. If the pin is connected to a multiple-source signal, the weak-keeper holds the signal in its last state if all drivers are disabled. Maintaining a valid logic level in this way eliminates bus chatter. An enabled pull-up or pull-down overrides the weak-keeper circuit.
LVCMOS25 sinks and sources current up to 24 mA. The current is programmable (see Table 6). Drive strength and slew rate controls for each output driver minimize bus transients. For LVDCI and LVDCI_DV2 standards, drive strength and slew rate controls are not available.

Table 6: LVCMOS Programmable Currents (Sink and Source)

<table>
<thead>
<tr>
<th>SelectIO-Ultra</th>
<th>Programable Current (Worst-Case Guaranteed Minimum)</th>
</tr>
</thead>
<tbody>
<tr>
<td>LVCMOS25</td>
<td>2 mA    4 mA    6 mA    8 mA    12 mA    16 mA    24 mA</td>
</tr>
<tr>
<td>LVCMOS18</td>
<td>2 mA    4 mA    6 mA    8 mA    12 mA    16 mA    n/a</td>
</tr>
<tr>
<td>LVCMOS15</td>
<td>2 mA    4 mA    6 mA    8 mA    12 mA    16 mA    n/a</td>
</tr>
</tbody>
</table>

Figure 14 shows the SSTL2, SSTL18, and HSTL configurations. HSTL can sink current up to 48 mA. (HSTL IV)

![Figure 14: SSTL or HSTL SelectIO-Ultra Standards](image)

All pads are protected against damage from electrostatic discharge (ESD) and from over-voltage transients. Virtex-II Pro uses two memory cells to control the configuration of an I/O as an input. This is to reduce the probability of an I/O configured as an input from flipping to an output when subjected to a single event upset (SEU) in space applications.

Prior to configuration, all outputs not involved in configuration are forced into their high-impedance state. The pull-down resistors and the weak-keeper circuits are inactive. The dedicated pin HSWAP_EN controls the pull-up resistors prior to configuration. By default, HSWAP_EN is set High, which disables the pull-up resistors on user I/O pins. When HSWAP_EN is set Low, the pull-up resistors are activated on user I/O pins.

All Virtex-II Pro IOBs (except RocketIO transceiver pins) support IEEE 1149.1 and IEEE 1532 compatible boundary scan testing.

Input Path

The Virtex-II Pro IOB input path routes input signals directly to internal logic and/or through an optional input flip-flop or latch, or through the DDR input registers. An optional delay element at the D-input of the storage element eliminates pad-to-pad hold time. The delay is matched to the internal clock-distribution delay of the Virtex-II Pro device, and when used, assures that the pad-to-pad hold time is zero.

Each input buffer can be configured to conform to any of the low-voltage signaling standards supported. In some of these standards the input buffer utilizes a user-supplied threshold voltage, \( V_{REF} \). The need to supply \( V_{REF} \) imposes constraints on which standards can be used in the same bank. See I/O banking description.

Output Path

The output path includes a 3-state output buffer that drives the output signal onto the pad. The output and/or the 3-state signal can be routed to the buffer directly from the internal logic or through an output/3-state flip-flop or latch, or through the DDR output/3-state registers.

Each output driver can be individually programmed for a wide range of low-voltage signaling standards. In most signaling standards, the output High voltage depends on an externally supplied \( V_{CCO} \) voltage. The need to supply \( V_{CCO} \) imposes constraints on which standards can be used in the same bank. See I/O banking description.

I/O Banking

Some of the I/O standards described above require \( V_{CCO} \) and \( V_{REF} \) voltages. These voltages are externally supplied and connected to device pins that serve groups of I/O blocks, called banks. Consequently, restrictions exist about which I/O standards can be combined within a given bank.

Eight I/O banks result from dividing each edge of the FPGA into two banks, as shown in Figure 15 and Figure 16. Each bank has multiple \( V_{CCO} \) pins, all of which must be connected to the same voltage. This voltage is determined by the output standards in use.
Within a bank, output standards can be mixed only if they use the same V\textsubscript{CCO}. Compatible standards are shown in Table 7. GTL and GTLP appear under all voltages because their open-drain outputs do not depend on V\textsubscript{CCO}.

Some input standards require a user-supplied threshold voltage, V\textsubscript{REF}. In this case, certain user-I/O pins are automatically configured as inputs for the V\textsubscript{REF} voltage. Approximately one in six of the I/O pins in the bank assume this role. Table 8 lists compatible input standards.

V\textsubscript{REF} pins within a bank are interconnected internally, and consequently only one V\textsubscript{REF} voltage can be used within each bank. However, for correct operation, all V\textsubscript{REF} pins in the bank must be connected to the external reference voltage source.

The V\textsubscript{CCO} and the V\textsubscript{REF} pins for each bank appear in the device pinout tables. Within a given package, the number of V\textsubscript{REF} and V\textsubscript{CCO} pins can vary depending on the size of device. In larger devices, more I/O pins convert to V\textsubscript{REF} pins. Since these are always a superset of the V\textsubscript{REF} pins used for smaller devices, it is possible to design a PCB that permits migration to a larger device if necessary.

### Table 7: Compatible Output Standards

<table>
<thead>
<tr>
<th>V\textsubscript{CCO}</th>
<th>Compatible Standards</th>
</tr>
</thead>
<tbody>
<tr>
<td>3.3V</td>
<td>PCI\textsuperscript{(1)}, LVDCI_33\textsuperscript{(2)}</td>
</tr>
<tr>
<td>2.5V</td>
<td>SSTL2 (I &amp; II), LVCMOS25, GTL, GTLP, LVDS\textsubscript{25}, LVDS\textsubscript{EXT25}, LVDS\textsubscript{25_DCI}, LVDS\textsubscript{25_DCI}, LVDCI\textsubscript{25}, LVDCI\textsubscript{DV2_25}, SSTL2\textsubscript{DCI (I &amp; II)}, LDT, ULVDS, BLVDS, LVPECL\textsubscript{25}</td>
</tr>
<tr>
<td>1.8V</td>
<td>HSTL (I, II, III, &amp; IV), HSTL\textsubscript{DCI (I,II, III &amp; IV)}, LVCMOS18, GTL, GTLP, LVDCI\textsubscript{18}, LVDCI\textsubscript{DV2_18}, SSTL18\textsubscript{I}, SSTL18\textsubscript{II}, SSTL18\textsubscript{I_DCI}, SSTL18\textsubscript{II_DCI}</td>
</tr>
<tr>
<td>1.5V</td>
<td>HSTL (I, II, III, &amp; IV), HSTL\textsubscript{DCI (I,II, III &amp; IV)}, LVCMOS15, GTL, GTLP, LVDCI\textsubscript{15}, LVDCI\textsubscript{DV2_15}, GTLP\textsubscript{DCI}</td>
</tr>
<tr>
<td>1.2V</td>
<td>GTL\textsubscript{DCI}</td>
</tr>
</tbody>
</table>

**Notes:**
1. See application notes XAPP646 and XAPP653 for detailed information.
2. Perfect impedance matching is required for this standard.

All V\textsubscript{REF} pins for the largest device anticipated must be connected to the V\textsubscript{REF} voltage and not used for I/O. In smaller devices, some V\textsubscript{CCO} pins used in larger devices do not connect within the package. These unconnected pins can be left unconnected externally, or, if necessary, they can be connected to the V\textsubscript{CCO} voltage to permit migration to a larger device.
Table 8: Compatible Input Standards

<table>
<thead>
<tr>
<th>VREF</th>
<th>3.3V</th>
<th>2.5V</th>
<th>1.8V</th>
<th>1.5V</th>
<th>1.2V</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>No VREF</strong></td>
<td>LVCMS25, LDVCI_25,</td>
<td>LVCMS25, LDVCI_25,</td>
<td>LVCMS18, LDVCI_18,</td>
<td>LVCMS15, LDVCI_15,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>LDVCI_DV2_25, LDVCI_25,</td>
<td>LDVCI_DV2_25, LDVCI_25,</td>
<td>LDVCI_DV2_18, LDVCI_DV2_18,</td>
<td>LDVCI_DV2_15, LDVCI_DV2_15,</td>
<td>LDVCI_DV2_18, LDVCI_DV2_18,</td>
</tr>
<tr>
<td></td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td></td>
</tr>
<tr>
<td>1.5V</td>
<td>LVCMS25, LDVCI_25,</td>
<td>LVCMS25, LDVCI_25,</td>
<td>LVCMS18, LDVCI_18,</td>
<td>LVCMS15, LDVCI_15,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>LDVCI_DV2_25, LDVCI_25,</td>
<td>LDVCI_DV2_25, LDVCI_25,</td>
<td>LDVCI_DV2_18, LDVCI_DV2_18,</td>
<td>LDVCI_DV2_15, LDVCI_DV2_15,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td></td>
</tr>
<tr>
<td>1.32V</td>
<td>LVCMS25, LDVCI_25,</td>
<td>LVCMS25, LDVCI_25,</td>
<td>LVCMS18, LDVCI_18,</td>
<td>LVCMS15, LDVCI_15,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>LDVCI_DV2_25, LDVCI_25,</td>
<td>LDVCI_DV2_25, LDVCI_25,</td>
<td>LDVCI_DV2_18, LDVCI_DV2_18,</td>
<td>LDVCI_DV2_15, LDVCI_DV2_15,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td></td>
</tr>
<tr>
<td>1.25V</td>
<td>LVCMS25, LDVCI_25,</td>
<td>LVCMS25, LDVCI_25,</td>
<td>LVCMS18, LDVCI_18,</td>
<td>LVCMS15, LDVCI_15,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>LDVCI_DV2_25, LDVCI_25,</td>
<td>LDVCI_DV2_25, LDVCI_25,</td>
<td>LDVCI_DV2_18, LDVCI_DV2_18,</td>
<td>LDVCI_DV2_15, LDVCI_DV2_15,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td></td>
</tr>
<tr>
<td>0.9V</td>
<td>LVCMS25, LDVCI_25,</td>
<td>LVCMS25, LDVCI_25,</td>
<td>LVCMS18, LDVCI_18,</td>
<td>LVCMS15, LDVCI_15,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>LDVCI_DV2_25, LDVCI_25,</td>
<td>LDVCI_DV2_25, LDVCI_25,</td>
<td>LDVCI_DV2_18, LDVCI_DV2_18,</td>
<td>LDVCI_DV2_15, LDVCI_DV2_15,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td>LDVDS_25, LDVDS_25,</td>
<td></td>
</tr>
</tbody>
</table>

Notes:
1. Inputs that are VREF controlled are completely independent of those that are VCCO controlled. Therefore, VREF controlled inputs can also be placed in banks with inputs and outputs of different voltages that are VCCO controlled.
2. All non-DCI differential inputs are VCCAux controlled. This makes them (Inputs Only) very flexible in terms of banking rules.
3. It is important to ensure that the input DC levels are within VCCO + 0.5V, because all user I/Os have clamp diodes connected to VCCO.
Digitally Controlled Impedance (DCI)

Today’s chip output signals with fast edge rates require termination to prevent reflections and maintain signal integrity. High pin count packages (especially ball grid arrays) can not accommodate external termination resistors.

Virtex-II Pro XCITE DCI provides controlled impedance drivers and on-chip termination for single-ended I/Os. This eliminates the need for external resistors, and improves signal integrity. The DCI feature can be used on any IOB by selecting one of the DCI I/O standards.

When applied to inputs, DCI provides input parallel termination. When applied to outputs, DCI provides controlled impedance drivers (series termination) or output parallel termination.

DCI operates independently on each I/O bank. When a DCI I/O standard is used in a particular I/O bank, external reference resistors must be connected to two dual-function pins on the bank. These resistors, voltage reference of N transistor (VRN) and the voltage reference of P transistor (VRP) are shown in Figure 17.

When used with a terminated I/O standard, the value of the resistors are specified by the standard (typically 50Ω). When used with a controlled impedance driver, the resistors set the output impedance of the driver within the specified range (20Ω to 100Ω). For all series and parallel terminations listed in Table 9 and Table 10, the reference resistors must have the same value for any given bank. One percent resistors are recommended.

The DCI system adjusts the I/O impedance to match the two external reference resistors, or half of the reference resistors, and compensates for impedance changes due to voltage and/or temperature fluctuations. The adjustment is done by turning parallel transistors in the IOB on or off.

Controlled Impedance Drivers (Series Termination)

DCI can be used to provide a buffer with a controlled output impedance. It is desirable for this output impedance to match the transmission line impedance (Z₀). Virtex-II Pro input buffers also support LVDCI and LVDCI_DV2 I/O standards.

Controlled Impedance Terminations (Parallel Termination)

DCI also provides on-chip termination for SSTL2, SSTL18, HSTL (Class I, II, III, or IV), LVDS_25, LVDSEXT_25, and GTL/GTLP receivers or transmitters on bidirectional lines. Table 10 and Table 11 list the on-chip parallel terminations available in Virtex-II Pro devices. VCCO must be set according to Table 5. Note that there is a VCCO requirement for GTL_DCI and GTLP_DCI, due to the on-chip termination resistor.

Table 9: SelectIO-Ultra Controlled Impedance Buffers

<table>
<thead>
<tr>
<th>VCCO</th>
<th>DCI</th>
<th>DCI Half Impedance</th>
</tr>
</thead>
<tbody>
<tr>
<td>3.3V</td>
<td>LVDCI_33</td>
<td>N/A</td>
</tr>
<tr>
<td>2.5V</td>
<td>LVDCI_25</td>
<td>LVDCI_DV2_25</td>
</tr>
<tr>
<td>1.8V</td>
<td>LVDCI_18</td>
<td>LVDCI_DV2_18</td>
</tr>
<tr>
<td>1.5V</td>
<td>LVDCI_15</td>
<td>LVDCI_DV2_15</td>
</tr>
</tbody>
</table>

Table 10: SelectIO-Ultra Buffers With On-Chip Parallel Termination

<table>
<thead>
<tr>
<th>I/O Standard</th>
<th>External Termination</th>
<th>On-Chip Termination</th>
</tr>
</thead>
<tbody>
<tr>
<td>SSTL2 Class I</td>
<td>SSTL2_I</td>
<td>SSTL2_I_DCI</td>
</tr>
<tr>
<td>SSTL2 Class II</td>
<td>SSTL2_II</td>
<td>SSTL2_II_DCI</td>
</tr>
<tr>
<td>SSTL18 Class I</td>
<td>SSTL18_I</td>
<td>SSTL18_I_DCI</td>
</tr>
<tr>
<td>SSTL18 Class II</td>
<td>SSTL18_II</td>
<td>SSTL18_II_DCI</td>
</tr>
<tr>
<td>HSTL Class I</td>
<td>HSTL_I</td>
<td>HSTL_I_DCI</td>
</tr>
<tr>
<td>HSTL Class II</td>
<td>HSTL_II</td>
<td>HSTL_II_DCI</td>
</tr>
<tr>
<td>HSTL Class III</td>
<td>HSTL_III</td>
<td>HSTL_III_DCI</td>
</tr>
<tr>
<td>HSTL Class IV</td>
<td>HSTL_IV</td>
<td>HSTL_IV_DCI</td>
</tr>
<tr>
<td>GTL</td>
<td>GTL</td>
<td>GTL_DCI</td>
</tr>
<tr>
<td>GTLP</td>
<td>GTLP</td>
<td>GTLP_DCI</td>
</tr>
</tbody>
</table>

Notes:
1. SSTL Compatible
Table 11: SelectIO-Ultra Differential Buffers With On-Chip Termination

<table>
<thead>
<tr>
<th>I/O Standard</th>
<th>External Termination</th>
<th>On-Chip Termination</th>
</tr>
</thead>
<tbody>
<tr>
<td>LVDS</td>
<td>LVDS_25</td>
<td>LVDS_25_DCI</td>
</tr>
<tr>
<td>LVDSEXT</td>
<td>LVDSEXT_25</td>
<td>LVDSEXT_25_DCI</td>
</tr>
</tbody>
</table>

Figure 19 provides examples illustrating the use of the HSTL_I_DCI, HSTL_II_DCI, HSTL_III_DCI, and HSTL_IV_DCI I/O standards. For a complete list, see the Virtex-II Pro User Guide.

Figure 19: HSTL DCI Usage Examples
Figure 20 provides examples illustrating the use of the SSTL2_I_DCI, SSTL2_II_DCI, SSTL18_I_DCI, and SSTL18_II_DCI I/O standards. For a complete list, see the Virtex-II Pro User Guide.

![SSTL DCI Usage Examples](DS083-2_65b_082902)

**Figure 20: SSTL DCI Usage Examples**
Figure 21 provides examples illustrating the use of the LVDS_25_DCI and LVDSEXT_25_DCI I/O standards. For a complete list, see the Virtex-II Pro User Guide.

Configurable Logic Blocks (CLBs)

The Virtex-II Pro configurable logic blocks (CLB) are organized in an array and are used to build combinatorial and synchronous logic designs. Each CLB element is tied to a switch matrix to access the general routing matrix, as shown in Figure 22.

A CLB element comprises 4 similar slices, with fast local feedback within the CLB. The four slices are split in two columns of two slices with two independent carry logic chains and one common shift chain.

Slice Description

Each slice includes two 4-input function generators, carry logic, arithmetic logic gates, wide function multiplexers and two storage elements. As shown in Figure 23, each 4-input function generator is programmable as a 4-input LUT, 16 bits of distributed SelectRAM+ memory, or a 16-bit variable-tap shift register element.

Figure 22: Virtex-II Pro CLB Element

Figure 23: Virtex-II Pro Slice Configuration
The output from the function generator in each slice drives both the slice output and the D input of the storage element. Figure 24 shows a more detailed view of a single slice.

**Configurations**

**Look-Up Table**

Virtex-II Pro function generators are implemented as 4-input look-up tables (LUTs). Four independent inputs are provided to each of the two function generators in a slice (F and G). These function generators are each capable of implementing any arbitrarily defined boolean function of four inputs. The propagation delay is therefore independent of the function implemented. Signals from the function generators can exit the slice (X or Y output), can input the XOR dedicated gate (see arithmetic logic), or input the carry-logic multiplexer (see fast look-ahead carry logic), or feed the D input of the storage element, or go to the MUXF5 (not shown in Figure 24).

In addition to the basic LUTs, the Virtex-II Pro slice contains logic (MUXF5 and MUXFX multiplexers) that combines function generators to provide any function of five, six, seven, or eight inputs. The MUXFX is either MUXF6, MUXF7, or MUXF8 according to the slice considered in the CLB. Selected functions up to nine inputs (MUXF5 multiplexer) can be implemented in one slice. The MUXFX can also be a MUXF6, MUXF7, or MUXF8 multiplexer to map any function of six, seven, or eight inputs and selected wide logic functions.
Register/Latch

The storage elements in a Virtex-II Pro slice can be configured either as edge-triggered D-type flip-flops or as level-sensitive latches. The D input can be directly driven by the X or Y output via the DX or DY input, or by the slice inputs bypassing the function generators via the BX or BY input. The clock enable signal (CE) is active High by default. If left unconnected, the clock enable for that storage element defaults to the active state.

In addition to clock (CK) and clock enable (CE) signals, each slice has set and reset signals (SR and BY slice inputs). SR forces the storage element into the state specified by the attribute SRHIGH or SRLOW. SRHIGH forces a logic 1 when SR is asserted. SRLOW forces a logic 0. When SR is used, an optional second input (BY) forces the storage element into the opposite state via the REV pin. The reset condition is predominant over the set condition. (See Figure 25.)

The initial state after configuration or global initial state is defined by a separate INIT0 and INIT1 attribute. By default, setting the SRLOW attribute sets INIT0, and setting the SRHIGH attribute sets INIT1.

For each slice, set and reset can be set to be synchronous or asynchronous. Virtex-II Pro devices also have the ability to set INIT0 and INIT1 independent of SRHIGH and SRLOW.

The control signals clock (CLK), clock enable (CE) and set/reset (SR) are common to both storage elements in one slice. All of the control signals have independent polarity. Any inverter placed on a control input is automatically absorbed.

The set and reset functionality of a register or a latch can be configured as follows:
- No set or reset
- Synchronous set
- Synchronous reset
- Synchronous set and reset
- Asynchronous set (preset)
- Asynchronous reset (clear)
- Asynchronous set and reset (preset and clear)

The synchronous reset has precedence over a set, and an asynchronous clear has precedence over a preset.

Distributed SelectRAM+ Memory

Each function generator (LUT) can implement a 16 x 1-bit synchronous RAM resource called a distributed SelectRAM+ element. SelectRAM+ elements are configurable within a CLB to implement the following:
- Single-Port 16 x 8-bit RAM
- Single-Port 32 x 4-bit RAM
- Single-Port 64 x 2-bit RAM
- Single-Port 128 x 1-bit RAM
- Dual-Port 16 x 4-bit RAM
- Dual-Port 32 x 2-bit RAM
- Dual-Port 64 x 1-bit RAM

Distributed SelectRAM+ memory modules are synchronous (write) resources. The combinatorial read access time is extremely fast, while the synchronous write simplifies high-speed designs. A synchronous read can be implemented with a storage element in the same slice. The distributed SelectRAM+ memory and the storage element share the same clock input. A Write Enable (WE) input is active High, and is driven by the SR input.

Table 12 shows the number of LUTs (2 per slice) occupied by each distributed SelectRAM+ configuration.

<table>
<thead>
<tr>
<th>RAM</th>
<th>Number of LUTs</th>
</tr>
</thead>
<tbody>
<tr>
<td>16 x 1S</td>
<td>1</td>
</tr>
<tr>
<td>16 x 1D</td>
<td>2</td>
</tr>
<tr>
<td>32 x 1S</td>
<td>2</td>
</tr>
<tr>
<td>32 x 1D</td>
<td>4</td>
</tr>
<tr>
<td>64 x 1S</td>
<td>4</td>
</tr>
<tr>
<td>64 x 1D</td>
<td>8</td>
</tr>
<tr>
<td>128 x 1S</td>
<td>8</td>
</tr>
</tbody>
</table>

Notes:
1. S = single-port configuration; D = dual-port configuration
For single-port configurations, distributed SelectRAM+ memory has one address port for synchronous writes and asynchronous reads.

For dual-port configurations, distributed SelectRAM+ memory has one port for synchronous writes and asynchronous reads and another port for asynchronous reads. The function generator (LUT) has separated read address inputs (A1, A2, A3, A4) and write address inputs (WG1/WF1, WG2/WF2, WG3/WF3, WG4/WF4).

In single-port mode, read and write addresses share the same address bus. In dual-port mode, one function generator (R/W port) is connected with shared read and write addresses. The second function generator has the A inputs (read) connected to the second read-only port address and the W inputs (write) shared with the first read/write port address.

Figure 26, Figure 27, and Figure 28 illustrate various example configurations.

**Table 13: ROM Configuration**

<table>
<thead>
<tr>
<th>ROM</th>
<th>Number of LUTs</th>
</tr>
</thead>
<tbody>
<tr>
<td>16 x 1</td>
<td>1</td>
</tr>
<tr>
<td>32 x 1</td>
<td>2</td>
</tr>
<tr>
<td>64 x 1</td>
<td>4</td>
</tr>
<tr>
<td>128 x 1</td>
<td>8 (1 CLB)</td>
</tr>
<tr>
<td>256 x 1</td>
<td>16 (2 CLBs)</td>
</tr>
</tbody>
</table>
Shift Registers

Each function generator can also be configured as a 16-bit shift register. The write operation is synchronous with a clock input (CLK) and an optional clock enable, as shown in Figure 29. A dynamic read access is performed through the 4-bit address bus, A[3:0]. The configurable 16-bit shift register cannot be set or reset. The read is asynchronous; however, the storage element or flip-flop is available to implement a synchronous read. Any of the 16 bits can be read out asynchronously by varying the address. The storage element should always be used with a constant address. For example, when building an 8-bit shift register and configuring the addresses to point to the 7th bit, the 8th bit can be the flip-flop. The overall system performance is improved by using the superior clock-to-out of the flip-flops.

An additional dedicated connection between shift registers allows connecting the last bit of one shift register to the first bit of the next, without using the ordinary LUT output. (See Figure 30.) Longer shift registers can be built with dynamic access to any bit in the chain. The shift register chaining and the MUXF5, MUXF6, and MUXF7 multiplexers allow up to a 128-bit shift register with addressable access to be implemented in one CLB.

Figure 29: Shift Register Configurations

Figure 30: Cascadable Shift Register
Multiplexers

Virtex-II Pro function generators and associated multiplexers can implement the following:

- 4:1 multiplexer in one slice
- 8:1 multiplexer in two slices
- 16:1 multiplexer in one CLB element (4 slices)
- 32:1 multiplexer in two CLB elements (8 slices)

Each Virtex-II Pro slice has one MUXF5 multiplexer and one MUXFX multiplexer. The MUXFX multiplexer implements the MUXF6, MUXF7, or MUXF8, as shown in Figure 31. Each CLB element has two MUXF6 multiplexers, one MUXF7 multiplexer and one MUXF8 multiplexer. Examples of multiplexers are shown in the Virtex-II Pro User Guide. Any LUT can implement a 2:1 multiplexer.

Fast Lookahead Carry Logic

Dedicated carry logic provides fast arithmetic addition and subtraction. The Virtex-II Pro CLB has two separate carry chains, as shown in the Figure 32.

The height of the carry chains is two bits per slice. The carry chain in the Virtex-II Pro device is running upward. The dedicated carry path and carry multiplexer (MUXCY) can also be used to cascade function generators for implementing wide logic functions.
Arithmetic Logic

The arithmetic logic includes an XOR gate that allows a 2-bit full adder to be implemented within a slice. In addition, a dedicated AND (MULT_AND) gate (shown in Figure 24) improves the efficiency of multiplier implementation.
Sum of Products

Each Virtex-II Pro slice has a dedicated OR gate named ORCY, ORing together outputs from the slices carryout and the ORCY from an adjacent slice. The ORCY gate with the dedicated Sum of Products (SOP) chain are designed for implementing large, flexible SOP chains. One input of each ORCY is connected through the fast SOP chain to the output of the previous ORCY in the same slice row. The second input is connected to the output of the top MUXCY in the same slice, as shown in Figure 33.

Figure 33: Horizontal Cascade Chain

LUTs and MUXCYs can implement large AND gates or other combinatorial logic functions. Figure 34 illustrates LUT and MUXCY resources configured as a 16-input AND gate.

Figure 34: Wide-Input AND Gate (16 Inputs)
3-State Buffers

Introduction

Each Virtex-II Pro CLB contains two 3-state drivers (TBUFS) that can drive on-chip buses. Each 3-state buffer has its own 3-state control pin and its own input pin.

Each of the four slices have access to the two 3-state buffers through the switch matrix, as shown in Figure 35. TBUFS in neighboring CLBs can access slice outputs by direct connects. The outputs of the 3-state buffers drive horizontal routing resources used to implement 3-state buses.

The 3-state buffer logic is implemented using AND-OR logic rather than 3-state drivers, so that timing is more predictable and less load dependant especially with larger devices.

Locations / Organization

Four horizontal routing resources per CLB are provided for on-chip 3-state buses. Each 3-state buffer has access alternately to two horizontal lines, which can be partitioned as shown in Figure 36. The switch matrices corresponding to SelectRAM+ memory and multiplier or I/O blocks are skipped.

Number of 3-State Buffers

Table 14 shows the number of 3-state buffers available in each Virtex-II Pro device. The number of 3-state buffers is twice the number of CLB elements.

Table 14: Virtex-II Pro 3-State Buffers

<table>
<thead>
<tr>
<th>Device</th>
<th>3-State Buffers per Row</th>
<th>Total Number of 3-State Buffers</th>
</tr>
</thead>
<tbody>
<tr>
<td>XC2VP2</td>
<td>44</td>
<td>704</td>
</tr>
<tr>
<td>XC2VP4</td>
<td>44</td>
<td>1,760</td>
</tr>
<tr>
<td>XC2VP7</td>
<td>68</td>
<td>2,720</td>
</tr>
<tr>
<td>XC2VP20</td>
<td>92</td>
<td>5,152</td>
</tr>
<tr>
<td>XC2VP30</td>
<td>92</td>
<td>6,848</td>
</tr>
<tr>
<td>XC2VP40</td>
<td>116</td>
<td>9,696</td>
</tr>
<tr>
<td>XC2VP50</td>
<td>140</td>
<td>11,808</td>
</tr>
<tr>
<td>XC2VP70</td>
<td>164</td>
<td>16,544</td>
</tr>
<tr>
<td>XC2VP100</td>
<td>188</td>
<td>22,048</td>
</tr>
<tr>
<td>XC2VP125</td>
<td>212</td>
<td>27,808</td>
</tr>
</tbody>
</table>

Figure 36: 3-State Buffer Connection to Horizontal Lines

CLB/Slice Configurations

Table 15 summarizes the logic resources in one CLB. All of the CLBs are identical and each CLB or slice can be implemented in one of the configurations listed. Table 16 shows the available resources in all CLBs.

Table 15: Logic Resources in One CLB

<table>
<thead>
<tr>
<th>Slices</th>
<th>LUTs</th>
<th>Flip-Flops</th>
<th>MULT_ANDs</th>
<th>Arithmetic &amp; Carry-Chains</th>
<th>SOP Chains</th>
<th>Distributed SelectRAM+</th>
<th>Shift Registers</th>
<th>TBUF</th>
</tr>
</thead>
</table>
**18 Kb Block SelectRAM+ Resources**

**Introduction**

Virtex-II Pro devices incorporate large amounts of 18 Kb block SelectRAM+ resources. These complement the distributed SelectRAM+ resources that provide shallow RAM structures implemented in CLBs. Each Virtex-II Pro block SelectRAM+ resource is an 18 Kb true dual-port RAM with two independently clocked and independently controlled synchronous ports that access a common storage area. Both ports are functionally identical. CLK, EN, WE, and SSR polarities are defined through configuration.

Each port has the following types of inputs: Clock and Clock Enable, Write Enable, Set/Reset, and Address, as well as separate Data/parity data inputs (for write) and Data/parity data outputs (for read).

Operation is synchronous; the block SelectRAM+ behaves like a register. Control, address and data inputs must (and need only) be valid during the set-up time window prior to a rising (or falling, a configuration option) clock edge. Data outputs change as a result of the same clock edge.

**Configuration**

Virtex-II Pro block SelectRAM+ supports various configurations, including single- and dual-port RAM and various data/address aspect ratios. Supported memory configurations for single- and dual-port modes are shown in Table 17.

**Table 17: Dual- and Single-Port Configurations**

<table>
<thead>
<tr>
<th></th>
<th>16K x 1 bit</th>
<th>2K x 9 bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>8K x 2 bits</td>
<td>1K x 18 bits</td>
<td></td>
</tr>
<tr>
<td>4K x 4 bits</td>
<td>512 x 36 bits</td>
<td></td>
</tr>
</tbody>
</table>

**Single-Port Configuration**

As a single-port RAM, the block SelectRAM+ has access to the 18 Kb memory locations in any of the 2K x 9-bit, 1K x 18-bit, or 512 x 36-bit configurations and to 16 Kb memory locations in any of the 16K x 1-bit, 8K x 2-bit, or 4K x 4-bit configurations. The advantage of the 9-bit, 18-bit and 36-bit widths is the ability to store a parity bit for each eight bits. Parity bits must be generated or checked externally in user logic. In such cases, the width is viewed as 8 + 1, 16 + 2, or 32 + 4. These extra parity bits are stored and behave exactly as the other bits, including the timing parameters. Video applications can use the 9-bit ratio of Virtex-II Pro block SelectRAM+ memory to advantage.

Each block SelectRAM+ cell is a fully synchronous memory as illustrated in Figure 37. Input data bus and output data bus widths are identical.
Dual-Port Configuration

As a dual-port RAM, each port of block SelectRAM+ has access to a common 18 Kb memory resource. These are fully synchronous ports with independent control signals for each port. The data widths of the two ports can be configured independently, providing built-in bus-width conversion.

Table 18 illustrates the different configurations available on ports A and B.

If both ports are configured in either 2K x 9-bit, 1K x 18-bit, or 512 x 36-bit configurations, the 18 Kb block is accessible from port A or B. If both ports are configured in either 16K x 1-bit, 8K x 2-bit, or 4K x 4-bit configurations, the 16 K-bit block is accessible from Port A or Port B. All other configurations result in one port having access to an 18 Kb memory block and the other port having access to a 16 K-bit subset of the memory block equal to 16 Kbs.

Table 18: Dual-Port Mode Configurations

<table>
<thead>
<tr>
<th>Port</th>
<th>16K x 1</th>
<th>16K x 1</th>
<th>16K x 1</th>
<th>16K x 1</th>
<th>16K x 1</th>
<th>16K x 1</th>
</tr>
</thead>
<tbody>
<tr>
<td>Port A</td>
<td>16K x 1</td>
<td>8K x 2</td>
<td>4K x 4</td>
<td>2K x 9</td>
<td>1K x 18</td>
<td>512 x 36</td>
</tr>
<tr>
<td>Port B</td>
<td>8K x 2</td>
<td>4K x 4</td>
<td>2K x 9</td>
<td>1K x 18</td>
<td>512 x 36</td>
<td></td>
</tr>
<tr>
<td>Port A</td>
<td>4K x 4</td>
<td>4K x 4</td>
<td>4K x 4</td>
<td>4K x 4</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Port B</td>
<td>4K x 4</td>
<td>2K x 9</td>
<td>1K x 18</td>
<td>512 x 36</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Port A</td>
<td>2K x 9</td>
<td>2K x 9</td>
<td>2K x 9</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Port B</td>
<td>2K x 9</td>
<td>1K x 18</td>
<td>512 x 36</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Port A</td>
<td>1K x 18</td>
<td>1K x 18</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Port B</td>
<td>1K x 18</td>
<td>512 x 36</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Port A</td>
<td>512 x 36</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Port B</td>
<td>512 x 36</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
Each block SelectRAM+ cell is a fully synchronous memory, as illustrated in Figure 38. The two ports have independent inputs and outputs and are independently clocked.

**Figure 38: 18 Kb Block SelectRAM+ in Dual-Port Mode**

### Port Aspect Ratios

Table 19 shows the depth and the width aspect ratios for the 18 Kb block SelectRAM+ resource. Virtex-II Pro block SelectRAM+ also includes dedicated routing resources to provide an efficient interface with CLBs, block SelectRAM+, and multipliers.

**Table 19: 18 Kb Block SelectRAM+ Port Aspect Ratio**

<table>
<thead>
<tr>
<th>Width</th>
<th>Depth</th>
<th>Address Bus</th>
<th>Data Bus</th>
<th>Parity Bus</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>16,384</td>
<td>ADDR[13:0]</td>
<td>DATA[0]</td>
<td>N/A</td>
</tr>
<tr>
<td>2</td>
<td>8,192</td>
<td>ADDR[12:0]</td>
<td>DATA[1:0]</td>
<td>N/A</td>
</tr>
<tr>
<td>4</td>
<td>4,096</td>
<td>ADDR[11:0]</td>
<td>DATA[3:0]</td>
<td>N/A</td>
</tr>
<tr>
<td>9</td>
<td>2,048</td>
<td>ADDR[10:0]</td>
<td>DATA[7:0]</td>
<td>Parity[0]</td>
</tr>
<tr>
<td>18</td>
<td>1,024</td>
<td>ADDR[9:0]</td>
<td>DATA[15:0]</td>
<td>Parity[1:0]</td>
</tr>
<tr>
<td>36</td>
<td>512</td>
<td>ADDR[8:0]</td>
<td>DATA[31:0]</td>
<td>Parity[3:0]</td>
</tr>
</tbody>
</table>

### Read/Write Operations

The Virtex-II Pro block SelectRAM+ read operation is fully synchronous. An address is presented, and the read operation is enabled by control signal ENA or ENB. Then, depending on clock polarity, a rising or falling clock edge causes the stored data to be loaded into output registers.

The write operation is also fully synchronous. Data and address are presented, and the write operation is enabled by control signals WEA and WEB in addition to ENA or ENB. Then, again depending on the clock input mode, a rising or falling clock edge causes the data to be loaded into the memory cell addressed.

A write operation performs a simultaneous read operation. Three different options are available, selected by configuration:

1. **WRITE_FIRST**

   The WRITE_FIRST option is a transparent mode. The same clock edge that writes the data input (DI) into the memory also transfers DI into the output registers DO, as shown in Figure 39.

   **Figure 39: WRITE_FIRST Mode**

2. **READ_FIRST**

   The READ_FIRST option is a read-before-write mode. The same clock edge that writes data input (DI) into the memory also transfers the prior content of the memory cell addressed into the data output registers DO, as shown in Figure 40.

   **Figure 40: READ_FIRST Mode**
3. NO_CHANGE

The NO_CHANGE option maintains the content of the output registers, regardless of the write operation. The clock edge during the write mode has no effect on the content of the data output register DO. When the port is configured as NO_CHANGE, only a read operation loads a new value in the output register DO, as shown in Figure 41.

![Control Signal Function](image)

**Figure 41: NO_CHANGE Mode**

### Control Pins and Attributes

Virtex-II Pro SelectRAM+ memory has two independent ports with the control signals described in Table 20. All control inputs including the clock have an optional inversion.

<table>
<thead>
<tr>
<th>Control Signal</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLK</td>
<td>Read and Write Clock</td>
</tr>
<tr>
<td>EN</td>
<td>Enable affects Read, Write, Set, Reset</td>
</tr>
<tr>
<td>WE</td>
<td>Write Enable</td>
</tr>
<tr>
<td>SSR</td>
<td>Set DO register to SRVAL (attribute)</td>
</tr>
</tbody>
</table>

Initial memory content is determined by the INIT_xx attributes. Separate attributes determine the output register value after device configuration (INIT) and SSR is asserted (SRVAL). Both attributes (INIT_B and SRVAL) are available for each port when a block SelectRAM+ resource is configured as dual-port RAM.

### Total Amount of SelectRAM+ Memory

Virtex-II Pro SelectRAM+ memory blocks are organized in multiple columns. The number of blocks per column depends on the row size, the number of Processor Blocks, and the number of RocketIO transceivers.

Table 21 shows the number of columns as well as the total amount of block SelectRAM+ memory available for each Virtex-II Pro device. The 18 Kb SelectRAM+ blocks are cascadable to implement deeper or wider single- or dual-port memory resources.

<table>
<thead>
<tr>
<th>Device</th>
<th>Columns</th>
<th>Total SelectRAM+ Memory</th>
</tr>
</thead>
<tbody>
<tr>
<td>XC2VP2</td>
<td>4</td>
<td>216 221,184</td>
</tr>
<tr>
<td>XC2VP4</td>
<td>4</td>
<td>504 516,096</td>
</tr>
<tr>
<td>XC2VP7</td>
<td>6</td>
<td>792 811,008</td>
</tr>
<tr>
<td>XC2VP20</td>
<td>8</td>
<td>1,584 1,622,016</td>
</tr>
<tr>
<td>XC2VP30</td>
<td>8</td>
<td>2,448 2,506,752</td>
</tr>
<tr>
<td>XC2VP40</td>
<td>10</td>
<td>3,456 3,538,944</td>
</tr>
<tr>
<td>XC2VP50</td>
<td>12</td>
<td>4,176 4,276,224</td>
</tr>
<tr>
<td>XC2VP70</td>
<td>14</td>
<td>5,904 6,045,696</td>
</tr>
<tr>
<td>XC2VP100</td>
<td>16</td>
<td>7,992 8,183,808</td>
</tr>
<tr>
<td>XC2VP125</td>
<td>18</td>
<td>10,008 10,248,192</td>
</tr>
</tbody>
</table>

### 18-Bit x 18-Bit Multipliers

**Introduction**

A Virtex-II Pro multiplier block is an 18-bit by 18-bit 2's complement signed multiplier. Virtex-II Pro devices incorporate many embedded multiplier blocks. These multipliers can be associated with an 18 Kb block SelectRAM+ resource or can be used independently. They are optimized for high-speed operations and have a lower power consumption compared to an 18-bit x 18-bit multiplier in slices.
Each SelectRAM+ memory and multiplier block is tied to four switch matrices, as shown in Figure 43.

![Figure 43: SelectRAM+ and Multiplier Blocks](ds031_33_101000)

**Association With Block SelectRAM+ Memory**

The interconnect is designed to allow SelectRAM+ memory and multiplier blocks to be used at the same time, but some interconnect is shared between the SelectRAM+ and the multiplier. Thus, SelectRAM+ memory can be used only up to 18 bits wide when the multiplier is used, because the multiplier shares inputs with the upper data bits of the SelectRAM+ memory.

This sharing of the interconnect is optimized for an 18-bit-wide block SelectRAM+ resource feeding the multiplier. The use of SelectRAM+ memory and the multiplier with an accumulator in LUTs allows for implementation of a digital signal processor (DSP) multiplier-accumulator (MAC) function, which is commonly used in finite and infinite impulse response (FIR and IIR) digital filters.

**Configuration**

The multiplier block is an 18-bit by 18-bit signed multiplier (2’s complement). Both A and B are 18-bit-wide inputs, and the output is 36 bits. Figure 44 shows a multiplier block.

![Figure 44: Multiplier Block](ds031_40_100400)

**Locations / Organization**

Multiplier organization is identical to the 18 Kb SelectRAM+ organization, because each multiplier is associated with an 18 Kb block SelectRAM+ resource.

**Table 22: Multiplier Resources**

<table>
<thead>
<tr>
<th>Device</th>
<th>Columns</th>
<th>Total Multipliers</th>
</tr>
</thead>
<tbody>
<tr>
<td>XC2VP2</td>
<td>4</td>
<td>12</td>
</tr>
<tr>
<td>XC2VP4</td>
<td>4</td>
<td>28</td>
</tr>
<tr>
<td>XC2VP7</td>
<td>6</td>
<td>44</td>
</tr>
<tr>
<td>XC2VP20</td>
<td>8</td>
<td>88</td>
</tr>
<tr>
<td>XC2VP30</td>
<td>8</td>
<td>136</td>
</tr>
<tr>
<td>XC2VP40</td>
<td>10</td>
<td>192</td>
</tr>
<tr>
<td>XC2VP50</td>
<td>12</td>
<td>232</td>
</tr>
<tr>
<td>XC2VP70</td>
<td>14</td>
<td>328</td>
</tr>
<tr>
<td>XC2VP100</td>
<td>16</td>
<td>444</td>
</tr>
<tr>
<td>XC2VP125</td>
<td>18</td>
<td>556</td>
</tr>
</tbody>
</table>

In addition to the built-in multiplier blocks, the CLB elements have dedicated logic to implement efficient multipliers in logic. (Refer to Configurable Logic Blocks (CLBs), page 49).

**Global Clock Multiplexer Buffers**

Virtex-II Pro devices have 16 clock input pins that can also be used as regular user I/Os. Eight clock pads center on both the top edge and the bottom edge of the device, as illustrated in Figure 45.

The global clock multiplexer buffer represents the input to dedicated low-skew clock tree distribution in Virtex-II Pro devices. Like the clock pads, eight global clock multiplexer buffers are on the top edge of the device and eight are on the bottom edge.

![Figure 45: Virtex-II Pro Clock Pads](ds083-2_42_052902)
Each global clock multiplexer buffer can be driven either by the clock pad to distribute a clock directly to the device, or by the Digital Clock Manager (DCM), discussed in Digital Clock Manager (DCM), page 65. Each global clock multiplexer buffer can also be driven by local interconnects. The DCM has clock output(s) that can be connected to global clock multiplexer buffer inputs, as shown in Figure 46.

**Figure 46: Virtex-II Pro Clock Multiplexer Buffer Configuration**

Global clock buffers are used to distribute the clock to some or all synchronous logic elements (such as registers in CLBs and IOBs, and SelectRAM+ blocks.

Eight global clocks can be used in each quadrant of the Virtex-II Pro device. Designers should consider the clock distribution detail of the device prior to pin-locking and floor-planning. (See the Virtex-II Pro User Guide.)

**Figure 47 shows clock distribution in Virtex-II Pro devices.**

In each quadrant, up to eight clocks are organized in clock rows. A clock row supports up to 16 CLB rows (eight up and eight down).

To reduce power consumption, any unused clock branches remain static.

**Figure 47: Virtex-II Pro Clock Distribution**
Global clocks are driven by dedicated clock buffers (BUFG), which can also be used to gate the clock (BUFGCE) or to multiplex between two independent clock inputs (BUFGMUX).

The most common configuration option of this element is as a buffer. A BUFG function in this (global buffer) mode, is shown in Figure 48.

![Figure 48: Virtex-II Pro BUFG Function](image)

The Virtex-II Pro global clock buffer BUFG can also be configured as a clock enable/disable circuit (Figure 49), as well as a two-input clock multiplexer (Figure 50). A functional description of these two options is provided below. Each of them can be used in either of two modes, selected by configuration: rising clock edge or falling clock edge.

This section describes the rising clock edge option. For the opposite option, falling clock edge, just change all “rising” references to “falling” and all “High” references to “Low”, except for the description of the CE and S levels. The rising clock edge option uses the BUFGCE and BUFGMUX primitives. The falling clock edge option uses the BUFGCE_1 and BUFGMUX_1 primitives.

**BUFGCE**

If the CE input is active (High) prior to the incoming rising clock edge, this Low-to-High-to-Low clock pulse passes through the clock buffer. Any level change of CE during the incoming clock High time has no effect.

![Figure 49: Virtex-II Pro BUFGCE Function](image)

If the CE input is inactive (Low) prior to the incoming rising clock edge, the following clock pulse does not pass through the clock buffer, and the output stays Low. Any level change of CE during the incoming clock High time has no effect.

**BUFGMUX**

BUFGMUX can switch between two unrelated, even asynchronous clocks. Basically, a Low on S selects the I0 input, a High on S selects the I1 input. Switching from one clock to the other is done in such a way that the output High and Low time is never shorter than the shortest High or Low time of either input clock. As long as the presently selected clock is High, any level change of S has no effect.

![Figure 50: Virtex-II Pro BUFGMUX Function](image)

If the presently selected clock is Low while S changes, or if it goes Low after S has changed, the output is kept Low until the other (“to-be-selected”) clock has made a transition from High to Low. At that instant, the new clock starts driving the output.

The two clock inputs can be asynchronous with regard to each other, and the S input can change at any time, except for a short setup time prior to the rising edge of the presently selected clock; that is, prior to the rising edge of the BUFGMUX output O. Violating this setup time requirement can result in an undefined runt pulse output.

All Virtex-II Pro devices have 16 global clock multiplexer buffers.

Figure 51 shows a switchover from CLK0 to CLK1.

![Figure 51: Clock Multiplexer Waveform Diagram](image)

- The current clock is CLK0.
- S is activated High.
- If CLK0 is currently High, the multiplexer waits for CLK0 to go Low.
- Once CLK0 is Low, the multiplexer output stays Low until CLK1 transitions High to Low.
- When CLK1 transitions from High to Low, the output switches to CLK1.
- No glitches or short pulses can appear on the output.
Digital Clock Manager (DCM)

The Virtex-II Pro DCM offers a wide range of powerful clock management features.

- **Clock De-skew**: The DCM generates new system clocks (either internally or externally to the FPGA), which are phase-aligned to the input clock, thus eliminating clock distribution delays.

- **Frequency Synthesis**: The DCM generates a wide range of output clock frequencies, performing very flexible clock multiplication and division.

- **Phase Shifting**: The DCM provides both coarse phase shifting and fine-grained phase shifting with dynamic phase shift control.

The DCM utilizes fully digital delay lines allowing robust high-precision control of clock phase and frequency. It also utilizes fully digital feedback systems, operating dynamically to compensate for temperature and voltage variations during operation.

Up to four of the nine DCM clock outputs can drive inputs to global clock buffers or global clock multiplexer buffers simultaneously (see Figure 52). All DCM clock outputs can simultaneously drive general routing resources, including routes to output buffers.

To achieve clock de-skew, the CLKFB input must be connected, and its source must be either CLK0 or CLK2X. Note that CLKFB must always be connected, unless only the CLKFX or CLKFX180 outputs are used and de-skew is not required.

**Clock De-skew**

The DCM de-skews the output clocks relative to the input clock by automatically adjusting a digital delay line. Additional delay is introduced so that clock edges arrive at internal registers and block RAMs simultaneously with the clock edges arriving at the input clock pad. Alternatively, external clocks, which are also de-skewed relative to the input clock, can be generated for board-level routing. All DCM output clocks are phase-aligned to CLK0 and, therefore, are also phase-aligned to the input clock.

The DCM has the following general control signals:

- **RST input pin**: resets the entire DCM
- **LOCKED output pin**: asserted High when all enabled DCM circuits have locked.
- **STATUS output pins (active High)**: shown in Table 23.

**Frequency Synthesis**

The DCM provides flexible methods for generating new clock frequencies. Each method has a different operating frequency range and different AC characteristics. The CLK2X and CLK2X180 outputs double the clock frequency. The CLKDV output creates divided output clocks with division options of 1.5, 2, 2.5, 3, 3.5, 4, 4.5, 5, 5.5, 6, 6.5, 7, 7.5, 8, 9, 10, 11, 12, 13, 14, 15, and 16.

The CLKFX and CLKFX180 outputs can be used to produce clocks at the following frequency:

\[
FREQ_{CLKFX} = (M/D) \cdot FREQ_{CLKIN}
\]

where \( M \) and \( D \) are two integers. Specifications for \( M \) and \( D \) are provided under DCM Timing Parameters. By default, \( M = 4 \) and \( D = 1 \), which results in a clock output frequency four times faster than the clock input frequency (CLKIN).

CLK2X180 is phase shifted 180 degrees relative to CLK2X. CLKFX180 is phase shifted 180 degrees relative to CLKFX. All frequency synthesis outputs automatically have 50/50 duty cycles, with the exception of the CLKDV output when performing a non-integer divide in high-frequency mode. See Table 24 for more details.
Note that CLK2X and CLK2X180 are not available in high-frequency mode.

**Phase Shifting**

The DCM provides additional control over clock skew through either coarse or fine-grained phase shifting. The CLK0, CLK90, CLK180, and CLK270 outputs are each phase shifted by $\frac{1}{4}$ of the input clock period relative to each other, providing coarse phase control. Note that CLK90 and CLK270 are not available in high-frequency mode.

Fine-phase adjustment affects all nine DCM output clocks. When activated, the phase shift between the rising edges of CLKIN and CLKFB is a specified fraction of the input clock period.

In variable mode, the PHASE_SHIFT value can also be dynamically incremented or decremented as determined by PSINCDEC synchronously to PSCLK, when the PSEN input is active. Figure 53 illustrates the effects of fine-phase shifting. For more information on DCM features, see the Virtex-II Pro User Guide.

Table 24 lists fine-phase shifting control pins, when used in variable mode.

**Table 24: CLKDV Duty Cycle for Non-integer Divides**

<table>
<thead>
<tr>
<th>CLKDV_DIVIDE</th>
<th>Duty Cycle</th>
</tr>
</thead>
<tbody>
<tr>
<td>1.5</td>
<td>1/3</td>
</tr>
<tr>
<td>2.5</td>
<td>2/5</td>
</tr>
<tr>
<td>3.5</td>
<td>3/7</td>
</tr>
<tr>
<td>4.5</td>
<td>4/9</td>
</tr>
<tr>
<td>5.5</td>
<td>5/11</td>
</tr>
<tr>
<td>6.5</td>
<td>6/13</td>
</tr>
<tr>
<td>7.5</td>
<td>7/15</td>
</tr>
</tbody>
</table>

**Table 25: Fine Phase Shifting Control Pins**

<table>
<thead>
<tr>
<th>Control Pin</th>
<th>Direction</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>PSINCDEC</td>
<td>In</td>
<td>Increment or decrement</td>
</tr>
<tr>
<td>PSEN</td>
<td>In</td>
<td>Enable ± phase shift</td>
</tr>
<tr>
<td>PSCLK</td>
<td>In</td>
<td>Clock for phase shift</td>
</tr>
<tr>
<td>PSDONE</td>
<td>Out</td>
<td>Active when completed</td>
</tr>
</tbody>
</table>

Two separate components of the phase shift range must be understood:

- PHASE_SHIFT attribute range
- FINE_SHIFT_RANGE DCM timing parameter range

The PHASE_SHIFT attribute is the numerator in the following equation:

\[
\text{Phase Shift (ns)} = \frac{\text{PHASE_SHIFT}}{256} \times \text{PERIOD}_{\text{CLKIN}}
\]

The full range of this attribute is always -255 to +255, but its practical range varies with CLKIN frequency, as constrained by the FINE_SHIFT_RANGE component, which represents the total delay achievable by the phase shift delay line. Total delay is a function of the number of delay taps used in the circuit. Across process, voltage, and temperature, this absolute range is guaranteed to be as specified under **DCM Timing Parameters**.

Absolute range (fixed mode) = ± FINE_SHIFT_RANGE

Absolute range (variable mode) = ± $\frac{\text{FINE_SHIFT_RANGE}}{2}$

The reason for the difference between fixed and variable modes is as follows. For variable mode to allow symmetric, dynamic sweeps from -255/256 to +255/256, the DCM sets the “zero phase skew” point as the middle of the delay line, thus dividing the total delay line range in half. In fixed mode, since the PHASE_SHIFT value never changes after configu-
ration, the entire delay line is available for insertion into either the CLKin or CLKFb path (to create either positive or negative skew).

Taking both of these components into consideration, the following are some usage examples:

- If PERIOD\textsubscript{CLKin} = 2 \times FINE\_SHIFT\_RANGE, then PHASE\_SHIFT in fixed mode is limited to ±128, and in variable mode it is limited to ±64.
- If PERIOD\textsubscript{CLKin} = FINE\_SHIFT\_RANGE, then PHASE\_SHIFT in fixed mode is limited to ±255, and in variable mode it is limited to ±128.

Table 26: DCM Frequency Ranges

<table>
<thead>
<tr>
<th>Output Clock</th>
<th>Low-Frequency Mode</th>
<th>High-Frequency Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>CLKin Input</td>
<td>CLOut _Freq_1X_LF</td>
</tr>
<tr>
<td>CLK0, CLK180</td>
<td>CLKin_Freq_DLL_LF</td>
<td>CLOut_Freq_1X_LF</td>
</tr>
<tr>
<td>CLK90, CLK270</td>
<td>CLKin_Freq_DLL_LF</td>
<td>CLOut_Freq_1X_LF</td>
</tr>
<tr>
<td>CLK2X, CLK2X180</td>
<td>CLKin_Freq_DLL_LF</td>
<td>CLOut_Freq_2X_LF</td>
</tr>
<tr>
<td>CLKDV</td>
<td>CLKin_Freq_DLL_LF</td>
<td>CLOut_Freq_DV_LF</td>
</tr>
<tr>
<td>CLKFX, CLKFX180</td>
<td>CLKin_Freq_FX_LF</td>
<td>CLOut_Freq_FX_LF</td>
</tr>
</tbody>
</table>

CLK90, and CLK270 outputs are not available in high-frequency mode.

High or low-frequency mode is selected by an attribute.

Routing

DCM and MGT Locations/Organization

Virtex-II Pro DCMs and serial transceivers (MGTs) are placed on the top and bottom of each block RAM and multiplier column in some combination, as shown in Table 27. The number of DCMs and RocketIO transceivers total twice the number of block RAM columns in the device. Refer to Figure 42, page 61 for an illustration of this in the XC2VP4 device.

Place-and-route software takes advantage of this regular array to deliver optimum system performance and fast compile times. The segmented routing resources are essential to guarantee IP cores portability and to efficiently handle an incremental design flow that is based on modular implementations. Total design time is reduced due to fewer and shorter design iterations.

Hierarchical Routing Resources

Most Virtex-II Pro signals are routed using the global routing resources, which are located in horizontal and vertical routing channels between each switch matrix.

As shown in Figure 54, page 68, Virtex-II Pro has fully buffered programmable interconnections, with a number of resources counted between any two adjacent switch matrix rows or columns. Fanout has minimal impact on the performance of each net.

Table 27: DCM Organization

<table>
<thead>
<tr>
<th>Device</th>
<th>Block RAM Columns</th>
<th>DCMs</th>
<th>MGTs</th>
</tr>
</thead>
<tbody>
<tr>
<td>XC2VP2</td>
<td>4</td>
<td>4</td>
<td>4</td>
</tr>
<tr>
<td>XC2VP4</td>
<td>6</td>
<td>4</td>
<td>4</td>
</tr>
<tr>
<td>XC2VP7</td>
<td>6</td>
<td>4</td>
<td>8</td>
</tr>
<tr>
<td>XC2VP20</td>
<td>6</td>
<td>8</td>
<td>8</td>
</tr>
<tr>
<td>XC2VP30</td>
<td>8</td>
<td>8</td>
<td>8</td>
</tr>
<tr>
<td>XC2VP40</td>
<td>10</td>
<td>8</td>
<td>12</td>
</tr>
<tr>
<td>XC2VP50</td>
<td>12</td>
<td>8</td>
<td>16</td>
</tr>
<tr>
<td>XC2VP70</td>
<td>14</td>
<td>8</td>
<td>20</td>
</tr>
<tr>
<td>XC2VP100</td>
<td>16</td>
<td>12</td>
<td>20</td>
</tr>
<tr>
<td>XC2VP125</td>
<td>18</td>
<td>12</td>
<td>24</td>
</tr>
</tbody>
</table>

• The long lines are bidirectional wires that distribute signals across the device. Vertical and horizontal long lines span the full height and width of the device.
• The hex lines route signals to every third or sixth block away in all four directions. Organized in a staggered pattern, hex lines can only be driven from one end. Hex-line signals can be accessed either at the endpoints or at the midpoint (three blocks from the source).
The double lines route signals to every first or second block away in all four directions. Organized in a staggered pattern, double lines can be driven only at their endpoints. Double-line signals can be accessed either at the endpoints or at the midpoint (one block from the source).

The direct connect lines route signals to neighboring blocks: vertically, horizontally, and diagonally.

The fast connect lines are the internal CLB local interconnections from LUT outputs to LUT inputs.

**Dedicated Routing**

In addition to the global and local routing resources, dedicated signals are available.

- There are eight global clock nets per quadrant. (See Global Clock Multiplexer Buffers, page 62.)
- Horizontal routing resources are provided for on-chip 3-state buses. Four partitionable bus lines are provided per CLB row, permitting multiple buses within a row. (See 3-State Buffers, page 57.)
- Two dedicated carry-chain resources per slice column (two per CLB column) propagate carry-chain MUXCY output signals vertically to the adjacent slice. (See CLB/Slice Configurations, page 57.)
- One dedicated SOP chain per slice row (two per CLB row) propagate ORCY output logic signals horizontally to the adjacent slice. (See Sum of Products, page 56.)
- One dedicated shift-chain per CLB connects the output of LUTs in shift-register mode to the input of the next LUT in shift-register mode (vertically) inside the CLB. (See Shift Registers, page 53.)

<table>
<thead>
<tr>
<th>24 Horizontal Long Lines</th>
<th>120 Horizontal Hex Lines</th>
</tr>
</thead>
<tbody>
<tr>
<td>24 Vertical Long Lines</td>
<td>120 Vertical Hex Lines</td>
</tr>
<tr>
<td>40 Horizontal Double Lines</td>
<td>40 Vertical Double Lines</td>
</tr>
<tr>
<td>16 Direct Connections (total in all four directions)</td>
<td></td>
</tr>
<tr>
<td>8 Fast Connects</td>
<td></td>
</tr>
</tbody>
</table>

**Configuration**

Virtex-II Pro devices are configured by loading application specific configuration data into the internal configuration memory. Configuration is carried out using a subset of the device pins, some of which are dedicated, while others can be re-used as general purpose inputs and outputs once configuration is complete.

Depending on the system design, several configuration modes are supported, selectable via mode pins. The mode pins M2, M1 and M0 are dedicated pins. An additional pin, HSWAP_EN is used in conjunction with the mode pins to select whether user I/O pins have pull-ups during configuration. By default, HSWAP_EN is tied High (internal pull-up) which shuts off the pull-ups on the user I/O pins during configuration. When HSWAP_EN is tied Low, user I/Os have pull-ups during configuration. Other dedicated pins are CCLK (the configuration clock pin), DONE, PROG_B, and the boundary-scan pins: TDI, TDO, TMS, and TCK. Depending on the configuration mode chosen, CCLK can be an output generated by the FPGA, or an input accepting an externally generated clock. The configuration pins and
boundary scan pins are independent of the $V_{CCO}$. The auxiliary power supply ($V_{CCAux}$) of 2.5V is used for these pins. See Virtex-II Pro Switching Characteristics (Module 3).

A persist option is available which can be used to force the configuration pins to retain their configuration function even after device configuration is complete. If the persist option is not selected then the configuration pins with the exception of CCLK, PROG_B, and DONE can be used as user I/O in normal operation. The persist option does not apply to the boundary-scan related pins. The persist feature is valuable in applications which employ partial reconfiguration or reconfiguration on the fly.

Virtex-II Pro supports the following five configuration modes:

- Slave-Serial Mode
- Master-Serial Mode
- Slave SelectMAP Mode
- Master SelectMAP Mode
- Boundary-Scan (JTAG, IEEE 1532) Mode

Refer to Table 28, page 70.

A detailed description of configuration modes is provided in the Virtex-II Pro User Guide.

**Slave-Serial Mode**

In slave-serial mode, the FPGA receives configuration data in bit-serial form from a serial PROM or other serial source of configuration data. The CCLK pin on the FPGA is an input in this mode. The serial bitstream must be setup at the DIN input pin a short time before each rising edge of the externally generated CCLK.

Multiple FPGAs can be daisy-chained for configuration from a single source. After a particular FPGA has been configured, the data for the next device is routed internally to the DOUT pin. The data on the DOUT pin changes on the rising edge of CCLK.

Slave-serial mode is selected by applying [1 1 1] to the mode pins (M2, M1, M0). A weak pull-up on the mode pins makes slave serial the default mode if the pins are left unconnected.

**Master-Serial Mode**

In master-serial mode, the CCLK pin is an output pin. It is the Virtex-II Pro FPGA device that drives the configuration clock on the CCLK pin to a Xilinx Serial PROM which in turn feeds bit-serial data to the DIN input. The FPGA accepts this data on each rising CCLK edge. After the FPGA has been loaded, the data for the next device in a daisy-chain is presented on the DOUT pin after the rising CCLK edge.

The interface is identical to slave serial except that an internal oscillator is used to generate the configuration clock (CCLK). A wide range of frequencies can be selected for CCLK which always starts at a slow default frequency. Configuration bits then switch CCLK to a higher frequency for the remainder of the configuration.

**Slave SelectMAP Mode**

The SelectMAP mode is the fastest configuration option. Byte-wide data is written into the Virtex-II Pro FPGA device with a BUSY flag controlling the flow of data. An external data source provides a byte stream, CCLK, an active Low Chip Select (CS_B) signal and a Write signal (RDWR_B). If BUSY is asserted (High) by the FPGA, the data must be held until BUSY goes Low. Data can also be read using the SelectMAP mode. If RDWR_B is asserted, configuration data is read out of the FPGA as part of a readback operation.

After configuration, the pins of the SelectMAP port can be used as additional user I/O. Alternatively, the port can be retained to permit high-speed 8-bit readback using the persist option.

Multiple Virtex-II Pro FPGAs can be configured using the SelectMAP mode, and be made to start-up simultaneously. To configure multiple devices in this way, wire the individual CCLK, Data, RDWR_B, and BUSY pins of all the devices in parallel. The individual devices are loaded separately by deasserting the CS_B pin of each device in turn and writing the appropriate data.

**Master SelectMAP Mode**

This mode is a master version of the SelectMAP mode. The device is configured byte-wide on a CCLK supplied by the Virtex-II Pro FPGA device. Timing is similar to the Slave SerialMAP mode except that CCLK is supplied by the Virtex-II Pro FPGA.

**Boundary-Scan (JTAG, IEEE 1532) Mode**

In boundary-scan mode, dedicated pins are used for configuring the Virtex-II Pro device. The configuration is done entirely through the IEEE 1149.1 Test Access Port (TAP). Virtex-II Pro device configuration using Boundary scan is compliant with IEEE 1149.1-1993 standard and the new IEEE 1532 standard for In-System Configurable (ISC) devices. The IEEE 1532 standard is backward compliant with the IEEE 1149.1-1993 TAP and state machine. The IEEE Standard 1532 for In-System Configurable (ISC) devices is intended to be programmed, reprogrammed, or tested on the board via a physical and logical protocol. Configuration through the boundary-scan port is always available, independent of the mode selection. Selecting the boundary-scan mode simply turns off the other modes.
Table 28: Virtex-II Pro Configuration Mode Pin Settings

<table>
<thead>
<tr>
<th>Configuration Mode(1)</th>
<th>M2</th>
<th>M1</th>
<th>M0</th>
<th>CCLK Direction</th>
<th>Data Width</th>
<th>Serial DOUT(2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Master Serial</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>Out</td>
<td>1</td>
<td>Yes</td>
</tr>
<tr>
<td>Slave Serial</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>In</td>
<td>1</td>
<td>Yes</td>
</tr>
<tr>
<td>Master SelectMAP</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>Out</td>
<td>8</td>
<td>No</td>
</tr>
<tr>
<td>Slave SelectMAP</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>In</td>
<td>8</td>
<td>No</td>
</tr>
<tr>
<td>Boundary Scan</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>N/A</td>
<td>1</td>
<td>No</td>
</tr>
</tbody>
</table>

Notes:
1. The HSWAP_EN pin controls the pullups. Setting M2, M1, and M0 selects the configuration mode, while the HSWAP_EN pin controls whether or not the pullups are used.
2. Daisy chaining is possible only in modes where Serial DOUT is used. For example, in SelectMAP modes, the first device does NOT support daisy chaining of downstream devices.

Table 29 lists the total number of bits required to configure each device.

Table 29: Virtex-II Pro Bitstream Lengths

<table>
<thead>
<tr>
<th>Device</th>
<th>Number of Configuration Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>XC2VP2</td>
<td>1,305,440</td>
</tr>
<tr>
<td>XC2VP4</td>
<td>3,006,560</td>
</tr>
<tr>
<td>XC2VP7</td>
<td>4,485,472</td>
</tr>
<tr>
<td>XC2VP20</td>
<td>8,214,624</td>
</tr>
<tr>
<td>XC2VP30</td>
<td>11,364,608</td>
</tr>
<tr>
<td>XC2VP40</td>
<td>15,563,264</td>
</tr>
<tr>
<td>XC2VP50</td>
<td>19,021,472</td>
</tr>
<tr>
<td>XC2VP70</td>
<td>25,604,096</td>
</tr>
<tr>
<td>XC2VP100</td>
<td>33,645,312</td>
</tr>
<tr>
<td>XC2VP125</td>
<td>42,782,208</td>
</tr>
</tbody>
</table>

Configuration Sequence

The configuration of Virtex-II Pro devices is a three-phase process. First, the configuration memory is cleared. Next, configuration data is loaded into the memory, and finally, the logic is activated by a start-up process.

Configuration is automatically initiated on power-up unless it is delayed by the user. The INIT_B pin can be held Low using an open-drain driver. An open-drain is required since INIT_B is a bidirectional open-drain pin that is held Low by a Virtex-II Pro FPGA device while the configuration memory is being cleared. Extending the time that the pin is Low causes the configuration sequencer to wait. Thus, configuration is delayed by preventing entry into the phase where data is loaded.

The configuration process can also be initiated by asserting the PROG_B pin. The end of the memory-clearing phase is signaled by the INIT_B pin going High, and the completion of the entire process is signaled by the DONE pin going High. The Global Set/Reset (GSR) signal is pulsed after the last frame of configuration data is written but before the start-up sequence. The GSR signal resets all flip-flops on the device.

The default start-up sequence is that one CCLK cycle after DONE goes High, the global 3-state signal (GTS) is released. This permits device outputs to turn on as necessary. One CCLK cycle later, the Global Write Enable (GWE) signal is released. This permits the internal storage elements to begin changing state in response to the logic and the user clock.

The relative timing of these events can be changed via configuration options in software. In addition, the GTS and GWE events can be made dependent on the DONE pins of multiple devices all going High, forcing the devices to start synchronously. The sequence can also be paused at any stage, until lock has been achieved on any or all DCMs, as well as DCI.

Readback

In this mode, configuration data from the Virtex-II Pro FPGA device can be read back. Readback is supported only in the SelectMAP (master and slave) and Boundary Scan mode.

Along with the configuration data, it is possible to read back the contents of all registers, distributed SelectRAM+, and block RAM resources. This capability is used for real-time debugging. For more detailed configuration information, see the Virtex-II Pro User Guide.

Bitstream Encryption

Virtex-II Pro devices have an on-chip decryptor using one or two sets of three keys for triple-key Data Encryption Standard (DES) operation. Xilinx software tools offer an optional encryption of the configuration data (bitstream) with a triple-key DES determined by the designer.

The keys are stored in the FPGA by JTAG instruction and retained by a battery connected to the VBAT pin, when the device is not powered. Virtex-II Pro devices can be config-
ured with the corresponding encrypted bitstream, using any of the configuration modes described previously.

A detailed description of how to use bitstream encryption is provided in the Virtex-II Pro User Guide. Your local FAE can also provide specific information on this feature.

**Partial Reconfiguration**

Partial reconfiguration of Virtex-II Pro devices can be accomplished in either Slave SelectMAP mode or Boundary-Scan mode. Instead of resetting the chip and doing a full configuration, new data is loaded into a specified area of the chip, while the rest of the chip remains in operation.

Data is loaded on a column basis, with the smallest load unit being a configuration “frame” of the bitstream (device size dependent).

Partial reconfiguration is useful for applications that require different designs to be loaded into the same area of a chip, or that require the ability to change portions of a design without having to reset or reconfigure the entire chip.

For more information on Partial Reconfiguration in Virtex-II Pro devices, please refer to Xilinx Application Note XAPP290, Two Flows for Partial Reconfiguration.

---

**Revision History**

This section records the change history for this module of the data sheet.

<table>
<thead>
<tr>
<th>Date</th>
<th>Version</th>
<th>Revision</th>
</tr>
</thead>
<tbody>
<tr>
<td>01/31/02</td>
<td>1.0</td>
<td>Initial Xilinx release.</td>
</tr>
<tr>
<td>06/13/02</td>
<td>2.0</td>
<td>New Virtex-II Pro family members. New timing parameters per speedsfile v1.62.</td>
</tr>
<tr>
<td>09/03/02</td>
<td>2.1</td>
<td>• Revised Reset and Power sections.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Updated Table 8, which lists compatible input standards.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Added Figure 19, Figure 20, and Figure 21, which provide examples illustrating the use of I/O standards.</td>
</tr>
<tr>
<td>09/27/02</td>
<td>2.2</td>
<td>• In section Overview, corrected max number of MGTs from 16 to 24.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• In section Input/Output Blocks (IOBs), added references to XAPP659 regarding implementation of 3.3V I/O standards.</td>
</tr>
<tr>
<td></td>
<td>2.3</td>
<td>• Correct bitstream lengths, Table 29</td>
</tr>
</tbody>
</table>

---

**Virtex-II Pro Data Sheet Modules**

The Virtex-II Pro Data Sheet contains the following modules:

- Virtex-II Pro™ Platform FPGAs: Introduction and Overview (Module 1)
- Virtex-II Pro Platform FPGAs: Functional Description (Module 2)
- Virtex-II Pro™ Platform FPGAs: DC and Switching Characteristics (Module 3)
- Virtex-II Pro Platform FPGAs: Pinout Information (Module 4)
Virtex-II Pro™ Platform FPGAs: DC and Switching Characteristics

Virtex-II Pro Electrical Characteristics

Virtex-II Pro devices are provided in -7, -6, and -5 speed grades, with -7 having the highest performance.

Virtex-II Pro DC and AC characteristics are specified for both commercial and industrial grades. Except the operating temperature range or unless otherwise noted, all the DC and AC electrical parameters are the same for a particular speed grade (that is, the timing characteristics of a -6 speed grade industrial device are the same as for a -6 speed grade commercial device). However, only selected speed grades and/or devices might be available in the industrial range.

All supply voltage and junction temperature specifications are representative of worst-case conditions. The parameters included are common to popular designs and typical applications. Contact Xilinx for design considerations requiring more detailed information.

All specifications are subject to change without notice.

Virtex-II Pro DC Characteristics

Table 1: Absolute Maximum Ratings

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Description</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>VCCINT</td>
<td>Internal supply voltage relative to GND</td>
<td>–0.5 to 1.6 V</td>
</tr>
<tr>
<td>VCCUX</td>
<td>Auxiliary supply voltage relative to GND</td>
<td>–0.5 to 3.0 V</td>
</tr>
<tr>
<td>VCCO</td>
<td>3.3V output drivers supply voltage relative to GND</td>
<td>–0.3 to 3.6 V</td>
</tr>
<tr>
<td></td>
<td>2.5V and below output drivers supply voltage relative to GND</td>
<td>–0.5 to 3.0 V</td>
</tr>
<tr>
<td>VBATT</td>
<td>Key memory battery backup supply</td>
<td>–0.5 to 3.0 V</td>
</tr>
<tr>
<td>VREF</td>
<td>Input reference voltage</td>
<td>–0.3 to 3.6 V</td>
</tr>
<tr>
<td>VIN</td>
<td>3.3V I/O input voltage relative to GND (user and dedicated I/Os)</td>
<td>–0.3(2) to 3.6(3) V</td>
</tr>
<tr>
<td></td>
<td>2.5V or below I/O input voltage relative to GND (user and dedicated I/Os)</td>
<td>GND – 0.5 to VCCO + 0.5 V</td>
</tr>
<tr>
<td>VTS</td>
<td>Voltage applied to 3-state 3.3V output (user and dedicated I/Os)</td>
<td>–0.3(4) to 3.6(5) V</td>
</tr>
<tr>
<td></td>
<td>Voltage applied to 3-state 2.5V or below output (user and dedicated I/Os)</td>
<td>GND – 0.5 to VCCO + 0.5 V</td>
</tr>
<tr>
<td>VCCAXRX</td>
<td>Auxiliary supply voltage relative to analog ground, GNDA (RocketIO MGT pins)</td>
<td>–0.5 to 3.0 V</td>
</tr>
<tr>
<td>VCCAXTX</td>
<td>Auxiliary supply voltage relative to analog ground, GNDA (RocketIO MGT pins)</td>
<td>–0.5 to 3.0 V</td>
</tr>
<tr>
<td>VTTX</td>
<td>Terminal transmit supply voltage relative to GND (RocketIO MGT pins)</td>
<td>–0.5 to 3.0 V</td>
</tr>
<tr>
<td>VTRX</td>
<td>Terminal receive supply voltage relative to GND (RocketIO MGT pins)</td>
<td>–0.5 to 3.0 V</td>
</tr>
<tr>
<td>TSTG</td>
<td>Storage temperature (ambient)</td>
<td>-65 to +150 °C</td>
</tr>
<tr>
<td>TSOL</td>
<td>Maximum soldering temperature</td>
<td>+220 °C</td>
</tr>
<tr>
<td>TJ</td>
<td>Operating junction temperature</td>
<td>+125(6) °C</td>
</tr>
</tbody>
</table>

Notes:
1. Stresses beyond those listed under Absolute Maximum Ratings might cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those listed under Operating Conditions is not implied. Exposure to Absolute Maximum Ratings conditions for extended periods of time might affect device reliability.
2. For 3.3V I/O standards only, I/O input pin voltage, including negative undershoot, must not fall below –0.3V, either on a continuous or transient basis (i.e., no negative undershoot is allowed). See Table 6, page 78.
3. I/O input pin voltage, including overshoot, must not exceed 3.6V, either on a continuous or transient basis.
4. For 3.3V I/O standards only, I/O output pin voltage while in 3-state mode must not fall below –0.3V, either on a continuous or transient basis. See Table 6, page 78.
5. I/O output pin voltage while in 3-state mode must not exceed 3.6V, either on a continuous or transient basis.
6. For 3.3V operation, TJ must be less than 100°C.
### Table 2: Recommended Operating Conditions

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Description</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>$V_{CCINT}$</td>
<td>Internal supply voltage relative to GND, $T_J = 0 , ^\circ C$ to $+85, ^\circ C$</td>
<td>Commercial 1.425</td>
<td>1.575</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>Internal supply voltage relative to GND, $T_J = -40, ^\circ C$ to $+100, ^\circ C$</td>
<td>Industrial 1.425</td>
<td>1.575</td>
<td>V</td>
</tr>
<tr>
<td>$V_{CCAU$(1)X}$</td>
<td>Auxiliary supply voltage relative to GND, $T_J = 0 , ^\circ C$ to $+85, ^\circ C$</td>
<td>Commercial 2.375</td>
<td>2.625</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>Auxiliary supply voltage relative to GND, $T_J = -40, ^\circ C$ to $+100, ^\circ C$</td>
<td>Industrial 2.375</td>
<td>2.625</td>
<td>V</td>
</tr>
<tr>
<td>$V_{CCO$(2)}$</td>
<td>3.3V supply voltage relative to GND, $T_J = 0 , ^\circ C$ to $+85, ^\circ C$</td>
<td>Commercial 1.2</td>
<td>3.45(4)</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>3.3V supply voltage relative to GND, $T_J = -40, ^\circ C$ to $+100, ^\circ C$</td>
<td>Industrial 1.2</td>
<td>3.45(4)</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>2.5V and below supply voltage relative to GND, $T_J = 0 , ^\circ C$ to $+85, ^\circ C$</td>
<td>Commercial 1.2</td>
<td>2.63</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>2.5V and below supply voltage relative to GND, $T_J = -40, ^\circ C$ to $+100, ^\circ C$</td>
<td>Industrial 1.2</td>
<td>2.63</td>
<td>V</td>
</tr>
<tr>
<td>$V_{IN}$</td>
<td>3.3V supply voltage relative to GND, $T_J = 0 , ^\circ C$ to $+85, ^\circ C$</td>
<td>Commercial GND – 0.2</td>
<td>3.45(4)</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>3.3V supply voltage relative to GND, $T_J = -40, ^\circ C$ to $+100, ^\circ C$</td>
<td>Industrial GND – 0.2</td>
<td>3.45(4)</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>2.5V and below supply voltage relative to GND, $T_J = 0 , ^\circ C$ to $+85, ^\circ C$</td>
<td>Commercial GND – 0.2</td>
<td>$V_{CCO} + 0.2$</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>2.5V and below supply voltage relative to GND, $T_J = -40, ^\circ C$ to $+100, ^\circ C$</td>
<td>Industrial GND – 0.2</td>
<td>$V_{CCO} + 0.2$</td>
<td>V</td>
</tr>
<tr>
<td>$V_{BATT$(3)}$</td>
<td>Battery voltage relative to GND, $T_J = 0 , ^\circ C$ to $+85, ^\circ C$</td>
<td>Commercial 1.0</td>
<td>2.63</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>Battery voltage relative to GND, $T_J = -40, ^\circ C$ to $+100, ^\circ C$</td>
<td>Industrial 1.0</td>
<td>2.63</td>
<td>V</td>
</tr>
<tr>
<td>$V_{CCAU$(5)X}$</td>
<td>Auxiliary supply voltage relative to GND</td>
<td>Commercial 2.375</td>
<td>2.625</td>
<td>V</td>
</tr>
<tr>
<td>$V_{CCAU$(5)X}$</td>
<td>Auxiliary supply voltage relative to GND</td>
<td>Commercial 2.375</td>
<td>2.625</td>
<td>V</td>
</tr>
<tr>
<td>$V_{TTX}, V_{TRX}$</td>
<td>Terminal supply voltage relative to GND</td>
<td>Commercial 1.8</td>
<td>2.625</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>Terminal supply voltage relative to GND</td>
<td>Industrial 1.8</td>
<td>2.625</td>
<td>V</td>
</tr>
</tbody>
</table>

**Notes:**

1. For LVDS operation, $V_{CCAU}$ min is 2.37V and max is 2.63V.
2. Configuration data is retained even if $V_{CCO}$ drops to 0V.
3. If battery is not used, do not connect $V_{BATT}$.
4. For 3.3V operation: See Table 4 in Module 4 of the Virtex-II Pro data sheet for banking information. (Module 4 not included in this volume; see [www.xilinx.com/virtex2pro](http://www.xilinx.com/virtex2pro).) Also see Application Note XAPP646 on [www.xilinx.com](http://www.xilinx.com).
5. **IMPORTANT!** All unused RocketIO transceivers in the FPGA must be connected to power and ground. If RocketIO transceivers in the FPGA are used, refer to the information on power filtering in the [RocketIO Transceiver User Guide](http://www.xilinx.com). Unused transceivers can be powered by any 2.5V source, and passive filtering is not required.
### Table 3: DC Characteristics Over Recommended Operating Conditions

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Description</th>
<th>Device</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>VDRINT</td>
<td>Data retention $V_{CCINT}$ voltage (below which configuration data might be lost)</td>
<td>All</td>
<td>1.25</td>
<td></td>
<td></td>
<td>V</td>
</tr>
<tr>
<td>VDRI</td>
<td>Data retention $V_{CCAUUX}$ voltage (below which configuration data might be lost)</td>
<td>All</td>
<td>2.0</td>
<td></td>
<td></td>
<td>V</td>
</tr>
<tr>
<td>IREF</td>
<td>$V_{REF}$ current per pin</td>
<td>All</td>
<td></td>
<td></td>
<td></td>
<td>µA</td>
</tr>
<tr>
<td>I3V</td>
<td>3.3V input or output leakage current per pin</td>
<td>All</td>
<td></td>
<td></td>
<td></td>
<td>µA</td>
</tr>
<tr>
<td>I2V</td>
<td>2.5V input or output leakage current per pin</td>
<td>All</td>
<td></td>
<td></td>
<td></td>
<td>µA</td>
</tr>
<tr>
<td>Cin</td>
<td>Input capacitance (sample tested)</td>
<td>All</td>
<td></td>
<td>10</td>
<td></td>
<td>pF</td>
</tr>
<tr>
<td>IRPU</td>
<td>Pad pull-up (when selected) @ $V_{in} = 0V, V_{CCO} = 2.5V$ (sample tested)</td>
<td>All</td>
<td></td>
<td></td>
<td></td>
<td>µA</td>
</tr>
<tr>
<td>IRPD</td>
<td>Pad pull-down (when selected) @ $V_{in} = 2.5V$ (sample tested)</td>
<td>All</td>
<td></td>
<td></td>
<td></td>
<td>µA</td>
</tr>
<tr>
<td>IBATT</td>
<td>Battery supply current</td>
<td>All</td>
<td></td>
<td></td>
<td></td>
<td>nA</td>
</tr>
<tr>
<td>ICCAUXTX</td>
<td>Operating $V_{CCAUXTX}$ supply current</td>
<td>All</td>
<td></td>
<td>60</td>
<td></td>
<td>mA</td>
</tr>
<tr>
<td>ICCAUXRX</td>
<td>Operating $V_{CCAUXRX}$ supply current</td>
<td>All</td>
<td></td>
<td>35</td>
<td></td>
<td>mA</td>
</tr>
<tr>
<td>ITTX</td>
<td>Operating $I_{TX}$ supply current when transmitter is AC coupled</td>
<td>All</td>
<td></td>
<td>30</td>
<td></td>
<td>mA</td>
</tr>
<tr>
<td>ITTXD</td>
<td>Operating $I_{TX}$ supply current when transmitter is DC coupled</td>
<td>All</td>
<td></td>
<td>15</td>
<td></td>
<td>mA</td>
</tr>
<tr>
<td>ITRX</td>
<td>Operating $I_{RX}$ supply current when receiver is AC coupled</td>
<td>All</td>
<td></td>
<td>15</td>
<td></td>
<td>mA</td>
</tr>
<tr>
<td>P_CPU</td>
<td>Power dissipation of PowerPC® 405 processor block</td>
<td>All</td>
<td></td>
<td>0.9</td>
<td></td>
<td>mW/MHz</td>
</tr>
<tr>
<td>PRXTX</td>
<td>Power dissipation of RocketIO transceiver @ 3.125 Gb/s per channel</td>
<td>All</td>
<td></td>
<td>350</td>
<td></td>
<td>mW</td>
</tr>
<tr>
<td>Power dissipation of RocketIO transceiver @ 2.5 Gb/s per channel</td>
<td>All</td>
<td></td>
<td>310</td>
<td></td>
<td>mW</td>
<td></td>
</tr>
<tr>
<td>Power dissipation of RocketIO transceiver @ 1.25 Gb/s per channel</td>
<td>All</td>
<td></td>
<td>230</td>
<td></td>
<td>mW</td>
<td></td>
</tr>
<tr>
<td>Symbol</td>
<td>Description</td>
<td>Device</td>
<td>Min</td>
<td>Typ</td>
<td>Max</td>
<td>Units</td>
</tr>
<tr>
<td>-----------</td>
<td>----------------------</td>
<td>------------</td>
<td>-----</td>
<td>-----</td>
<td>-----</td>
<td>-------</td>
</tr>
<tr>
<td>ICCINTQ</td>
<td>Quiescent $V_{CCINT}$ supply current</td>
<td>XC2VP2</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP4</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP7</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP20</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP30</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP40</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP50</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP70</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP100</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP125</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ICCOQ</td>
<td>Quiescent $V_{CCO}$ supply current</td>
<td>XC2VP2</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP4</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP7</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP20</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP30</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP40</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP50</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP70</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP100</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP125</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ICCAUXQ</td>
<td>Quiescent $V_{CCAUX}$ supply current</td>
<td>XC2VP2</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP4</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP7</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP20</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP50</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP40</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP50</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP70</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP100</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP125</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Notes:
1. With no output current loads, no active input pull-up resistors, all I/O pins are 3-state and floating.
2. If DCI or differential signaling is used, more accurate quiescent current estimates can be obtained by using the Power Estimator or XPOWER™.
Power-On Power Supply Requirements

Xilinx FPGAs require a certain amount of supply current during power-on to insure proper device operation. The actual current consumed depends on the power-on ramp rate of the power supply.

The $V_{CCINT}$ power supply must ramp on no faster than 200 $\mu$s and no slower than 50 ms. Ramp on is defined as: 0 $V_{DC}$ to minimum supply voltages (see Table 2).

$V_{CCAUX}$ and $V_{CCO}$ can power on at any ramp rate. Power supplies can be turned on in any sequence. $V_{CCAUX}$ and $V_{CCO}$ for bank 4 must be connected together to 2.5 $V_{DC}$. $V_{CCAUX}$ must power on before or with $V_{CCO}$ for the current specifications to apply.

Table 5 shows the minimum current required by Virtex-II Pro devices for proper power on and configuration. If the currents minimums shown in Table 5 are met, the device powers on properly after all three supplies have passed through their power-on reset threshold voltages.

Once initialized and configured, use the power calculator to estimate current drain on these supplies.

For more information on $V_{CCAUX}$, $V_{CCO}$, and configuration mode, refer to Chapter 3 in the Virtex-II Pro Platform FPGA User Guide.

Table 5: Power-On Current for Virtex-II Pro Devices

<table>
<thead>
<tr>
<th>Symbol</th>
<th>XC2VP2</th>
<th>XC2VP4</th>
<th>XC2VP7</th>
<th>XC2VP20</th>
<th>XC2VP30</th>
<th>XC2VP40</th>
<th>XC2VP50</th>
<th>XC2VP70</th>
<th>XC2VP100</th>
<th>XC2VP125</th>
</tr>
</thead>
<tbody>
<tr>
<td>$I_{CCINTMIN}$</td>
<td>500</td>
<td>500</td>
<td>500</td>
<td>500</td>
<td>TBD</td>
<td>TBD</td>
<td>TBD</td>
<td>TBD</td>
<td>TBD</td>
<td>TBD</td>
</tr>
<tr>
<td>$I_{CCAUXMIN}$</td>
<td>250</td>
<td>250</td>
<td>250</td>
<td>250</td>
<td>250</td>
<td>250</td>
<td>250</td>
<td>250</td>
<td>250</td>
<td>250</td>
</tr>
<tr>
<td>$I_{CCOMIN}$</td>
<td>100</td>
<td>100</td>
<td>100</td>
<td>100</td>
<td>100</td>
<td>100</td>
<td>100</td>
<td>100</td>
<td>100</td>
<td>100</td>
</tr>
<tr>
<td>Units</td>
<td>mA</td>
<td>mA</td>
<td>mA</td>
<td>mA</td>
<td>mA</td>
<td>mA</td>
<td>mA</td>
<td>mA</td>
<td>mA</td>
<td>mA</td>
</tr>
</tbody>
</table>

General Power Supply Requirements

Proper decoupling of all FPGA power supplies is essential. Consult Xilinx Application Note 623 for detailed information on power distribution system design.

$V_{CCAUX}$ powers critical resources in the FPGA. Therefore, this supply voltage is especially susceptible to power supply noise.

$V_{CCAUX}$ can share a power plane with $V_{CCO}$, but only if $V_{CCO}$ does not have excessive noise. Staying within simultaneously switching output (SSO) limits is essential for keeping power supply noise to a minimum. More information on SSO is available at support.xilinx.com in Xilinx Answer Record 11713.

Changes in $V_{CCAUX}$ voltage beyond 200 mV peak-to-peak should take place at a rate no faster than 10 mV per millisecond.

Recommended practices that can help reduce jitter and period distortion are described in Xilinx Answer Record 13756.
SelectIO™-Ultra DC Input and Output Levels

Values for $V_{IL}$ and $V_{IH}$ are recommended input voltages. Values for $I_{OL}$ and $I_{OH}$ are guaranteed over the recommended operating conditions at the $V_{OL}$ and $V_{OH}$ test points. Only selected standards are tested. These are chosen to ensure that all standards meet their specifications. The selected standards are tested at minimum $V_{CCO}$ with the respective $V_{OL}$ and $V_{OH}$ voltage levels shown. Other standards are sample tested.

<table>
<thead>
<tr>
<th>Input/Output Standard</th>
<th>$V_{IL}$</th>
<th>$V_{IH}$</th>
<th>$V_{OL}$</th>
<th>$V_{OH}$</th>
<th>$I_{OL}$</th>
<th>$I_{OH}$</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>$V_{min}$</td>
<td>$V_{max}$</td>
<td>$V_{min}$</td>
<td>$V_{max}$</td>
<td>$V_{max}$</td>
<td>$V_{Min}$</td>
</tr>
<tr>
<td>LVCMOS25</td>
<td>0.5</td>
<td>0.7</td>
<td>1.7</td>
<td>$V_{CCO}$ + 0.4</td>
<td>0.4</td>
<td>$V_{CCO}$ − 0.4</td>
</tr>
<tr>
<td>LVCMOS18</td>
<td>0.5</td>
<td>0.7</td>
<td>1.7</td>
<td>$V_{CCO}$ + 0.4</td>
<td>0.4</td>
<td>$V_{CCO}$ − 0.45</td>
</tr>
<tr>
<td>LVCMOS15</td>
<td>0.5</td>
<td>0.7</td>
<td>1.7</td>
<td>$V_{CCO}$ + 0.4</td>
<td>0.4</td>
<td>$V_{CCO}$ − 0.45</td>
</tr>
<tr>
<td>PCI33_3</td>
<td>0.3</td>
<td>0.7</td>
<td>1.7</td>
<td>$V_{CCO}$ + 0.4</td>
<td>0.4</td>
<td>$V_{CCO}$ − 0.45</td>
</tr>
<tr>
<td>PCI66_3</td>
<td>0.3</td>
<td>0.7</td>
<td>1.7</td>
<td>$V_{CCO}$ + 0.4</td>
<td>0.4</td>
<td>$V_{CCO}$ − 0.45</td>
</tr>
<tr>
<td>GTLP</td>
<td>0.5</td>
<td>0.7</td>
<td>1.7</td>
<td>$V_{CCO}$ + 0.4</td>
<td>0.4</td>
<td>$V_{CCO}$ − 0.45</td>
</tr>
<tr>
<td>GTL</td>
<td>0.5</td>
<td>0.7</td>
<td>1.7</td>
<td>$V_{CCO}$ + 0.4</td>
<td>0.4</td>
<td>$V_{CCO}$ − 0.45</td>
</tr>
<tr>
<td>HSTL I</td>
<td>0.5</td>
<td>0.7</td>
<td>1.7</td>
<td>$V_{CCO}$ + 0.4</td>
<td>0.4</td>
<td>$V_{CCO}$ − 0.45</td>
</tr>
<tr>
<td>HSTL II</td>
<td>0.5</td>
<td>0.7</td>
<td>1.7</td>
<td>$V_{CCO}$ + 0.4</td>
<td>0.4</td>
<td>$V_{CCO}$ − 0.45</td>
</tr>
<tr>
<td>HSTL III</td>
<td>0.5</td>
<td>0.7</td>
<td>1.7</td>
<td>$V_{CCO}$ + 0.4</td>
<td>0.4</td>
<td>$V_{CCO}$ − 0.45</td>
</tr>
<tr>
<td>HSTL IV</td>
<td>0.5</td>
<td>0.7</td>
<td>1.7</td>
<td>$V_{CCO}$ + 0.4</td>
<td>0.4</td>
<td>$V_{CCO}$ − 0.45</td>
</tr>
<tr>
<td>SSTL2 I</td>
<td>0.3</td>
<td>0.7</td>
<td>1.7</td>
<td>$V_{CCO}$ + 0.4</td>
<td>0.4</td>
<td>$V_{CCO}$ − 0.45</td>
</tr>
<tr>
<td>SSTL2 II</td>
<td>0.3</td>
<td>0.7</td>
<td>1.7</td>
<td>$V_{CCO}$ + 0.4</td>
<td>0.4</td>
<td>$V_{CCO}$ − 0.45</td>
</tr>
<tr>
<td>SSTL18 I</td>
<td>0.3</td>
<td>0.7</td>
<td>1.7</td>
<td>$V_{CCO}$ + 0.4</td>
<td>0.4</td>
<td>$V_{CCO}$ − 0.45</td>
</tr>
<tr>
<td>SSTL18 II</td>
<td>0.3</td>
<td>0.7</td>
<td>1.7</td>
<td>$V_{CCO}$ + 0.4</td>
<td>0.4</td>
<td>$V_{CCO}$ − 0.45</td>
</tr>
</tbody>
</table>

Notes:
1. This applies to 1.5V and 1.8V HSTL.

LDT DC Specifications (LDT_25)

<table>
<thead>
<tr>
<th>DC Parameter</th>
<th>Symbol</th>
<th>Conditions</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Supply Voltage</td>
<td>$V_{CCO}$</td>
<td>2.38 2.5 2.63</td>
<td>V</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Differential Output Voltage</td>
<td>$V_{OD}$</td>
<td>R_T = 100 ohm across Q and Q signals</td>
<td>500 600 700</td>
<td>mV</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Change in $V_{OD}$ Magnitude</td>
<td>$\Delta V_{OD}$</td>
<td>−15 15</td>
<td>mV</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Output Common Mode Voltage</td>
<td>$V_{OCM}$</td>
<td>R_T = 100 ohm across Q and Q signals</td>
<td>560 600 640</td>
<td>mV</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Change in $V_{OCM}$ Magnitude</td>
<td>$\Delta V_{OCM}$</td>
<td>−15 15</td>
<td>mV</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Input Differential Voltage</td>
<td>$V_{ID}$</td>
<td>200 600 1000</td>
<td>mV</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Change in $V_{ID}$ Magnitude</td>
<td>$\Delta V_{ID}$</td>
<td>−15 15</td>
<td>mV</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Input Common Mode Voltage</td>
<td>$V_{ICM}$</td>
<td>500 600 700</td>
<td>mV</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Change in $V_{ICM}$ Magnitude</td>
<td>$\Delta V_{ICM}$</td>
<td>−15 15</td>
<td>mV</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
LVDS DC Specifications (LVDS_25)

<table>
<thead>
<tr>
<th>DC Parameter</th>
<th>Symbol</th>
<th>Conditions</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Supply Voltage</td>
<td>( V_{CCO} )</td>
<td></td>
<td>2.38</td>
<td>2.5</td>
<td>2.63</td>
<td>V</td>
</tr>
<tr>
<td>Output High Voltage for Q and ( \overline{Q} )</td>
<td>( V_{OH} )</td>
<td>( R_T = 100 , \Omega ) across Q and ( \overline{Q} ) signals</td>
<td>1.602</td>
<td></td>
<td></td>
<td>V</td>
</tr>
<tr>
<td>Output Low Voltage for Q and ( \overline{Q} )</td>
<td>( V_{OL} )</td>
<td>( R_T = 100 , \Omega ) across Q and ( \overline{Q} ) signals</td>
<td>0.898</td>
<td></td>
<td></td>
<td>V</td>
</tr>
<tr>
<td>Differential Output Voltage (Q – ( \overline{Q} )), ( Q = \text{High} ) ( (\overline{Q} – Q) ), ( \overline{Q} = \text{High} )</td>
<td>( V_{ODIFF} )</td>
<td>( R_T = 100 , \Omega ) across Q and ( \overline{Q} ) signals</td>
<td>247</td>
<td>350</td>
<td>454</td>
<td>mV</td>
</tr>
<tr>
<td>Output Common-Mode Voltage</td>
<td>( V_{OCM} )</td>
<td>( R_T = 100 , \Omega ) across Q and ( \overline{Q} ) signals</td>
<td>1.125</td>
<td>1.2</td>
<td>1.375</td>
<td>V</td>
</tr>
<tr>
<td>Differential Input Voltage (Q – ( \overline{Q} )), ( Q = \text{High} ) ( (\overline{Q} – Q) ), ( \overline{Q} = \text{High} )</td>
<td>( V_{IDIFF} )</td>
<td>Common-mode input voltage = 1.25V</td>
<td>100</td>
<td>350</td>
<td>600</td>
<td>mV</td>
</tr>
<tr>
<td>Input Common-Mode Voltage</td>
<td>( V_{ICM} )</td>
<td>Differential input voltage = ±350 mV</td>
<td>0.3</td>
<td>1.2</td>
<td>2.2</td>
<td>V</td>
</tr>
</tbody>
</table>

Extended LVDS DC Specifications (LVDSEXT_25)

<table>
<thead>
<tr>
<th>DC Parameter</th>
<th>Symbol</th>
<th>Conditions</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Supply Voltage</td>
<td>( V_{CCO} )</td>
<td></td>
<td>2.38</td>
<td>2.5</td>
<td>2.63</td>
<td>V</td>
</tr>
<tr>
<td>Output High Voltage for Q and ( \overline{Q} )</td>
<td>( V_{OH} )</td>
<td>( R_T = 100 , \Omega ) across Q and ( \overline{Q} ) signals</td>
<td>1.785</td>
<td></td>
<td></td>
<td>V</td>
</tr>
<tr>
<td>Output Low Voltage for Q and ( \overline{Q} )</td>
<td>( V_{OL} )</td>
<td>( R_T = 100 , \Omega ) across Q and ( \overline{Q} ) signals</td>
<td>0.715</td>
<td></td>
<td></td>
<td>V</td>
</tr>
<tr>
<td>Differential Output Voltage (Q – ( \overline{Q} )), ( Q = \text{High} ) ( (\overline{Q} – Q) ), ( \overline{Q} = \text{High} )</td>
<td>( V_{ODIFF} )</td>
<td>( R_T = 100 , \Omega ) across Q and ( \overline{Q} ) signals</td>
<td>440</td>
<td>820</td>
<td></td>
<td>mV</td>
</tr>
<tr>
<td>Output Common-Mode Voltage</td>
<td>( V_{OCM} )</td>
<td>( R_T = 100 , \Omega ) across Q and ( \overline{Q} ) signals</td>
<td>1.125</td>
<td>1.250</td>
<td>1.375</td>
<td>V</td>
</tr>
<tr>
<td>Differential Input Voltage (Q – ( \overline{Q} )), ( Q = \text{High} ) ( (\overline{Q} – Q) ), ( \overline{Q} = \text{High} )</td>
<td>( V_{IDIFF} )</td>
<td>Common-mode input voltage = 1.25V</td>
<td>100</td>
<td>1000</td>
<td></td>
<td>mV</td>
</tr>
<tr>
<td>Input Common-Mode Voltage</td>
<td>( V_{ICM} )</td>
<td>Differential input voltage = ±350 mV</td>
<td>0.3</td>
<td>1.2</td>
<td>2.2</td>
<td>V</td>
</tr>
</tbody>
</table>

LVPECL DC Specifications (LVPECL_25)

<table>
<thead>
<tr>
<th>DC Parameter</th>
<th>Symbol</th>
<th>Conditions</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Supply Voltage</td>
<td>( V_{CCO} )</td>
<td></td>
<td>2.375</td>
<td>2.5</td>
<td>2.625</td>
<td>V</td>
</tr>
<tr>
<td>Output High Voltage for Q and ( \overline{Q} )</td>
<td>( V_{OH} )</td>
<td>( V_{CCO} – 1.025 ) ( \text{V}_{CCO} – 0.88 ) ( \text{V})</td>
<td>1.545</td>
<td></td>
<td></td>
<td>V</td>
</tr>
<tr>
<td>Output Low Voltage for Q and ( \overline{Q} )</td>
<td>( V_{OL} )</td>
<td>( V_{CCO} – 1.81 ) ( \text{V}_{CCO} – 1.62 ) ( \text{V})</td>
<td>0.795</td>
<td></td>
<td></td>
<td>V</td>
</tr>
<tr>
<td>Input High Voltage for Q and ( \overline{Q} )</td>
<td>( V_{IH} )</td>
<td>( V_{CCO} – 1.035 ) ( \text{V}_{CCO} – 0.88 ) ( \text{V})</td>
<td>0.795</td>
<td></td>
<td></td>
<td>V</td>
</tr>
<tr>
<td>Input Low Voltage for Q and ( \overline{Q} )</td>
<td>( V_{IL} )</td>
<td>( V_{CCO} – 1.81 ) ( \text{V}_{CCO} – 1.61 ) ( \text{V})</td>
<td>0.795</td>
<td></td>
<td></td>
<td>V</td>
</tr>
<tr>
<td>Differential Output Voltage (Q – ( \overline{Q} )), ( Q = \text{High} ) ( (\overline{Q} – Q) ), ( \overline{Q} = \text{High} )</td>
<td>( V_{ODIFF} )</td>
<td></td>
<td>345</td>
<td></td>
<td>1185</td>
<td>mV</td>
</tr>
<tr>
<td>Output Common-Mode Voltage</td>
<td>( V_{OCM} )</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>V</td>
</tr>
<tr>
<td>Differential Input Voltage (Q – ( \overline{Q} )), ( Q = \text{High} ) ( (\overline{Q} – Q) ), ( \overline{Q} = \text{High} )</td>
<td>( V_{IDIFF} )</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>mV</td>
</tr>
<tr>
<td>Input Common-Mode Voltage</td>
<td>( V_{ICM} )</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>V</td>
</tr>
</tbody>
</table>

Notes:
1. \( V_{OL}/V_{OH} \) measured at rx side; \( V_{IH}/V_{IL} \) are spec. number.
## RocketIO™ Transceiver DC Input and Output Levels

Table 11: RocketIO Transceiver DC Specifications

<table>
<thead>
<tr>
<th>DC Parameter</th>
<th>Symbol</th>
<th>Conditions</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Peak-to-Peak Differential Input Voltage</td>
<td>$D_{VIN}$</td>
<td></td>
<td>200</td>
<td></td>
<td>1000</td>
<td>mV</td>
</tr>
<tr>
<td>Differential Output Voltage $^{(1,2)}$</td>
<td>$D_{VOUT}$</td>
<td></td>
<td>400</td>
<td></td>
<td></td>
<td>mV</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>500</td>
<td></td>
<td></td>
<td>mV</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>600</td>
<td></td>
<td></td>
<td>mV</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>700</td>
<td></td>
<td></td>
<td>mV</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>800</td>
<td></td>
<td></td>
<td>mV</td>
</tr>
<tr>
<td>Peak-to-Peak Differential Output Voltage $^{(1,2)}$</td>
<td>$D_{VPPOUT}$</td>
<td></td>
<td>800</td>
<td></td>
<td></td>
<td>mV</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1000</td>
<td></td>
<td></td>
<td>mV</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1200</td>
<td></td>
<td></td>
<td>mV</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1400</td>
<td></td>
<td></td>
<td>mV</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1600</td>
<td></td>
<td></td>
<td>mV</td>
</tr>
</tbody>
</table>

Notes:

1. Output swing levels are selectable using TX_DIFF_CTRL attribute. See the RocketIO Transceiver section in Chapter 2, or refer to the RocketIO Transceiver User Guide for details.
2. Output preemphasis levels are selectable at 10% (default), 20%, 25%, and 33% using the TX_PREEMPHASIS attribute. See the RocketIO Transceiver section in Chapter 2 or the RocketIO Transceiver User Guide for details.
Virtex-II Pro Performance Characteristics

This section provides the performance characteristics of some common functions and designs implemented in Virtex-II Pro devices. The numbers reported here are fully characterized worst-case values. Note that these values are subject to the same guidelines as Virtex-II Pro Switching Characteristics (speed files).

Table 12 provides pin-to-pin values (in nanoseconds) including IOB delays; that is, delay through the device from input pin to output pin. In the case of multiple inputs and outputs, the worst delay is reported.

Table 12: Pin-to-Pin Performance

<table>
<thead>
<tr>
<th>Description</th>
<th>Pin-to-Pin (w/ I/O delays)</th>
<th>Units</th>
<th>Device Used &amp; Speed Grade</th>
</tr>
</thead>
<tbody>
<tr>
<td>Basic Functions:</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>16-bit Address Decoder</td>
<td>ns</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>32-bit Address Decoder</td>
<td>ns</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>64-bit Address Decoder</td>
<td>ns</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>4:1 MUX</td>
<td>ns</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>8:1 MUX</td>
<td>ns</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>16:1 MUX</td>
<td>ns</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>32:1 MUX</td>
<td>ns</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>Combinatorial (pad to LUT to pad)</td>
<td>ns</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>Memory:</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Block RAM</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Pad to setup</td>
<td>ns</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>Clock to Pad</td>
<td>ns</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>Distributed RAM</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Pad to setup</td>
<td>ns</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>Clock to Pad</td>
<td>ns</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
</tbody>
</table>

Table 13 shows internal (register-to-register) performance. Values are reported in MHz.

Table 13: Register-to-Register Performance

<table>
<thead>
<tr>
<th>Description</th>
<th>Register-to-Register Performance</th>
<th>Units</th>
<th>Device Used &amp; Speed Grade</th>
</tr>
</thead>
<tbody>
<tr>
<td>Basic Functions:</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>16-bit Address Decoder</td>
<td>MHz</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>32-bit Address Decoder</td>
<td>MHz</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>64-bit Address Decoder</td>
<td>MHz</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>4:1 MUX</td>
<td>MHz</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>8:1 MUX</td>
<td>MHz</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>16:1 MUX</td>
<td>MHz</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>32:1 MUX</td>
<td>MHz</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>Register to LUT to Register</td>
<td>MHz</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>8-bit Adder</td>
<td>MHz</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>16-bit Adder</td>
<td>MHz</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>64-bit Adder</td>
<td>MHz</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>64-bit Counter</td>
<td>MHz</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
<tr>
<td>64-bit Accumulator</td>
<td>MHz</td>
<td>XC2VP7FF672-6</td>
<td></td>
</tr>
</tbody>
</table>
### Table 13: Register-to-Register Performance (Continued)

<table>
<thead>
<tr>
<th>Description</th>
<th>Register-to-Register Performance</th>
<th>Units</th>
<th>Device Used &amp; Speed Grade</th>
</tr>
</thead>
<tbody>
<tr>
<td>Multiplier 18x18 (with Block RAM inputs)</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>Multiplier 18x18 (with Register inputs)</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td><strong>Memory:</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Block RAM</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Single-Port 4096 x 4 bits</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>Single-Port 2048 x 9 bits</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>Single-Port 1024 x 18 bits</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>Single-Port 512 x 36 bits</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>Dual-Port A:4096 x 4 bits &amp; B:1024 x 18 bits</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>Dual-Port A:1024 x 18 bits &amp; B:1024 x 18 bits</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>Dual-Port A:2048 x 9 bits &amp; B: 512 x 36 bits</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td><strong>Distributed RAM</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Single-Port 32 x 8-bit</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>Single-Port 64 x 8-bit</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>Single-Port 128 x 8-bit</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>Dual-Port 16 x 8</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>Dual-Port 32 x 8</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>Dual-Port 64 x 8</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>Dual-Port 128 x 8</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td><strong>Shift Registers</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>128-bit SRL</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>256-bit SRL</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td><strong>FIFOs (Async. in Block RAM)</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1024 x 18-bit</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>1024 x 18-bit</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td><strong>FIFOs (Sync. in SRL)</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>128 x 8-bit</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>128 x 16-bit</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td><strong>CAMs in Block RAM</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>32 x 9-bit</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>64 x 9-bit</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>128 x 9-bit</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>256 x 9-bit</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td><strong>CAMs in SRL</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>32 x 16-bit</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>64 x 32-bit</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>128 x 40-bit</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>256 x 48-bit</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>1024 x 16-bit</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
<tr>
<td>1024 x 72-bit</td>
<td>MHz</td>
<td></td>
<td>XC2VP7FF672-6</td>
</tr>
</tbody>
</table>
Virtex-II Pro Switching Characteristics

Switching characteristics are specified on a per-speed-grade basis and can be designated as Advance, Preliminary, or Production. Note that Virtex-II Pro Performance Characteristics are subject to these guidelines, as well. Each designation is defined as follows:

**Advance**: These speed files are based on simulations only and are typically available soon after device design specifications are frozen. Although speed grades with this designation are considered relatively stable and conservative, some under-reporting might still occur.

**Preliminary**: These speed files are based on complete ES (engineering sample) silicon characterization. Devices and speed grades with this designation are intended to give a better indication of the expected performance of production silicon. The probability of under-reporting delays is greatly reduced as compared to Advance data.

**Production**: These speed files are released once enough production silicon of a particular device family member has been characterized to provide full correlation between speed files and devices over numerous production lots. There is no under-reporting of delays, and customers receive formal notification of any subsequent changes. Typically, the slowest speed grades transition to Production before faster speed grades.

Since individual family members are produced at different times, the migration from one category to another depends completely on the status of the fabrication process for each device. Table 14 correlates the current status of each Virtex-II Pro device with a corresponding speed file designation.

All specifications are always representative of worst-case supply voltage and junction temperature conditions.

<table>
<thead>
<tr>
<th>Device</th>
<th>Speed Grade Designations</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Advance</td>
</tr>
<tr>
<td>XC2VP2</td>
<td>-7, -6, -5</td>
</tr>
<tr>
<td>XC2VP4</td>
<td>-7, -6, -5</td>
</tr>
<tr>
<td>XC2VP7</td>
<td>-7, -6, -5</td>
</tr>
<tr>
<td>XC2VP20</td>
<td>-7, -6, -5</td>
</tr>
<tr>
<td>XC2VP30</td>
<td></td>
</tr>
<tr>
<td>XC2VP40</td>
<td></td>
</tr>
<tr>
<td>XC2VP50</td>
<td>-7, -6, -5</td>
</tr>
<tr>
<td>XC2VP70</td>
<td></td>
</tr>
<tr>
<td>XC2VP100</td>
<td></td>
</tr>
<tr>
<td>XC2VP125</td>
<td></td>
</tr>
</tbody>
</table>

**Testing of Switching Characteristics**

All devices are 100% functionally tested. Internal timing parameters are derived from measuring internal test patterns. Listed below are representative values. For more specific, more precise, and worst-case guaranteed data, use the values reported by the static timing analyzer (TRCE in the Xilinx Development System) and back-annotate to the simulation net list. Unless otherwise noted, values apply to all Virtex-II Pro devices.

**PowerPC Switching Characteristics**

<table>
<thead>
<tr>
<th>Description</th>
<th>Speed Grade</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>-7</td>
<td>-6</td>
</tr>
<tr>
<td></td>
<td>Min</td>
<td>Max</td>
</tr>
<tr>
<td>CPMC405CLOCK frequency</td>
<td></td>
<td></td>
</tr>
<tr>
<td>JTAGC405TCK frequency(1)</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Notes:**
1. The theoretical maximum frequency of this clock is one-half the CPMC405CLOCK. However, the achievable maximum is dependent on the system, and will be much less.
### Table 16: Processor Block Switching Characteristics

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>-7</th>
<th>-6</th>
<th>-5</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Setup and Hold Relative to Clock (CPMC405CLOCK)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Device Control Register Bus control inputs</td>
<td>T_{PCCK_DCR}/T_{PCKC_DCR}</td>
<td>0.56/−0.23</td>
<td>0.61/−0.25</td>
<td>ns, min</td>
<td></td>
</tr>
<tr>
<td>Device Control Register Bus data inputs</td>
<td>T_{PDCK_DCR}/T_{PCKD_DCR}</td>
<td>0.82/−0.02</td>
<td>0.91/−0.02</td>
<td>ns, min</td>
<td></td>
</tr>
<tr>
<td>Clock and Power Management control inputs</td>
<td>T_{PCCK_CPM}/T_{PCKC_CPM}</td>
<td>0.20/0.03</td>
<td>0.22/0.04</td>
<td>ns, min</td>
<td></td>
</tr>
<tr>
<td>Reset control inputs</td>
<td>T_{PCCK_RST}/T_{PCKC_RST}</td>
<td>0.20/0.03</td>
<td>0.22/0.04</td>
<td>ns, min</td>
<td></td>
</tr>
<tr>
<td>Debug control inputs</td>
<td>T_{PCCK_DBG}/T_{PCKC_DBG}</td>
<td>0.34/0.38</td>
<td>0.38/0.42</td>
<td>ns, min</td>
<td></td>
</tr>
<tr>
<td>Trace control inputs</td>
<td>T_{PCCK_TRC}/T_{PCKC_TRC}</td>
<td>1.73/−0.52</td>
<td>1.90/−0.58</td>
<td>ns, min</td>
<td></td>
</tr>
<tr>
<td>External Interrupt Controller control inputs</td>
<td>T_{PCCK_EIC}/T_{PCKC_EIC}</td>
<td>0.72/−0.27</td>
<td>0.79/−0.30</td>
<td>ns, min</td>
<td></td>
</tr>
<tr>
<td>Clock to Out</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Device Control Register Bus control outputs</td>
<td>T_{PCKC_DCR}</td>
<td>1.67</td>
<td>1.84</td>
<td>ns, max</td>
<td></td>
</tr>
<tr>
<td>Device Control Register Bus address outputs</td>
<td>T_{PCKAO_DCR}</td>
<td>2.17</td>
<td>2.39</td>
<td>ns, max</td>
<td></td>
</tr>
<tr>
<td>Device Control Register Bus data outputs</td>
<td>T_{PCKDO_DCR}</td>
<td>2.22</td>
<td>2.44</td>
<td>ns, max</td>
<td></td>
</tr>
<tr>
<td>Clock and Power Management control outputs</td>
<td>T_{PCKC_CPM}</td>
<td>1.59</td>
<td>1.75</td>
<td>ns, max</td>
<td></td>
</tr>
<tr>
<td>Reset control outputs</td>
<td>T_{PCKC_RST}</td>
<td>1.66</td>
<td>1.83</td>
<td>ns, max</td>
<td></td>
</tr>
<tr>
<td>Debug control outputs</td>
<td>T_{PCKC_DBG}</td>
<td>2.44</td>
<td>2.69</td>
<td>ns, max</td>
<td></td>
</tr>
<tr>
<td>Trace control outputs</td>
<td>T_{PCKC_TRC}</td>
<td>1.71</td>
<td>1.88</td>
<td>ns, max</td>
<td></td>
</tr>
</tbody>
</table>

### Table 17: Processor Block PLB Switching Characteristics

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>-7</th>
<th>-6</th>
<th>-5</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Setup and Hold Relative to Clock (PLBCLK)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Processor Local Bus (ICU/DCU) control inputs</td>
<td>T_{PCCK_PLB}/T_{PCKC_PLB}</td>
<td>1.23/0.23</td>
<td>1.35/0.25</td>
<td>ns, min</td>
<td></td>
</tr>
<tr>
<td>Processor Local Bus (ICU/DCU) data inputs</td>
<td>T_{PDCK_PLB}/T_{PCKD_PLB}</td>
<td>0.78/0.20</td>
<td>0.86/0.22</td>
<td>ns, min</td>
<td></td>
</tr>
<tr>
<td>Clock to Out</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Processor Local Bus (ICU/DCU) control outputs</td>
<td>T_{PCKCO_PLB}</td>
<td>1.69</td>
<td>1.86</td>
<td>ns, max</td>
<td></td>
</tr>
<tr>
<td>Processor Local Bus (ICU/DCU) address bus outputs</td>
<td>T_{PCKAO_PLB}</td>
<td>1.47</td>
<td>1.61</td>
<td>ns, max</td>
<td></td>
</tr>
<tr>
<td>Processor Local Bus (ICU/DCU) data bus outputs</td>
<td>T_{PCKDO_PLB}</td>
<td>1.81</td>
<td>1.99</td>
<td>ns, max</td>
<td></td>
</tr>
<tr>
<td>Clock</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PLBCLK minimum pulse width, high</td>
<td>T_{PPWPH}</td>
<td></td>
<td></td>
<td>ns, min</td>
<td></td>
</tr>
<tr>
<td>PLBCLK minimum pulse width, low</td>
<td>T_{PPWL}</td>
<td></td>
<td></td>
<td>ns, min</td>
<td></td>
</tr>
</tbody>
</table>
### Table 18: Processor Block JTAG Switching Characteristics

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Speed Grade</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Setup and Hold Relative to Clock (JTAGC405TCK)</td>
<td></td>
<td>-7</td>
<td>-6</td>
</tr>
<tr>
<td>JTAG control inputs</td>
<td>$T_{PCKC_{-JTAG}/PCKC_{-JTAG}}$</td>
<td>0.80/0.70</td>
<td>0.88/0.77</td>
</tr>
<tr>
<td>JTAG reset input</td>
<td>$T_{PCKC_{-JTAG}/PCKC_{-JTAG}}$</td>
<td>0.80/0.70</td>
<td>0.88/0.77</td>
</tr>
<tr>
<td>Clock to Out</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>JTAG control outputs</td>
<td>$T_{PCKO_{-JTAG}}$</td>
<td>1.69</td>
<td>1.86</td>
</tr>
<tr>
<td>Clock</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>JTAGC405TCK minimum pulse width, high</td>
<td>$T_{JPWH}$</td>
<td></td>
<td></td>
</tr>
<tr>
<td>JTAGC405TCK minimum pulse width, low</td>
<td>$T_{JPWL}$</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### Table 19: PowerPC 405 Data-Side On-Chip Memory Switching Characteristics

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Speed Grade</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Setup and Hold Relative to Clock (BRAMDSOCMCLK)</td>
<td></td>
<td>-7</td>
<td>-6</td>
</tr>
<tr>
<td>Data-Side On-Chip Memory data bus inputs</td>
<td>$T_{PDCK_{-DSOCM}/PCKD_{-DSOCM}}$</td>
<td>0.92/1.05</td>
<td>1.02/1.15</td>
</tr>
<tr>
<td>Clock to Out</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Data-Side On-Chip Memory control outputs</td>
<td>$T_{PCKO_{-DSOCM}}$</td>
<td>2.63</td>
<td>2.90</td>
</tr>
<tr>
<td>Data-Side On-Chip Memory address bus outputs</td>
<td>$T_{PCKA_{-DSOCM}}$</td>
<td>3.20</td>
<td>3.52</td>
</tr>
<tr>
<td>Data-Side On-Chip Memory data bus outputs</td>
<td>$T_{PCKD_{-DSOCM}}$</td>
<td>1.13</td>
<td>1.25</td>
</tr>
<tr>
<td>Clock</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>BRAMDSOCMCLK minimum pulse width, high</td>
<td>$T_{DPWH}$</td>
<td></td>
<td></td>
</tr>
<tr>
<td>BRAMDSOCMCLK minimum pulse width, low</td>
<td>$T_{DPWL}$</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### Table 20: PowerPC 405 Instruction-Side On-Chip Memory Switching Characteristics

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Speed Grade</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Setup and Hold Relative to Clock (BRAMISOCMCLK)</td>
<td></td>
<td>-7</td>
<td>-6</td>
</tr>
<tr>
<td>Instruction-Side On-Chip Memory data bus inputs</td>
<td>$T_{PDCK_{-ISOCD/PCKD_{-ISOCD}}}$</td>
<td>1.02/0.86</td>
<td>1.12/0.95</td>
</tr>
<tr>
<td>Clock to Out</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Instruction-Side On-Chip Memory control outputs</td>
<td>$T_{PCKO_{-ISOCD}}$</td>
<td>1.68</td>
<td>1.85</td>
</tr>
<tr>
<td>Instruction-Side On-Chip Memory address bus outputs</td>
<td>$T_{PCKA_{-ISOCD}}$</td>
<td>2.05</td>
<td>2.25</td>
</tr>
<tr>
<td>Instruction-Side On-Chip Memory data bus outputs</td>
<td>$T_{PCKD_{-ISOCD}}$</td>
<td>1.20</td>
<td>1.32</td>
</tr>
<tr>
<td>Clock</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>BRAMISOCMCLK minimum pulse width, high</td>
<td>$T_{IPWH}$</td>
<td></td>
<td></td>
</tr>
<tr>
<td>BRAMISOCMCLK minimum pulse width, low</td>
<td>$T_{IPWL}$</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
RocketIO Transceiver Switching Characteristics

Table 21: RocketIO Reference Clock Switching Characteristics

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Conditions</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>REFCLK frequency range</td>
<td>F_GCLK</td>
<td>Full rate operation</td>
<td>40</td>
<td>156.25</td>
<td></td>
<td>MHz</td>
</tr>
<tr>
<td>REFCLK frequency range</td>
<td>F_GCLK</td>
<td>Half rate operation</td>
<td>62.2</td>
<td>100</td>
<td></td>
<td>MHz</td>
</tr>
<tr>
<td>REFCLK frequency tolerance</td>
<td>F_GTOL</td>
<td></td>
<td>±100</td>
<td></td>
<td></td>
<td>ppm</td>
</tr>
<tr>
<td>REFCLK rise time</td>
<td>T_RCLK</td>
<td>20% – 80%</td>
<td>75</td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>REFCLK fall time</td>
<td>T_FCLK</td>
<td>20% – 80%</td>
<td>75</td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>REFCLK duty cycle</td>
<td>T_DCREF</td>
<td></td>
<td>45</td>
<td>50</td>
<td>55</td>
<td>%</td>
</tr>
<tr>
<td>REFCLK total jitter</td>
<td>T_GJTT</td>
<td>peak-to-peak</td>
<td>40</td>
<td></td>
<td></td>
<td>ps</td>
</tr>
<tr>
<td>Clock recovery frequency acquisition time</td>
<td>T_LOCK</td>
<td></td>
<td>10</td>
<td></td>
<td></td>
<td>µs</td>
</tr>
<tr>
<td>Clock recovery phase acquisition time</td>
<td>T_PHASE</td>
<td></td>
<td>960</td>
<td></td>
<td></td>
<td>bits</td>
</tr>
</tbody>
</table>

Figure 1: Reference Clock (REFCLK) Timing Parameters

Table 22: RocketIO Receiver Switching Characteristics

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Conditions</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Receive total jitter tolerance</td>
<td>T_JTOL</td>
<td></td>
<td>0.65</td>
<td></td>
<td></td>
<td>UI(1)</td>
</tr>
<tr>
<td>Receive deterministic jitter tolerance</td>
<td>T_DJTOL</td>
<td></td>
<td>0.41</td>
<td></td>
<td></td>
<td>UI</td>
</tr>
<tr>
<td>Receive latency(2)</td>
<td>T_RXLAT</td>
<td></td>
<td>25</td>
<td>42</td>
<td></td>
<td>RXUSRCLK cycles</td>
</tr>
<tr>
<td>RXUSRCLK duty cycle</td>
<td>T_RXDC</td>
<td></td>
<td>45</td>
<td>50</td>
<td>55</td>
<td>%</td>
</tr>
<tr>
<td>RXUSRCLK2 duty cycle</td>
<td>T_RX2DC</td>
<td></td>
<td>45</td>
<td>50</td>
<td>55</td>
<td>%</td>
</tr>
<tr>
<td>Bit error rate</td>
<td>BER</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>10⁻¹²</td>
</tr>
</tbody>
</table>

Notes:
1. UI = Unit Interval
2. Receive latency delay from RXP/RXN to RXDATA
Table 23: RocketIO Transmitter Switching Characteristics

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Conditions</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Serial data rate, full-speed clock</td>
<td>$F_{GTX}$</td>
<td>Flipchip packages</td>
<td>0.800</td>
<td></td>
<td>3.125</td>
<td>Gb/s</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Wirebond packages</td>
<td>0.800</td>
<td></td>
<td>2.5</td>
<td>Gb/s</td>
</tr>
<tr>
<td>Serial data rate, half-speed clock</td>
<td>$F_{GTX}$</td>
<td>Flipchip packages</td>
<td>0.622</td>
<td></td>
<td>1.0</td>
<td>Gb/s</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Wirebond packages</td>
<td>0.622</td>
<td></td>
<td>1.0</td>
<td>Gb/s</td>
</tr>
<tr>
<td>Serial data output deterministic jitter</td>
<td>$T_{DJ}$</td>
<td></td>
<td>0.18</td>
<td></td>
<td></td>
<td>UI(1)</td>
</tr>
<tr>
<td>Serial data output random jitter</td>
<td>$T_{RJ}$</td>
<td></td>
<td>0.17</td>
<td></td>
<td></td>
<td>UI</td>
</tr>
<tr>
<td>TX rise time</td>
<td>$T_{RTX}$</td>
<td>20% – 80%</td>
<td>120</td>
<td></td>
<td></td>
<td>ps</td>
</tr>
<tr>
<td>TX fall time</td>
<td>$T_{FTX}$</td>
<td></td>
<td>120</td>
<td></td>
<td></td>
<td>ps</td>
</tr>
<tr>
<td>Transmit latency(2)</td>
<td>$T_{TXLAT}$</td>
<td>Including CRC</td>
<td>14</td>
<td>17</td>
<td></td>
<td>TXUSR CLK cycles</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Excluding CRC</td>
<td>8</td>
<td>11</td>
<td></td>
<td>TXUSR CLK cycles</td>
</tr>
<tr>
<td>TXUSRCLK duty cycle</td>
<td>$T_{TXDC}$</td>
<td></td>
<td>45</td>
<td>50</td>
<td>55</td>
<td>%</td>
</tr>
<tr>
<td>TXUSRCLK2 duty cycle</td>
<td>$T_{TX2DC}$</td>
<td></td>
<td>45</td>
<td>50</td>
<td>55</td>
<td>%</td>
</tr>
</tbody>
</table>

Notes:
1. UI = Unit Interval
2. Transmit latency delay from TXDATA to TXP/TXN
### Table 24: RocketIO RXUSRCLK Switching Characteristics

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>-7</th>
<th>-6</th>
<th>-5</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Setup and Hold Relative to Clock (RXUSRCLK)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CHBONDI control inputs</td>
<td>$T_{GCCK_CHBI}/T_{GCKC_CHBI}$</td>
<td>0.00/0.12</td>
<td>0.00/0.12</td>
<td>0.00/0.14</td>
<td>ns, min</td>
</tr>
<tr>
<td>Clock to Out</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CHBONDO control outputs</td>
<td>$T_{GCKCO_CHBO}$</td>
<td>0.50</td>
<td>0.50</td>
<td>0.55</td>
<td>ns, max</td>
</tr>
<tr>
<td>Clock</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RXUSRCLK minimum pulse width, High</td>
<td>$T_{GPWH_RX}$</td>
<td>0.80</td>
<td>0.80</td>
<td>0.88</td>
<td>ns, min</td>
</tr>
<tr>
<td>RXUSRCLK minimum pulse width, Low</td>
<td>$T_{GPWL_RX}$</td>
<td>0.40</td>
<td>0.40</td>
<td>0.44</td>
<td>ns, min</td>
</tr>
</tbody>
</table>

### Table 25: RocketIO RXUSRCLK2 Switching Characteristics

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>-7</th>
<th>-6</th>
<th>-5</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Setup and Hold Relative to Clock (RXUSRCLK2)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RXRESET control input</td>
<td>$T_{GCCK_RRST}/T_{GCKC_RRST}$</td>
<td>0.02/0.00</td>
<td>0.02/0.00</td>
<td>0.02/0.00</td>
<td>ns, min</td>
</tr>
<tr>
<td>RXPOLARITY control input</td>
<td>$T_{GCCK_RPOL}/T_{GCKC_RPOL}$</td>
<td>0.02/0.00</td>
<td>0.02/0.00</td>
<td>0.02/0.00</td>
<td>ns, min</td>
</tr>
<tr>
<td>ENCHANSYNC control input</td>
<td>$T_{GCCK_ECSY}/T_{GCKC_ECSY}$</td>
<td>0.02/0.00</td>
<td>0.02/0.00</td>
<td>0.02/0.00</td>
<td>ns, min</td>
</tr>
<tr>
<td>Clock to Out</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RXNOTINTABLE status outputs</td>
<td>$T_{GCKST_RNIT}$</td>
<td>0.50</td>
<td>0.50</td>
<td>0.55</td>
<td>ns, max</td>
</tr>
<tr>
<td>RXDISPERR status outputs</td>
<td>$T_{GCKST_RDERR}$</td>
<td>0.50</td>
<td>0.50</td>
<td>0.55</td>
<td>ns, max</td>
</tr>
<tr>
<td>RXCHARISCOMMA status outputs</td>
<td>$T_{GCKST_RCMCH}$</td>
<td>0.50</td>
<td>0.50</td>
<td>0.55</td>
<td>ns, max</td>
</tr>
<tr>
<td>RXREALIGN status output</td>
<td>$T_{GCKST_ALIGN}$</td>
<td>0.41</td>
<td>0.41</td>
<td>0.46</td>
<td>ns, max</td>
</tr>
<tr>
<td>RXCOMMADET status output</td>
<td>$T_{GCKST_CMDT}$</td>
<td>0.41</td>
<td>0.41</td>
<td>0.46</td>
<td>ns, max</td>
</tr>
<tr>
<td>RXLOSSOSYNC status outputs</td>
<td>$T_{GCKST_RLOS}$</td>
<td>0.50</td>
<td>0.50</td>
<td>0.55</td>
<td>ns, max</td>
</tr>
<tr>
<td>RXCLKCORCNT status outputs</td>
<td>$T_{GCKST_RCCCNT}$</td>
<td>0.41</td>
<td>0.41</td>
<td>0.46</td>
<td>ns, max</td>
</tr>
<tr>
<td>RXBUFSTATUS status outputs</td>
<td>$T_{GCKST_RBSTA}$</td>
<td>0.45</td>
<td>0.45</td>
<td>0.50</td>
<td>ns, max</td>
</tr>
<tr>
<td>RXCHECKINGCRC status output</td>
<td>$T_{GCKST_RCCRC}$</td>
<td>0.36</td>
<td>0.40</td>
<td>0.44</td>
<td>ns, max</td>
</tr>
<tr>
<td>RXCRCERR status output</td>
<td>$T_{GCKST_RCRCE}$</td>
<td>0.36</td>
<td>0.40</td>
<td>0.44</td>
<td>ns, max</td>
</tr>
<tr>
<td>CHBONDDONE status output</td>
<td>$T_{GCKST_CHBD}$</td>
<td>0.50</td>
<td>0.50</td>
<td>0.55</td>
<td>ns, max</td>
</tr>
<tr>
<td>RXCHARISK status outputs</td>
<td>$T_{GCKST_RKCH}$</td>
<td>0.50</td>
<td>0.50</td>
<td>0.55</td>
<td>ns, max</td>
</tr>
<tr>
<td>RXRUNDISP status outputs</td>
<td>$T_{GCKST_RRDIS}$</td>
<td>0.50</td>
<td>0.50</td>
<td>0.55</td>
<td>ns, max</td>
</tr>
<tr>
<td>RXDATA data outputs</td>
<td>$T_{GCKDO_RDAT}$</td>
<td>0.50</td>
<td>0.50</td>
<td>0.55</td>
<td>ns, max</td>
</tr>
<tr>
<td>Clock</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RXUSRCLK2 minimum pulse width, High</td>
<td>$T_{GPWH_RX2}$</td>
<td>0.40</td>
<td>0.40</td>
<td>0.44</td>
<td>ns, min</td>
</tr>
<tr>
<td>RXUSRCLK2 minimum pulse width, Low</td>
<td>$T_{GPWL_RX2}$</td>
<td>0.20</td>
<td>0.20</td>
<td>0.22</td>
<td>ns, min</td>
</tr>
<tr>
<td>Description</td>
<td>Symbol</td>
<td>-7</td>
<td>-6</td>
<td>-5</td>
<td>Units</td>
</tr>
<tr>
<td>------------------------------------------------------------------------------</td>
<td>-----------------------</td>
<td>----------</td>
<td>----------</td>
<td>----------</td>
<td>-----------</td>
</tr>
<tr>
<td><strong>Setup and Hold Relative to Clock (TXUSRCLK2)</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CONFIGENABLE control input</td>
<td>T_GCCK_CFGEN/T_GCCK_CFGEN</td>
<td>0.35/0.10</td>
<td>0.35/0.10</td>
<td>0.39/ 0.11</td>
<td>ns, min</td>
</tr>
<tr>
<td>TXBYPASS8B10B control inputs</td>
<td>T_GCCK_TBP/T_GCCK_TBPY</td>
<td>0.02/0.00</td>
<td>0.02/0.00</td>
<td>0.02/ 0.00</td>
<td>ns, min</td>
</tr>
<tr>
<td>TXFORCECRCERR control input</td>
<td>T_GCCK_TCRCE/T_GCCK_TCRCE</td>
<td>0.39/0.12</td>
<td>0.44/0.14</td>
<td>0.49/ 0.15</td>
<td>ns, min</td>
</tr>
<tr>
<td>TXPOLARITY control input</td>
<td>T_GCCK_TPOL/T_GCCK_TPOL</td>
<td>0.02/0.00</td>
<td>0.02/0.00</td>
<td>0.02/ 0.00</td>
<td>ns, min</td>
</tr>
<tr>
<td>TXINHIBIT control inputs</td>
<td>T_GCCK_TINH/T_GCCK_TINH</td>
<td>0.02/0.00</td>
<td>0.02/0.00</td>
<td>0.02/ 0.00</td>
<td>ns, min</td>
</tr>
<tr>
<td>LOOPBACK control inputs</td>
<td>T_GCCK_LBK/T_GCCK_LBK</td>
<td>0.02/0.00</td>
<td>0.02/0.00</td>
<td>0.02/ 0.00</td>
<td>ns, min</td>
</tr>
<tr>
<td>TXRESET control input</td>
<td>T_GCCK_TRST/T_GCCK_TRST</td>
<td>0.02/0.10</td>
<td>0.02/0.10</td>
<td>0.02/ 0.11</td>
<td>ns, min</td>
</tr>
<tr>
<td>TXCHARISK control inputs</td>
<td>T_GCCK_TKCH/T_GCCK_TKCH</td>
<td>0.02/0.00</td>
<td>0.02/0.00</td>
<td>0.02/ 0.00</td>
<td>ns, min</td>
</tr>
<tr>
<td>TXCHARDISPMODE control inputs</td>
<td>T_GCCK_TCDM/T_GCCK_TCDM</td>
<td>0.02/0.00</td>
<td>0.02/0.00</td>
<td>0.02/ 0.00</td>
<td>ns, min</td>
</tr>
<tr>
<td>TXCHARDISPVAL control inputs</td>
<td>T_GCCK_TCDV/T_GCCK_TCDV</td>
<td>0.02/0.00</td>
<td>0.02/0.00</td>
<td>0.02/ 0.00</td>
<td>ns, min</td>
</tr>
<tr>
<td>CONFIGIN data input</td>
<td>T_GCCK_CFGIN/T_GCCK_CFGIN</td>
<td>0.35/0.10</td>
<td>0.35/0.10</td>
<td>0.39/ 0.11</td>
<td>ns, min</td>
</tr>
<tr>
<td>TXDATA data inputs</td>
<td>T_GCCK_TDAT/T_GCCK_TDAT</td>
<td>0.02/0.00</td>
<td>0.02/0.00</td>
<td>0.02/ 0.00</td>
<td>ns, min</td>
</tr>
<tr>
<td><strong>Clock to Out</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>TXBUFERR status output</td>
<td>T_GCCKST_TBERR</td>
<td>0.54</td>
<td>0.54</td>
<td>0.60</td>
<td>ns, max</td>
</tr>
<tr>
<td>TXERR status outputs</td>
<td>T_GCCKST_TKERR</td>
<td>0.41</td>
<td>0.41</td>
<td>0.46</td>
<td>ns, max</td>
</tr>
<tr>
<td>TXRUNDISP status outputs</td>
<td>T_GCCKST_TRDIS</td>
<td>0.41</td>
<td>0.41</td>
<td>0.46</td>
<td>ns, max</td>
</tr>
<tr>
<td>CONFIGOUT data output</td>
<td>T_GCCKD_CFGOUT</td>
<td>0.25</td>
<td>0.25</td>
<td>0.28</td>
<td>ns, max</td>
</tr>
<tr>
<td><strong>Clock</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>TXUSRCLK minimum pulse width, High</td>
<td>T_GPWH_TX</td>
<td>0.80</td>
<td>0.80</td>
<td>0.88</td>
<td>ns, min</td>
</tr>
<tr>
<td>TXUSRCLK minimum pulse width, Low</td>
<td>T_GPWL_TX</td>
<td>0.40</td>
<td>0.40</td>
<td>0.44</td>
<td>ns, min</td>
</tr>
<tr>
<td>TXUSRCLK2 minimum pulse width, High</td>
<td>T_GPWH_TX2</td>
<td>0.40</td>
<td>0.40</td>
<td>0.44</td>
<td>ns, min</td>
</tr>
<tr>
<td>TXUSRCLK2 minimum pulse width, Low</td>
<td>T_GPWL_TX2</td>
<td>0.20</td>
<td>0.20</td>
<td>0.22</td>
<td>ns, min</td>
</tr>
</tbody>
</table>
IOB Input Switching Characteristics

Input delays associated with the pad are specified for LVCMOS 2.5V levels. For other standards, adjust the delays with the values shown in IOB Input Switching Characteristics Standard Adjustments.

**Table 27: IOB Input Switching Characteristics**

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Device</th>
<th>-7</th>
<th>-6</th>
<th>-5</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Propagation Delays</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Pad to I output, no delay</td>
<td>$T_{IOPI}$</td>
<td>All</td>
<td>0.75</td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td>Pad to I output, with delay</td>
<td>$T_{IOPID}$</td>
<td>XC2VP2</td>
<td>1.99</td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP4</td>
<td>1.99</td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP7</td>
<td>1.99</td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP20</td>
<td>2.40</td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP30</td>
<td></td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP40</td>
<td></td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP50</td>
<td></td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP70</td>
<td></td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP100</td>
<td></td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP125</td>
<td></td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td><strong>Propagation Delays</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Pad to output IQ via transparent latch, no delay</td>
<td>$T_{IOPLI}$</td>
<td>All</td>
<td>0.96</td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td>Pad to output IQ via transparent latch, with delay</td>
<td>$T_{IOPLID}$</td>
<td>XC2VP2</td>
<td>3.76</td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP4</td>
<td>3.76</td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP7</td>
<td>3.76</td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP20</td>
<td>4.21</td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP30</td>
<td></td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP40</td>
<td></td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP50</td>
<td></td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP70</td>
<td></td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP100</td>
<td></td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP125</td>
<td></td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td>Clock CLK to output IQ</td>
<td>$T_{IOCKIQ}$</td>
<td>All</td>
<td>0.71</td>
<td></td>
<td></td>
<td>ns, max</td>
</tr>
<tr>
<td><strong>Setup and Hold Times With Respect to Clock at IOB Input Register</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Pad, no delay</td>
<td>$T_{IOPICK}/T_{IOICKP}$</td>
<td>All</td>
<td>0.74</td>
<td>–0.40</td>
<td></td>
<td>ns, min</td>
</tr>
</tbody>
</table>
Table 27: IOB Input Switching Characteristics (Continued)

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Device</th>
<th>Speed Grade</th>
</tr>
</thead>
<tbody>
<tr>
<td>Pad, with delay</td>
<td>$T_{IOPICKD}$/$T_{IOICKPD}$</td>
<td>XC2VP2</td>
<td>4.07/–2.73 ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP4</td>
<td>4.07/–2.73 ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP7</td>
<td>4.07/–2.73 ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP20</td>
<td>4.47/–3.01 ns, max</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP30</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP40</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP50</td>
<td>5.12/–3.46 ns, max</td>
</tr>
<tr>
<td>ICE input</td>
<td>$T_{IOICECK}$/$T_{IOICKICE}$</td>
<td>All</td>
<td>0.39/ 0.01 ns, min</td>
</tr>
<tr>
<td>SR input (IFF, synchronous)</td>
<td>$T_{IOSRCKI}$</td>
<td>All</td>
<td>0.77 ns, min</td>
</tr>
<tr>
<td>Set/Reset Delays</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SR input to IQ (asynchronous)</td>
<td>$T_{IOSRIQ}$</td>
<td>All</td>
<td>1.58 ns, max</td>
</tr>
<tr>
<td>GSR to output IQ</td>
<td>$T_{GSRQ}$</td>
<td>All</td>
<td>10.00 ns, max</td>
</tr>
</tbody>
</table>

Notes:
1. Input timing for LVCMOS25 is measured at 1.25V. For other I/O standards, see Table 31.
## IOB Input Switching Characteristics Standard Adjustments

Table 28: IOB Input Switching Characteristics Standard Adjustments

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Standard</th>
<th>-7</th>
<th>-6</th>
<th>-5</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Data Input Delay Adjustments</td>
<td>T_{ILVCMOS25}</td>
<td>LVCMOS25</td>
<td>0.00</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{ILVCMOS18}</td>
<td>LVCMOS18</td>
<td>0.26</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{ILVCMOS15}</td>
<td>LVCMOS15</td>
<td>0.43</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{LVDS_25}</td>
<td>LVDS_25</td>
<td>0.35</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{PCI33_3}</td>
<td>PCI, 33 MHz, 3.3V</td>
<td>0.15</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{PCI66_3}</td>
<td>PCI, 66 MHz, 3.3V</td>
<td>0.15</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{GTLP}</td>
<td>GTLP</td>
<td>0.66</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{GTLP}</td>
<td>GTLP</td>
<td>0.66</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{HSTL_I}</td>
<td>HSTL_I</td>
<td>0.72</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{HSTL_II}</td>
<td>HSTL_II</td>
<td>0.69</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{HSTL_III}</td>
<td>HSTL_III</td>
<td>0.70</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{HSTL_IV}</td>
<td>HSTL_IV</td>
<td>0.71</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{HSTL_I_18}</td>
<td>HSTL_I_18</td>
<td>0.72</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{HSTL_II_18}</td>
<td>HSTL_II_18</td>
<td>0.69</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{HSTL_III_18}</td>
<td>HSTL_III_18</td>
<td>0.70</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{HSTL_IV_18}</td>
<td>HSTL_IV_18</td>
<td>0.71</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{SSTL2_I}</td>
<td>SSTL2_I</td>
<td>0.56</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{SSTL2_II}</td>
<td>SSTL2_II</td>
<td>0.65</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{LVDCI33}</td>
<td>LVDCI_33</td>
<td>-0.05</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{LVDCI25}</td>
<td>LVDCI_25</td>
<td>0.00</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{LVDCI18}</td>
<td>LVDCI_18</td>
<td>0.08</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{LVDCI15}</td>
<td>LVDCI_15</td>
<td>0.15</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{LVDCI_DV2_25}</td>
<td>LVDCI_DV2_25</td>
<td>0.00</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{LVDCI_DV2_18}</td>
<td>LVDCI_DV2_18</td>
<td>0.08</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{LVDCI_DV2_15}</td>
<td>LVDCI_DV2_15</td>
<td>0.15</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{GTLP_DCI}</td>
<td>GTLP_DCI</td>
<td>0.54</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{GTLP_DCI}</td>
<td>GTLP_DCI</td>
<td>0.30</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{HSTL_I_DCI}</td>
<td>HSTL_I_DCI</td>
<td>0.30</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{HSTL_II_DCI}</td>
<td>HSTL_II_DCI</td>
<td>0.30</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{HSTL_III_DCI}</td>
<td>HSTL_III_DCI</td>
<td>0.30</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{HSTL_IV_DCI}</td>
<td>HSTL_IV_DCI</td>
<td>0.30</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{HSTL_I_DCI_18}</td>
<td>HSTL_I_DCI_18</td>
<td>0.30</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{HSTL_II_DCI_18}</td>
<td>HSTL_II_DCI_18</td>
<td>0.30</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>T_{HSTL_III_DCI_18}</td>
<td>HSTL_III_DCI_18</td>
<td>0.30</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
### Table 28: IOB Input Switching Characteristics Standard Adjustments (Continued)

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Standard</th>
<th>Speed Grade</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td>-7</td>
</tr>
<tr>
<td>TIHSTL_IV_DCI_18</td>
<td>HSTL_IV_DCI_18</td>
<td></td>
<td>0.30</td>
</tr>
<tr>
<td>TISSSTL2_I_DCI</td>
<td>SSTL2_I_DCI</td>
<td></td>
<td>0.19</td>
</tr>
<tr>
<td>TISSSTL2_II_DCI</td>
<td>SSTL2_II_DCI</td>
<td></td>
<td>0.19</td>
</tr>
<tr>
<td>TILVDSEXT_25</td>
<td>LVDSEXT_25</td>
<td></td>
<td>0.35</td>
</tr>
<tr>
<td>TILDT_25</td>
<td>LDT_25</td>
<td></td>
<td>0.34</td>
</tr>
<tr>
<td>TIBLVDS_25</td>
<td>BLVDS_25</td>
<td></td>
<td>0.00</td>
</tr>
<tr>
<td>TIVULVDS_25</td>
<td>ULVDS_25</td>
<td></td>
<td>0.34</td>
</tr>
<tr>
<td>TILVDS_25_DCI</td>
<td>LVDS_25_DCI</td>
<td></td>
<td>0.19</td>
</tr>
<tr>
<td>TILVDSEXT_25_DCI</td>
<td>LVDSEXT_25_DCI</td>
<td></td>
<td>0.35</td>
</tr>
<tr>
<td>TILVPECL_25</td>
<td>LVPECL_25</td>
<td></td>
<td>0.76</td>
</tr>
<tr>
<td>TISSSTL18_I</td>
<td>SSTL18_I</td>
<td></td>
<td>0.56</td>
</tr>
<tr>
<td>TISSSTL18_II</td>
<td>SSTL18_II</td>
<td></td>
<td>0.65</td>
</tr>
<tr>
<td>TISSSTL18_I_DCI</td>
<td>SSTL18_I_DCI</td>
<td></td>
<td>0.56</td>
</tr>
<tr>
<td>TISSSTL18_II_DCI</td>
<td>SSTL18_II_DCI</td>
<td></td>
<td>0.65</td>
</tr>
</tbody>
</table>
IOB Output Switching Characteristics

Output delays terminating at a pad are specified for LVCMOS25 with 12 mA drive and fast slew rate. For other standards, adjust the delays with the values shown in IOB Output Switching Characteristics Standard Adjustments.

### Table 29: IOB Output Switching Characteristics

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Speed Grade</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Propagation Delays</strong></td>
<td></td>
<td>-7</td>
<td>-6</td>
</tr>
<tr>
<td>O input to Pad</td>
<td>$T_{IOOP}$</td>
<td>3.42</td>
<td>ns, max</td>
</tr>
<tr>
<td>O input to Pad via transparent latch</td>
<td>$T_{IOOLLP}$</td>
<td>3.55</td>
<td>ns, max</td>
</tr>
<tr>
<td><strong>3-State Delays</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>T input to Pad high-impedance(^{(2)})</td>
<td>$T_{ITOTHZ}$</td>
<td>0.88</td>
<td>ns, max</td>
</tr>
<tr>
<td>T input to valid data on Pad</td>
<td>$T_{IOTP}$</td>
<td>3.45</td>
<td>ns, max</td>
</tr>
<tr>
<td>T input to Pad high-impedance via</td>
<td>$T_{IOTLPHZ}$</td>
<td>0.90</td>
<td>ns, max</td>
</tr>
<tr>
<td>transparent latch(^{(2)})</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>T input to valid data on Pad via</td>
<td>$T_{IOTLPON}$</td>
<td>3.49</td>
<td>ns, max</td>
</tr>
<tr>
<td>transparent latch</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>GTS to Pad high-impedance(^{(2)})</td>
<td>$T_{GTS}$</td>
<td>7.78</td>
<td>ns, max</td>
</tr>
<tr>
<td><strong>Sequential Delays</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Clock CLK to Pad</td>
<td>$T_{IOCKP}$</td>
<td>3.59</td>
<td>ns, max</td>
</tr>
<tr>
<td>Clock CLK to Pad high-impedance (synchronous)(^{(2)})</td>
<td>$T_{IOCKHZ}$</td>
<td>1.28</td>
<td>ns, max</td>
</tr>
<tr>
<td>Clock CLK to valid data on Pad (synchronous)</td>
<td>$T_{IOCKON}$</td>
<td>3.85</td>
<td>ns, max</td>
</tr>
<tr>
<td><strong>Setup and Hold Times Before/After Clock CLK</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>O input</td>
<td>$T_{IOOCK}/T_{IOCKO}$</td>
<td>0.18/ 0.12</td>
<td>ns, min</td>
</tr>
<tr>
<td>OCE input</td>
<td>$T_{IOOCECK}/T_{IOCKOCE}$</td>
<td>0.39/ 0.01</td>
<td>ns, min</td>
</tr>
<tr>
<td>SR input (OFF)</td>
<td>$T_{IOSRCK}/T_{IOCKSRO}$</td>
<td>0.77/ 0.00</td>
<td>ns, min</td>
</tr>
<tr>
<td>3-State Setup Times, T input</td>
<td>$T_{IOTCK}/T_{IOCTK}$</td>
<td>0.18/ 0.12</td>
<td>ns, min</td>
</tr>
<tr>
<td>3-State Setup Times, TCE input</td>
<td>$T_{IOTCECK}/T_{IOCKTCE}$</td>
<td>0.39/ 0.01</td>
<td>ns, min</td>
</tr>
<tr>
<td>3-State Setup Times, SR input (TFF)</td>
<td>$T_{IOSRCKT}/T_{IOCKTSR}$</td>
<td>0.77/ 0.00</td>
<td>ns, min</td>
</tr>
<tr>
<td><strong>Set/Reset Delays</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SR input to Pad (asynchronous)</td>
<td>$T_{IOSR}$</td>
<td>4.57</td>
<td>ns, max</td>
</tr>
<tr>
<td>SR input to Pad high-impedance (asynchronous)(^{(2)})</td>
<td>$T_{IOSRHZ}$</td>
<td>1.93</td>
<td>ns, max</td>
</tr>
<tr>
<td>SR input to valid data on Pad (asynchronous)</td>
<td>$T_{IOSRON}$</td>
<td>4.51</td>
<td>ns, max</td>
</tr>
<tr>
<td>GSR to Pad</td>
<td>$T_{IOGSRQ}$</td>
<td>7.43</td>
<td>ns, max</td>
</tr>
</tbody>
</table>

**Notes:**
1. A Zero “0” Hold Time listing indicates no hold time or a negative hold time. Negative values can not be guaranteed “best-case”, but if a “0” is listed, there is no positive hold time.
2. The 3-state turn-off delays should not be adjusted.

### IOB Output Switching Characteristics Standard Adjustments

Output delays terminating at a pad are specified for LVCMOS25 with 12 mA drive and fast slew rate. For other standards,
adjust the delays by the values shown.

**Table 30: IOB Output Switching Characteristics Standard Adjustments**

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Standard</th>
<th>Speed Grade</th>
</tr>
</thead>
<tbody>
<tr>
<td>Standard-specific adjustments for output delays terminating at pads (based on standard capacitive load, Csl)</td>
<td>TOLVDS_25</td>
<td>LVDS</td>
<td>-0.77 ns</td>
</tr>
<tr>
<td></td>
<td>TOLVDSEX_25</td>
<td>LVDSEX</td>
<td>-0.64 ns</td>
</tr>
<tr>
<td></td>
<td>TOLDT_25</td>
<td>LDT</td>
<td>-0.63 ns</td>
</tr>
<tr>
<td></td>
<td>TOBLVDS_25</td>
<td>BLVDS</td>
<td>0.00 ns</td>
</tr>
<tr>
<td></td>
<td>TOULVDS_25</td>
<td>ULVDS</td>
<td>-0.63 ns</td>
</tr>
<tr>
<td></td>
<td>TOPCII33_3</td>
<td>PCI, 33 MHz, 3.3V</td>
<td>0.28 ns</td>
</tr>
<tr>
<td></td>
<td>TOPCII66_3</td>
<td>PCI, 66 MHz, 3.3V</td>
<td>0.31 ns</td>
</tr>
<tr>
<td></td>
<td>TOGTL</td>
<td>GTL</td>
<td>1.01 ns</td>
</tr>
<tr>
<td></td>
<td>TOGTLT</td>
<td>GTLP</td>
<td>3.38 ns</td>
</tr>
<tr>
<td></td>
<td>TOHSTLI</td>
<td>HSTL_I</td>
<td>0.01 ns</td>
</tr>
<tr>
<td></td>
<td>TOHSTLII</td>
<td>HSTL_II</td>
<td>-0.36 ns</td>
</tr>
<tr>
<td></td>
<td>TOHSTLIII</td>
<td>HSTL_III</td>
<td>-0.33 ns</td>
</tr>
<tr>
<td></td>
<td>TOHSTLv</td>
<td>HSTL_III</td>
<td>0.89 ns</td>
</tr>
<tr>
<td></td>
<td>TOHSJa_18</td>
<td>HSTL_I_18</td>
<td>-0.09 ns</td>
</tr>
<tr>
<td></td>
<td>TOHSb_18</td>
<td>HSTL_II_18</td>
<td>-0.47 ns</td>
</tr>
<tr>
<td></td>
<td>TOHSTc_18</td>
<td>HSTL_III_18</td>
<td>-0.36 ns</td>
</tr>
<tr>
<td></td>
<td>TOHSTIV</td>
<td>HSTL_IV</td>
<td>0.86 ns</td>
</tr>
<tr>
<td></td>
<td>TOHSTIVB_18</td>
<td>HSTL_IV_18</td>
<td>0.05 ns</td>
</tr>
<tr>
<td></td>
<td>TOSSTLI</td>
<td>SSTL2_I</td>
<td>-0.66 ns</td>
</tr>
<tr>
<td></td>
<td>TOSSTLII</td>
<td>SSTL2_II</td>
<td>-0.66 ns</td>
</tr>
<tr>
<td></td>
<td>TOLVCMOS25_S2</td>
<td>LVCMOS25, Slow, 2 mA</td>
<td>12.96 ns</td>
</tr>
<tr>
<td></td>
<td>TOLVCMOS25_S4</td>
<td>4 mA</td>
<td>6.42 ns</td>
</tr>
<tr>
<td></td>
<td>TOLVCMOS25_S6</td>
<td>6 mA</td>
<td>4.17 ns</td>
</tr>
<tr>
<td></td>
<td>TOLVCMOS25_S8</td>
<td>8 mA</td>
<td>2.61 ns</td>
</tr>
<tr>
<td></td>
<td>TOLVCMOS25_S12</td>
<td>12 mA</td>
<td>1.42 ns</td>
</tr>
<tr>
<td></td>
<td>TOLVCMOS25_S16</td>
<td>16 mA</td>
<td>0.83 ns</td>
</tr>
<tr>
<td></td>
<td>TOLVCMOS25_S24</td>
<td>24 mA</td>
<td>0.19 ns</td>
</tr>
<tr>
<td></td>
<td>TOLVCMOS25_F2</td>
<td>LVCMOS25, Fast, 2 mA</td>
<td>11.84 ns</td>
</tr>
<tr>
<td></td>
<td>TOLVCMOS25_F4</td>
<td>4 mA</td>
<td>4.74 ns</td>
</tr>
<tr>
<td></td>
<td>TOLVCMOS25_F6</td>
<td>6 mA</td>
<td>2.85 ns</td>
</tr>
<tr>
<td></td>
<td>TOLVCMOS25_F8</td>
<td>8 mA</td>
<td>1.22 ns</td>
</tr>
<tr>
<td></td>
<td>TOLVCMOS25_F12</td>
<td>12 mA</td>
<td>0.00 ns</td>
</tr>
<tr>
<td></td>
<td>TOLVCMOS25_F16</td>
<td>16 mA</td>
<td>-0.17 ns</td>
</tr>
<tr>
<td></td>
<td>TOLVCMOS25_F24</td>
<td>24 mA</td>
<td>-0.44 ns</td>
</tr>
<tr>
<td></td>
<td>TOLVCMOS18_S2</td>
<td>LVCMOS18, Slow, 2 mA</td>
<td>10.06 ns</td>
</tr>
<tr>
<td></td>
<td>TOLVCMOS18_S4</td>
<td>4 mA</td>
<td>6.26 ns</td>
</tr>
<tr>
<td></td>
<td>TOLVCMOS18_S6</td>
<td>6 mA</td>
<td>3.85 ns</td>
</tr>
</tbody>
</table>
### Table 30: IOB Output Switching Characteristics Standard Adjustments (Continued)

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Standard</th>
<th>-7</th>
<th>-6</th>
<th>-5</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Standard-specific adjustments for output delays terminating at pads (based on standard capacitive load, Csl)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS18_S8}$</td>
<td>8 mA</td>
<td></td>
<td>3.94</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS18_S12}$</td>
<td>12 mA</td>
<td></td>
<td>3.16</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS18_S16}$</td>
<td>16 mA</td>
<td></td>
<td>1.21</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS18_F2}$</td>
<td>LVCMOS18, Fast, 2 mA</td>
<td></td>
<td>8.83</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS18_F4}$</td>
<td>4 mA</td>
<td></td>
<td>3.46</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS18_F6}$</td>
<td>6 mA</td>
<td></td>
<td>1.69</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS18_F8}$</td>
<td>8 mA</td>
<td></td>
<td>1.24</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS18_F12}$</td>
<td>12 mA</td>
<td></td>
<td>0.49</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS18_F16}$</td>
<td>16 mA</td>
<td></td>
<td>–0.03 ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS15_S2}$</td>
<td>LVCMOS15, Slow, 2 mA</td>
<td></td>
<td>12.76</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS15_S4}$</td>
<td>4 mA</td>
<td></td>
<td>8.73</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS15_S6}$</td>
<td>6 mA</td>
<td></td>
<td>5.66</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS15_S8}$</td>
<td>8 mA</td>
<td></td>
<td>4.85</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS15_S12}$</td>
<td>12 mA</td>
<td></td>
<td>2.14</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS15_S16}$</td>
<td>16 mA</td>
<td></td>
<td>1.99</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS15_F2}$</td>
<td>LVCMOS15, Fast, 2 mA</td>
<td></td>
<td>7.84</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS15_F4}$</td>
<td>4 mA</td>
<td></td>
<td>4.10</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS15_F6}$</td>
<td>6 mA</td>
<td></td>
<td>1.34</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS15_F8}$</td>
<td>8 mA</td>
<td></td>
<td>2.32</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS15_F12}$</td>
<td>12 mA</td>
<td></td>
<td>0.12</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVCOS15_F16}$</td>
<td>16 mA</td>
<td></td>
<td>0.18</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVDCI33}$</td>
<td>LVDCI_33</td>
<td></td>
<td>1.89</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVDCI25}$</td>
<td>LVDCI_25</td>
<td></td>
<td>1.72</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVDCI18}$</td>
<td>LVDCI_18</td>
<td></td>
<td>2.61</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVDCI15}$</td>
<td>LVDCI_15</td>
<td></td>
<td>3.58</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVDCI_DV2_25}$</td>
<td>LVDCI_DV2_25</td>
<td></td>
<td>–0.02 ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVDCI_DV2_18}$</td>
<td>LVDCI_DV2_18</td>
<td></td>
<td>0.43</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OLVDCI_DV2_15}$</td>
<td>LVDCI_DV2_15</td>
<td></td>
<td>1.00</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OGTL_DCI}$</td>
<td>GTL_DCI</td>
<td></td>
<td>1.10</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OGTLP_DCI}$</td>
<td>GTLP_DCI</td>
<td></td>
<td>3.23</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OHSTL_I_DCI}$</td>
<td>HSTL_I_DCI</td>
<td></td>
<td>0.00</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OHSTL_II_DCI}$</td>
<td>HSTL_II_DCI</td>
<td></td>
<td>–0.22</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OHSTL_III_DCI}$</td>
<td>HSTL_III_DCI</td>
<td></td>
<td>–0.32</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OHSTL_IV_DCI}$</td>
<td>HSTL_IV_DCI</td>
<td></td>
<td>1.93</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OHSTL_I_DCI_18}$</td>
<td>HSTL_I_DCI_18</td>
<td></td>
<td>–0.13</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OHSTL_II_DCI_18}$</td>
<td>HSTL_II_DCI_18</td>
<td></td>
<td>–0.35</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OHSTL_III_DCI_18}$</td>
<td>HSTL_III_DCI_18</td>
<td></td>
<td>–0.40</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{OHSTL_IV_DCI_18}$</td>
<td>HSTL_IV_DCI_18</td>
<td></td>
<td>1.30</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
Table 30: IOB Output Switching Characteristics Standard Adjustments (Continued)

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Standard</th>
<th>Speed Grade</th>
</tr>
</thead>
<tbody>
<tr>
<td>Standard-specific adjustments for output delays terminating at pads (based on standard capacitive load, Csl)</td>
<td>T_{OSSTL2_I_DCI}</td>
<td>SSTL2_I_DCI</td>
<td>-0.15 ns</td>
</tr>
<tr>
<td></td>
<td>T_{OSSTL2_II_DCI}</td>
<td>SSTL2_II_DCI</td>
<td>-0.38 ns</td>
</tr>
<tr>
<td></td>
<td>T_{OLVPECL_25}</td>
<td>LVPECL_25</td>
<td>0.21 ns</td>
</tr>
<tr>
<td></td>
<td>T_{OSSTL18_I}</td>
<td>SSTL18_I</td>
<td>0.04 ns</td>
</tr>
<tr>
<td></td>
<td>T_{OSSTL18_II}</td>
<td>SSTL18_II</td>
<td>-0.66 ns</td>
</tr>
<tr>
<td></td>
<td>T_{OSSTL18_I_DCI}</td>
<td>SSTL18_I_DCI</td>
<td>-0.15 ns</td>
</tr>
<tr>
<td></td>
<td>T_{OSSTL18_II_DCI}</td>
<td>SSTL18_II_DCI</td>
<td>-0.39 ns</td>
</tr>
</tbody>
</table>

Table 31: Delay Measurement Methodology

<table>
<thead>
<tr>
<th>Standard</th>
<th>V_L(^{(1)})</th>
<th>V_H(^{(1)})</th>
<th>Meas. Point</th>
<th>V_{REF} ((\text{Typ}))^{(2)}</th>
</tr>
</thead>
<tbody>
<tr>
<td>LVCMOS25</td>
<td>0</td>
<td>2.5</td>
<td>1.25</td>
<td>–</td>
</tr>
<tr>
<td>LVCMOS18</td>
<td>0</td>
<td>1.8</td>
<td>0.9</td>
<td>–</td>
</tr>
<tr>
<td>LVCMOS15</td>
<td>0</td>
<td>1.5</td>
<td>0.75</td>
<td>–</td>
</tr>
<tr>
<td>PCI33_3</td>
<td>Per PCI Specification</td>
<td>–</td>
<td>Per PCI Specification</td>
<td>–</td>
</tr>
<tr>
<td>PCI66_3</td>
<td>Per PCI Specification</td>
<td>–</td>
<td>Per PCI Specification</td>
<td>–</td>
</tr>
<tr>
<td>GTL</td>
<td>V_{REF} - 0.2</td>
<td>V_{REF} + 0.2</td>
<td>V_{REF}</td>
<td>0.80</td>
</tr>
<tr>
<td>GTLP</td>
<td>V_{REF} - 0.2</td>
<td>V_{REF} + 0.2</td>
<td>V_{REF}</td>
<td>1.0</td>
</tr>
<tr>
<td>HSTL Class I</td>
<td>V_{REF} - 0.5</td>
<td>V_{REF} + 0.5</td>
<td>V_{REF}</td>
<td>0.75</td>
</tr>
<tr>
<td>HSTL Class II</td>
<td>V_{REF} - 0.5</td>
<td>V_{REF} + 0.5</td>
<td>V_{REF}</td>
<td>0.75</td>
</tr>
<tr>
<td>HSTL Class III</td>
<td>V_{REF} - 0.5</td>
<td>V_{REF} + 0.5</td>
<td>V_{REF}</td>
<td>0.90</td>
</tr>
<tr>
<td>HSTL Class IV</td>
<td>V_{REF} - 0.5</td>
<td>V_{REF} + 0.5</td>
<td>V_{REF}</td>
<td>0.90</td>
</tr>
<tr>
<td>HSTL Class I (1.8V)</td>
<td>V_{REF} - 0.5</td>
<td>V_{REF} + 0.5</td>
<td>V_{REF}</td>
<td>1.08</td>
</tr>
<tr>
<td>HSTL Class II (1.8V)</td>
<td>V_{REF} - 0.5</td>
<td>V_{REF} + 0.5</td>
<td>V_{REF}</td>
<td>1.08</td>
</tr>
<tr>
<td>HSTL Class III (1.8V)</td>
<td>V_{REF} - 0.5</td>
<td>V_{REF} + 0.5</td>
<td>V_{REF}</td>
<td>1.08</td>
</tr>
<tr>
<td>HSTL Class IV (1.8V)</td>
<td>V_{REF} - 0.5</td>
<td>V_{REF} + 0.5</td>
<td>V_{REF}</td>
<td>1.08</td>
</tr>
<tr>
<td>SSTL2 I &amp; II</td>
<td>V_{REF} - 0.75</td>
<td>V_{REF} + 0.75</td>
<td>V_{REF}</td>
<td>1.25</td>
</tr>
<tr>
<td>SSTL18 I &amp; II</td>
<td>V_{REF} - 0.5</td>
<td>V_{REF} + 0.5</td>
<td>V_{REF}</td>
<td>0.9</td>
</tr>
<tr>
<td>LVDS_25</td>
<td>1.2 – 0.125</td>
<td>1.2 + 0.125</td>
<td>1.2</td>
<td></td>
</tr>
<tr>
<td>LVDSEXT_25</td>
<td>1.2 – 0.125</td>
<td>1.2 + 0.125</td>
<td>1.2</td>
<td></td>
</tr>
<tr>
<td>ULVDS_25</td>
<td>0.6 – 0.125</td>
<td>0.6 + 0.125</td>
<td>0.6</td>
<td></td>
</tr>
<tr>
<td>LDT_25</td>
<td>0.6 – 0.125</td>
<td>0.6 + 0.125</td>
<td>0.6</td>
<td></td>
</tr>
</tbody>
</table>

Notes:
1. Input waveform switches between V_L and V_H.
2. Measurements are made at V_{REF} \((\text{Typ})\), Maximum, and Minimum. Worst-case values are reported.
### Table 32: Standard Capacitive Loads

<table>
<thead>
<tr>
<th>Standard</th>
<th>Csl (pF)</th>
</tr>
</thead>
<tbody>
<tr>
<td>LVCMOS25</td>
<td>35</td>
</tr>
<tr>
<td>LVCMOS18</td>
<td>35</td>
</tr>
<tr>
<td>LVCMOS15</td>
<td>35</td>
</tr>
<tr>
<td>PCI 33MHz 3.3V</td>
<td>10</td>
</tr>
<tr>
<td>PCI 66 MHz 3.3V</td>
<td>10</td>
</tr>
<tr>
<td>GTL</td>
<td>10</td>
</tr>
<tr>
<td>GTLP</td>
<td>10</td>
</tr>
<tr>
<td>HSTL Class I (1.5V and 1.8V)</td>
<td>10</td>
</tr>
<tr>
<td>HSTL Class II (1.5Vand 1.8V)</td>
<td>10</td>
</tr>
<tr>
<td>HSTL Class III (1.5Vand 1.8V)</td>
<td>10</td>
</tr>
<tr>
<td>HSTL Class IV (1.5Vand 1.8V)</td>
<td>10</td>
</tr>
<tr>
<td>SSTL2 Class I</td>
<td>10</td>
</tr>
<tr>
<td>SSTL2 Class II</td>
<td>10</td>
</tr>
<tr>
<td>SSTL18 Class I</td>
<td>10</td>
</tr>
<tr>
<td>SSTL18 Class II</td>
<td>10</td>
</tr>
</tbody>
</table>

**Notes:**
1. I/O parameter measurements are made with the capacitance values shown above.
2. I/O standard measurements are reflected in the IBIS model information except where the IBIS format precludes it.
3. Use of IBIS models results in a more accurate prediction of the propagation delay:
   a. Model the output in an IBIS simulation into the standard capacitive load.
   b. Record the relative time to the $V_{OH}$ or $V_{OL}$ transition of interest.
   c. Remove the capacitance, and model the actual PCB traces (transmission lines) and actual loads from the appropriate IBIS models for driven devices.
   d. Record the results from the new simulation.
   e. Compare with the capacitance simulation. The increase or decrease in delay from the capacitive load delay simulation should be added or subtracted from the value above to predict the actual delay.
## CLB Switching Characteristics

Delays originating at F/G inputs vary slightly according to the input used (see Figure 24 in Module 1 of this data sheet). The values listed below are worst-case. Precise values are provided by the timing analyzer.

### Table 33: CLB Switching Characteristics

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>-7</th>
<th>-6</th>
<th>-5</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Combinatorial Delays</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4-input function: F/G inputs to X/Y outputs</td>
<td>$T_{ILO}$</td>
<td>0.29</td>
<td>0.33</td>
<td>0.37</td>
<td>ns, max</td>
</tr>
<tr>
<td>5-input function: F/G inputs to F5 output</td>
<td>$T_{IFS}$</td>
<td>0.62</td>
<td>0.70</td>
<td>0.77</td>
<td>ns, max</td>
</tr>
<tr>
<td>5-input function: F/G inputs to X output</td>
<td>$T_{IF5X}$</td>
<td>0.59</td>
<td>0.67</td>
<td>0.74</td>
<td>ns, max</td>
</tr>
<tr>
<td>FXINA or FXINB inputs to Y output via MUXFX</td>
<td>$T_{IFXY}$</td>
<td>0.30</td>
<td>0.34</td>
<td>0.38</td>
<td>ns, max</td>
</tr>
<tr>
<td>FXINA input to FX output via MUXFX</td>
<td>$T_{INAFX}$</td>
<td>0.29</td>
<td>0.33</td>
<td>0.36</td>
<td>ns, max</td>
</tr>
<tr>
<td>FXINB input to FX output via MUXFX</td>
<td>$T_{INBFX}$</td>
<td>0.29</td>
<td>0.33</td>
<td>0.36</td>
<td>ns, max</td>
</tr>
<tr>
<td>SOPIN input to SOPOUT output via ORCY</td>
<td>$T_{SOPSOP}$</td>
<td>0.22</td>
<td>0.25</td>
<td>0.27</td>
<td>ns, max</td>
</tr>
<tr>
<td>Incremental delay routing through transparent latch to XQ/YQ outputs</td>
<td>$T_{IFNCTL}$</td>
<td>0.28</td>
<td>0.32</td>
<td>0.35</td>
<td>ns, max</td>
</tr>
<tr>
<td><strong>Sequential Delays</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>FF Clock CLK to XQ/YQ outputs</td>
<td>$T_{CKO}$</td>
<td>0.32</td>
<td>0.36</td>
<td>0.40</td>
<td>ns, max</td>
</tr>
<tr>
<td>Latch Clock CLK to XQ/YQ outputs</td>
<td>$T_{CKLO}$</td>
<td>0.58</td>
<td>0.66</td>
<td>0.73</td>
<td>ns, max</td>
</tr>
<tr>
<td><strong>Setup and Hold Times Before/After Clock CLK</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>BX/BY inputs</td>
<td>$T_{DICK}/T_{CKDI}$</td>
<td>0.23/–0.06</td>
<td>0.26/–0.07</td>
<td>0.29/–0.08</td>
<td>ns, min</td>
</tr>
<tr>
<td>DY inputs</td>
<td>$T_{DYCK}/T_{CKDY}$</td>
<td>0.01/0.09</td>
<td>0.01/0.11</td>
<td>0.01/0.12</td>
<td>ns, min</td>
</tr>
<tr>
<td>DX inputs</td>
<td>$T_{DXCK}/T_{CKDX}$</td>
<td>0.01/0.09</td>
<td>0.01/0.11</td>
<td>0.01/0.12</td>
<td>ns, min</td>
</tr>
<tr>
<td>CE input</td>
<td>$T_{CECK}/T_{CKCE}$</td>
<td>0.31/0.01</td>
<td>0.35/0.01</td>
<td>0.39/0.01</td>
<td>ns, min</td>
</tr>
<tr>
<td>SR/BY inputs (synchronous)</td>
<td>$T_{RCK}/T_{CKR}$</td>
<td>0.69/–0.01</td>
<td>0.79/–0.01</td>
<td>0.87/–0.01</td>
<td>ns, min</td>
</tr>
<tr>
<td><strong>Clock CLK</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Minimum Pulse Width, High</td>
<td>$T_{CH}$</td>
<td>0.37</td>
<td>0.42</td>
<td>0.46</td>
<td>ns, min</td>
</tr>
<tr>
<td>Minimum Pulse Width, Low</td>
<td>$T_{CL}$</td>
<td>0.37</td>
<td>0.42</td>
<td>0.46</td>
<td>ns, min</td>
</tr>
<tr>
<td><strong>Set/Reset</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Minimum Pulse Width, SR/BY inputs</td>
<td>TRPW</td>
<td>0.37</td>
<td>0.42</td>
<td>0.46</td>
<td>ns, min</td>
</tr>
<tr>
<td>Delay from SR/BY inputs to XQ/YQ outputs (asynchronous)</td>
<td>TRQ</td>
<td>1.16</td>
<td>1.32</td>
<td>1.45</td>
<td>ns, max</td>
</tr>
<tr>
<td>Toggle Frequency (MHz) (for export control)</td>
<td>FTOG</td>
<td>1350</td>
<td>1200</td>
<td>1050</td>
<td>MHz</td>
</tr>
</tbody>
</table>

### Notes:
1. A Zero “0” Hold Time listing indicates no hold time or a negative hold time. Negative values cannot be guaranteed “best-case”, but if a “0” is listed, there is no positive hold time.
CLB Distributed RAM Switching Characteristics

Table 34: CLB Distributed RAM Switching Characteristics

<table>
<thead>
<tr>
<th>Speed Grade</th>
<th>Description</th>
<th>Symbol</th>
<th>-7</th>
<th>-6</th>
<th>-5</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Sequential Delays</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Clock CLK to X/Y outputs (WE active) in 16 x 1 mode</td>
<td>$T_{SHCKO16}$</td>
<td>1.30</td>
<td>1.48</td>
<td>1.63</td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td>Clock CLK to X/Y outputs (WE active) in 32 x 1 mode</td>
<td>$T_{SHCKO32}$</td>
<td>1.56</td>
<td>1.78</td>
<td>1.96</td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td>Clock CLK to F5 output</td>
<td>$T_{SHCKOF5}$</td>
<td>1.56</td>
<td>1.78</td>
<td>1.96</td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td>Setup and Hold Times Before/After Clock CLK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>BX/BY data inputs (DIN)</td>
<td>$T_{DS/TDH}$</td>
<td>0.35/-0.03</td>
<td>0.39/-0.04</td>
<td>0.43/-0.04</td>
<td>ns, min</td>
</tr>
<tr>
<td></td>
<td>F/G address inputs</td>
<td>$T_{AS/TAH}$</td>
<td>0.42/0.00</td>
<td>0.47/0.00</td>
<td>0.52/ 0.00</td>
<td>ns, min</td>
</tr>
<tr>
<td></td>
<td>CE input (WE)</td>
<td>$T_{WES/TWEH}$</td>
<td>0.21/0.04</td>
<td>0.24/0.05</td>
<td>0.26/ 0.05</td>
<td>ns, min</td>
</tr>
<tr>
<td></td>
<td>Clock CLK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Minimum Pulse Width, High</td>
<td>$T_{WPH}$</td>
<td>0.63</td>
<td>0.72</td>
<td>0.79</td>
<td>ns, min</td>
</tr>
<tr>
<td></td>
<td>Minimum Pulse Width, Low</td>
<td>$T_{WPL}$</td>
<td>0.63</td>
<td>0.72</td>
<td>0.79</td>
<td>ns, min</td>
</tr>
<tr>
<td></td>
<td>Minimum clock period to meet address write cycle time</td>
<td>$T_{WC}$</td>
<td>1.25</td>
<td>1.44</td>
<td>1.58</td>
<td>ns, min</td>
</tr>
</tbody>
</table>

Notes:
1. A Zero “0” Hold Time listing indicates no hold time or a negative hold time. Negative values cannot be guaranteed “best-case”, but if a “0” is listed, there is no positive hold time.

CLB Shift Register Switching Characteristics

Table 35: CLB Shift Register Switching Characteristics

<table>
<thead>
<tr>
<th>Speed Grade</th>
<th>Description</th>
<th>Symbol</th>
<th>-7</th>
<th>-6</th>
<th>-5</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Sequential Delays</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Clock CLK to X/Y outputs</td>
<td>$T_{REG}$</td>
<td>2.61</td>
<td>2.97</td>
<td>3.27</td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td>Clock CLK to X/Y outputs</td>
<td>$T_{REG32}$</td>
<td>2.87</td>
<td>3.27</td>
<td>3.59</td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td>Clock CLK to XB output via MC15 LUT output</td>
<td>$T_{REGXB}$</td>
<td>2.62</td>
<td>2.99</td>
<td>3.29</td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td>Clock CLK to YB output via MC15 LUT output</td>
<td>$T_{REGYB}$</td>
<td>2.60</td>
<td>2.97</td>
<td>3.26</td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td>Clock CLK to Shiftout</td>
<td>$T_{CKSH}$</td>
<td>2.53</td>
<td>2.88</td>
<td>3.17</td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td>Clock CLK to F5 output</td>
<td>$T_{REGF5}$</td>
<td>2.86</td>
<td>3.27</td>
<td>3.59</td>
<td>ns, max</td>
</tr>
<tr>
<td></td>
<td>Setup and Hold Times Before/After Clock CLK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>BX/BY data inputs (DIN)</td>
<td>$T_{SRLDS/TSRLDH}$</td>
<td>0.84/-0.15</td>
<td>0.96/-0.17</td>
<td>1.06/-0.19</td>
<td>ns, min</td>
</tr>
<tr>
<td></td>
<td>CE input (WS)</td>
<td>$T_{WSS/TWSH}$</td>
<td>0.31/0.01</td>
<td>0.35/0.01</td>
<td>0.39/ 0.01</td>
<td>ns, min</td>
</tr>
<tr>
<td></td>
<td>Clock CLK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Minimum Pulse Width, High</td>
<td>$T_{SRPH}$</td>
<td>0.63</td>
<td>0.72</td>
<td>0.79</td>
<td>ns, min</td>
</tr>
<tr>
<td></td>
<td>Minimum Pulse Width, Low</td>
<td>$T_{SRPL}$</td>
<td>0.63</td>
<td>0.72</td>
<td>0.79</td>
<td>ns, min</td>
</tr>
</tbody>
</table>

Notes:
1. A Zero “0” Hold Time listing indicates no hold time or a negative hold time. Negative values cannot be guaranteed “best-case”, but if a “0” is listed, there is no positive hold time.
# Multiplier Switching Characteristics

## Table 36: Multiplier Switching Characteristics

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>-7</th>
<th>-6</th>
<th>-5</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Propagation Delay to Output Pin</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Input to Pin35</td>
<td>T_MULT_P35</td>
<td>4.04</td>
<td>4.66</td>
<td>5.14</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin34</td>
<td>T_MULT_P34</td>
<td>3.96</td>
<td>4.57</td>
<td>5.03</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin33</td>
<td>T_MULT_P33</td>
<td>3.88</td>
<td>4.47</td>
<td>4.93</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin32</td>
<td>T_MULT_P32</td>
<td>3.79</td>
<td>4.37</td>
<td>4.82</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin31</td>
<td>T_MULT_P31</td>
<td>3.71</td>
<td>4.28</td>
<td>4.71</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin30</td>
<td>T_MULT_P30</td>
<td>3.62</td>
<td>4.18</td>
<td>4.61</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin29</td>
<td>T_MULT_P29</td>
<td>3.54</td>
<td>4.08</td>
<td>4.50</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin28</td>
<td>T_MULT_P28</td>
<td>3.46</td>
<td>3.99</td>
<td>4.39</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin27</td>
<td>T_MULT_P27</td>
<td>3.37</td>
<td>3.89</td>
<td>4.28</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin26</td>
<td>T_MULT_P26</td>
<td>3.29</td>
<td>3.79</td>
<td>4.18</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin25</td>
<td>T_MULT_P25</td>
<td>3.20</td>
<td>3.69</td>
<td>4.07</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin24</td>
<td>T_MULT_P24</td>
<td>3.12</td>
<td>3.60</td>
<td>3.96</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin23</td>
<td>T_MULT_P23</td>
<td>3.04</td>
<td>3.50</td>
<td>3.86</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin22</td>
<td>T_MULT_P22</td>
<td>2.95</td>
<td>3.40</td>
<td>3.75</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin21</td>
<td>T_MULT_P21</td>
<td>2.87</td>
<td>3.31</td>
<td>3.64</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin20</td>
<td>T_MULT_P20</td>
<td>2.78</td>
<td>3.21</td>
<td>3.54</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin19</td>
<td>T_MULT_P19</td>
<td>2.70</td>
<td>3.11</td>
<td>3.43</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin18</td>
<td>T_MULT_P18</td>
<td>2.62</td>
<td>3.02</td>
<td>3.32</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin17</td>
<td>T_MULT_P17</td>
<td>2.53</td>
<td>2.92</td>
<td>3.21</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin16</td>
<td>T_MULT_P16</td>
<td>2.45</td>
<td>2.82</td>
<td>3.11</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin15</td>
<td>T_MULT_P15</td>
<td>2.36</td>
<td>2.72</td>
<td>3.00</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin14</td>
<td>T_MULT_P14</td>
<td>2.28</td>
<td>2.63</td>
<td>2.89</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin13</td>
<td>T_MULT_P13</td>
<td>2.20</td>
<td>2.53</td>
<td>2.79</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin12</td>
<td>T_MULT_P12</td>
<td>2.11</td>
<td>2.43</td>
<td>2.68</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin11</td>
<td>T_MULT_P11</td>
<td>2.03</td>
<td>2.34</td>
<td>2.57</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin10</td>
<td>T_MULT_P10</td>
<td>1.94</td>
<td>2.24</td>
<td>2.47</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin9</td>
<td>T_MULT_P9</td>
<td>1.86</td>
<td>2.14</td>
<td>2.36</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin8</td>
<td>T_MULT_P8</td>
<td>1.78</td>
<td>2.05</td>
<td>2.25</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin7</td>
<td>T_MULT_P7</td>
<td>1.69</td>
<td>1.95</td>
<td>2.14</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin6</td>
<td>T_MULT_P6</td>
<td>1.61</td>
<td>1.85</td>
<td>2.04</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin5</td>
<td>T_MULT_P5</td>
<td>1.52</td>
<td>1.75</td>
<td>1.93</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin4</td>
<td>T_MULT_P4</td>
<td>1.44</td>
<td>1.66</td>
<td>1.82</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin3</td>
<td>T_MULT_P3</td>
<td>1.36</td>
<td>1.56</td>
<td>1.72</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin2</td>
<td>T_MULT_P2</td>
<td>1.27</td>
<td>1.46</td>
<td>1.61</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin1</td>
<td>T_MULT_P1</td>
<td>1.19</td>
<td>1.37</td>
<td>1.50</td>
<td>ns, max</td>
</tr>
<tr>
<td>Input to Pin0</td>
<td>T_MULT_P0</td>
<td>1.10</td>
<td>1.27</td>
<td>1.40</td>
<td>ns, max</td>
</tr>
</tbody>
</table>
### Table 37: Pipelined Multiplier Switching Characteristics

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Speed Grade</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Setup and Hold Times Before/After Clock</strong></td>
<td></td>
<td>-7</td>
<td>-6</td>
</tr>
<tr>
<td>Data Inputs T_{MULIDCK}/T_{MULCKID}</td>
<td>2.61/0.00</td>
<td>3.00/0.00</td>
<td>3.45/0.00</td>
</tr>
<tr>
<td>Clock Enable T_{MULIDCK_CE}/T_{MULCKID_CE}</td>
<td>0.63/0.00</td>
<td>0.72/0.00</td>
<td>0.80/0.00</td>
</tr>
<tr>
<td>Reset T_{MULIDCK_RST}/T_{MULCKID_RST}</td>
<td>0.63/0.00</td>
<td>0.72/0.00</td>
<td>0.80/0.00</td>
</tr>
<tr>
<td><strong>Clock to Output Pin</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Clock to Pin35 T_{MULTCK_P35}</td>
<td>2.64</td>
<td>3.05</td>
<td>3.36</td>
</tr>
<tr>
<td>Clock to Pin34 T_{MULTCK_P34}</td>
<td>2.56</td>
<td>2.95</td>
<td>3.25</td>
</tr>
<tr>
<td>Clock to Pin33 T_{MULTCK_P33}</td>
<td>2.48</td>
<td>2.85</td>
<td>3.14</td>
</tr>
<tr>
<td>Clock to Pin32 T_{MULTCK_P32}</td>
<td>2.39</td>
<td>2.76</td>
<td>3.04</td>
</tr>
<tr>
<td>Clock to Pin31 T_{MULTCK_P31}</td>
<td>2.31</td>
<td>2.66</td>
<td>2.93</td>
</tr>
<tr>
<td>Clock to Pin30 T_{MULTCK_P30}</td>
<td>2.22</td>
<td>2.56</td>
<td>2.82</td>
</tr>
<tr>
<td>Clock to Pin29 T_{MULTCK_P29}</td>
<td>2.14</td>
<td>2.47</td>
<td>2.72</td>
</tr>
<tr>
<td>Clock to Pin28 T_{MULTCK_P28}</td>
<td>2.06</td>
<td>2.37</td>
<td>2.61</td>
</tr>
<tr>
<td>Clock to Pin27 T_{MULTCK_P27}</td>
<td>1.97</td>
<td>2.27</td>
<td>2.50</td>
</tr>
<tr>
<td>Clock to Pin26 T_{MULTCK_P26}</td>
<td>1.89</td>
<td>2.17</td>
<td>2.40</td>
</tr>
<tr>
<td>Clock to Pin25 T_{MULTCK_P25}</td>
<td>1.80</td>
<td>2.08</td>
<td>2.29</td>
</tr>
<tr>
<td>Clock to Pin24 T_{MULTCK_P24}</td>
<td>1.72</td>
<td>1.98</td>
<td>2.18</td>
</tr>
<tr>
<td>Clock to Pin23 T_{MULTCK_P23}</td>
<td>1.64</td>
<td>1.88</td>
<td>2.07</td>
</tr>
<tr>
<td>Clock to Pin22 T_{MULTCK_P22}</td>
<td>1.55</td>
<td>1.79</td>
<td>1.97</td>
</tr>
<tr>
<td>Clock to Pin21 T_{MULTCK_P21}</td>
<td>1.47</td>
<td>1.69</td>
<td>1.86</td>
</tr>
<tr>
<td>Clock to Pin20 T_{MULTCK_P20}</td>
<td>1.38</td>
<td>1.59</td>
<td>1.75</td>
</tr>
<tr>
<td>Clock to Pin19 T_{MULTCK_P19}</td>
<td>1.30</td>
<td>1.50</td>
<td>1.65</td>
</tr>
<tr>
<td>Clock to Pin18 T_{MULTCK_P18}</td>
<td>1.22</td>
<td>1.40</td>
<td>1.54</td>
</tr>
<tr>
<td>Clock to Pin17 T_{MULTCK_P17}</td>
<td>1.13</td>
<td>1.30</td>
<td>1.43</td>
</tr>
<tr>
<td>Clock to Pin16 T_{MULTCK_P16}</td>
<td>1.05</td>
<td>1.20</td>
<td>1.33</td>
</tr>
<tr>
<td>Clock to Pin15 T_{MULTCK_P15}</td>
<td>0.96</td>
<td>1.11</td>
<td>1.22</td>
</tr>
<tr>
<td>Clock to Pin14 T_{MULTCK_P14}</td>
<td>0.88</td>
<td>1.01</td>
<td>1.11</td>
</tr>
<tr>
<td>Clock to Pin13 T_{MULTCK_P13}</td>
<td>0.80</td>
<td>0.91</td>
<td>1.00</td>
</tr>
<tr>
<td>Clock to Pin12 T_{MULTCK_P12}</td>
<td>0.80</td>
<td>0.91</td>
<td>1.00</td>
</tr>
<tr>
<td>Clock to Pin11 T_{MULTCK_P11}</td>
<td>0.80</td>
<td>0.91</td>
<td>1.00</td>
</tr>
<tr>
<td>Clock to Pin10 T_{MULTCK_P10}</td>
<td>0.80</td>
<td>0.91</td>
<td>1.00</td>
</tr>
<tr>
<td>Clock to Pin9 T_{MULTCK_P9}</td>
<td>0.80</td>
<td>0.91</td>
<td>1.00</td>
</tr>
<tr>
<td>Clock to Pin8 T_{MULTCK_P8}</td>
<td>0.80</td>
<td>0.91</td>
<td>1.00</td>
</tr>
<tr>
<td>Clock to Pin7 T_{MULTCK_P7}</td>
<td>0.80</td>
<td>0.91</td>
<td>1.00</td>
</tr>
<tr>
<td>Clock to Pin6 T_{MULTCK_P6}</td>
<td>0.80</td>
<td>0.91</td>
<td>1.00</td>
</tr>
<tr>
<td>Clock to Pin5 T_{MULTCK_P5}</td>
<td>0.80</td>
<td>0.91</td>
<td>1.00</td>
</tr>
<tr>
<td>Clock to Pin4 T_{MULTCK_P4}</td>
<td>0.80</td>
<td>0.91</td>
<td>1.00</td>
</tr>
<tr>
<td>Clock to Pin3 T_{MULTCK_P3}</td>
<td>0.80</td>
<td>0.91</td>
<td>1.00</td>
</tr>
<tr>
<td>Clock to Pin2 T_{MULTCK_P2}</td>
<td>0.80</td>
<td>0.91</td>
<td>1.00</td>
</tr>
<tr>
<td>Clock to Pin1 T_{MULTCK_P1}</td>
<td>0.80</td>
<td>0.91</td>
<td>1.00</td>
</tr>
<tr>
<td>Clock to Pin0 T_{MULTCK_P0}</td>
<td>0.80</td>
<td>0.91</td>
<td>1.00</td>
</tr>
</tbody>
</table>
**Block SelectRAM+ Switching Characteristics**

Table 38: Block SelectRAM+ Switching Characteristics

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>-7</th>
<th>-6</th>
<th>-5</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Sequential Delays</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Clock CLK to DOUT output</td>
<td>$T_{BCKO}$</td>
<td>1.80</td>
<td>2.06</td>
<td>2.26</td>
<td>ns, max</td>
</tr>
<tr>
<td>Setup and Hold Times Before Clock CLK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADDR inputs</td>
<td>$T_{BACK}/T_{BCKA}$</td>
<td>0.28/0.00</td>
<td>0.32/0.00</td>
<td>0.35/0.00</td>
<td>ns, min</td>
</tr>
<tr>
<td>DIN inputs</td>
<td>$T_{BDCK}/T_{BCKD}$</td>
<td>0.28/0.00</td>
<td>0.32/0.00</td>
<td>0.35/0.00</td>
<td>ns, min</td>
</tr>
<tr>
<td>EN input</td>
<td>$T_{BECK}/T_{BCKE}$</td>
<td>0.91/–0.44</td>
<td>1.04/–0.50</td>
<td>1.15/–0.56</td>
<td>ns, min</td>
</tr>
<tr>
<td>RST input</td>
<td>$T_{BRCK}/T_{BCKR}$</td>
<td>1.25/–0.68</td>
<td>1.44/–0.78</td>
<td>1.58/–0.86</td>
<td>ns, min</td>
</tr>
<tr>
<td>WEN input</td>
<td>$T_{BWCK}/T_{BCWK}$</td>
<td>0.55/–0.18</td>
<td>0.63/–0.21</td>
<td>0.69/–0.24</td>
<td>ns, min</td>
</tr>
<tr>
<td>Clock CLK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Minimum Pulse Width, High</td>
<td>$T_{BPWH}$</td>
<td>1.04</td>
<td>1.19</td>
<td>1.30</td>
<td>ns, min</td>
</tr>
<tr>
<td>Minimum Pulse Width, Low</td>
<td>$T_{BPWL}$</td>
<td>1.04</td>
<td>1.19</td>
<td>1.30</td>
<td>ns, min</td>
</tr>
</tbody>
</table>

Notes:
1. A Zero “0” Hold Time listing indicates no hold time or a negative hold time. Negative values can not be guaranteed “best-case”, but if a “0” is listed, there is no positive hold time.

**TBUF Switching Characteristics**

Table 39: TBUF Switching Characteristics

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>-7</th>
<th>-6</th>
<th>-5</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Combinatorial Delays</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IN input to OUT output</td>
<td>$T_{IO}$</td>
<td>1.09</td>
<td>1.24</td>
<td>1.37</td>
<td>ns, max</td>
</tr>
<tr>
<td>TRI input to OUT output high-impedance</td>
<td>$T_{OFF}$</td>
<td>0.47</td>
<td>0.54</td>
<td>0.60</td>
<td>ns, max</td>
</tr>
<tr>
<td>TRI input to valid data on OUT output</td>
<td>$T_{ON}$</td>
<td>0.47</td>
<td>0.54</td>
<td>0.60</td>
<td>ns, max</td>
</tr>
</tbody>
</table>
Configuration Timing

Configuration Memory Clearing Parameters

Power-up timing of configuration signals is shown in Figure 4; corresponding timing characteristics are listed in Table 40.

![Figure 4: Power-Up Timing Configuration Signals](ds022_020_022900)

Table 40: Power-Up Timing Characteristics

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Value</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Program Latency</td>
<td>T\textsubscript{PL}</td>
<td>4 µs per frame max</td>
<td></td>
</tr>
<tr>
<td>Power-on-Reset</td>
<td>T\textsubscript{POR}</td>
<td>4 ms, max</td>
<td></td>
</tr>
<tr>
<td>CCLK (output) Delay</td>
<td>T\textsubscript{ICCK}</td>
<td>1 µs, min</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>4 µs, max</td>
<td></td>
</tr>
<tr>
<td>Program Pulse Width</td>
<td>T\textsubscript{PROGRAM}</td>
<td>ns, min</td>
<td></td>
</tr>
</tbody>
</table>

Master/Slave Serial Mode Parameters

For Slave configurations, a free running CCLK can be used, as shown in Figure 5.

![Figure 5: Serial Configuration Clocking Sequence](ugp02_c3_028_112900)
Table 41: Master/Slave Serial Mode Programming Switching

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Values</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>CCLK</td>
<td>T_{DCC}/T_{CCD}</td>
<td>5.0/0.0 ns</td>
<td>min</td>
</tr>
<tr>
<td>DIN setup/hold, slave mode</td>
<td>T_{DSCK}/T_{SCKD}</td>
<td>5.0/0.0 ns</td>
<td>min</td>
</tr>
<tr>
<td>DIN setup/hold, master mode</td>
<td>T_{CCO}</td>
<td>12.0 ns</td>
<td>max</td>
</tr>
<tr>
<td>DOUT</td>
<td>T_{CCH}</td>
<td>5.0 ns</td>
<td>min</td>
</tr>
<tr>
<td>High time</td>
<td>T_{CCL}</td>
<td>5.0 ns</td>
<td>min</td>
</tr>
<tr>
<td>Low time</td>
<td>F_{CC_SERIAL}</td>
<td>66 MHz</td>
<td>max</td>
</tr>
<tr>
<td>Frequency Tolerance, master mode with respect to nominal</td>
<td>+45% -30%</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Master/Slave SelectMAP Parameters**

Figure 6 is a generic diagram for data loading using SelectMAP. For other data loading diagrams, refer to *Virtex-II Pro Platform FPGA User Guide*.

![Figure 6: Data Loading in SelectMAP](image)

Table 42: SelectMAP Write Timing Characteristics

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Value</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>CCLK</td>
<td>T_{SMDCD}/T_{SMCCD}</td>
<td>5.0/0.0 ns</td>
<td>min</td>
</tr>
<tr>
<td>D_{0-7} Setup/Hold</td>
<td>T_{SMSCCD}/T_{SMCCCS}</td>
<td>7.0/0.0 ns</td>
<td>min</td>
</tr>
<tr>
<td>CS_B Setup/Hold</td>
<td>T_{SMCCW}/T_{SMWCC}</td>
<td>7.0/0.0 ns</td>
<td>min</td>
</tr>
<tr>
<td>RDWR_B Setup/Hold</td>
<td>T_{SMCKBY}</td>
<td>12.0 ns</td>
<td>max</td>
</tr>
<tr>
<td>BUSY Propagation Delay</td>
<td>F_{CC_SelctMAP}</td>
<td>66 MHz</td>
<td>max</td>
</tr>
<tr>
<td>Maximum Frequency</td>
<td>F_{CC_SERIAL}</td>
<td>66 MHz</td>
<td>max</td>
</tr>
<tr>
<td>Maximum Frequency with no handshake</td>
<td>F_{CC_SERIAL}</td>
<td>66 MHz</td>
<td>max</td>
</tr>
</tbody>
</table>
JTAG Test Access Port Switching Characteristics

Characterization data for some of the most commonly requested timing parameters shown in Figure 7 is listed in Table 43.

![Virtex-II Pro Boundary Scan Port Timing Waveforms](image)

**Table 43: Boundary-Scan Port Timing Specifications**

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Value</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>$T_{TAP\text{TCK}}$</td>
<td>TMS and TDI setup time before TCK</td>
<td>4.0</td>
<td>ns, min</td>
</tr>
<tr>
<td>$T_{TCK\text{TAP}}$</td>
<td>TMS and TDI hold times after TCK</td>
<td>2.0</td>
<td>ns, min</td>
</tr>
<tr>
<td>$T_{TCK\text{TDO}}$</td>
<td>TCK falling edge to TDO output valid</td>
<td>11.0</td>
<td>ns, min</td>
</tr>
<tr>
<td>$F_{TCK}$</td>
<td>Maximum TCK clock frequency</td>
<td>33.0</td>
<td>MHz, max</td>
</tr>
</tbody>
</table>
Virtex-II Pro Pin-to-Pin Output Parameter Guidelines

All devices are 100% functionally tested. Listed below are representative values for typical pin locations and normal clock loading. Values are expressed in nanoseconds unless otherwise noted.

Global Clock Input to Output Delay for LVCMOS25, 12 mA, Fast Slew Rate, With DCM

Table 44: Global Clock Input to Output Delay for LVCMOS25, 12 mA, Fast Slew Rate, With DCM

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Device</th>
<th>-7</th>
<th>-6</th>
<th>-5</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>LVCMOS25 Global Clock Input to Output Delay using Output Flip-flop, 12 mA, Fast Slew Rate, with DCM. For data output with different standards, adjust the delays with the values shown in IOB Output Switching Characteristics Standard Adjustments, page 94.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Global Clock and OFF with DCM</td>
<td>T\text{ICKOFDCM}</td>
<td>XC2VP2</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP4</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP7</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP20</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP30</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP40</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP50</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP70</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP100</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP125</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Notes:

1. Listed above are representative values where one global clock input drives one vertical clock line in each accessible column, and where all accessible IOB and CLB flip-flops are clocked by the global clock net.
2. Output timing is measured at 50% \(V_{CC}\) threshold with 35 pF external capacitive load. For other I/O standards and different loads, see Table 31.
3. DCM output jitter is already included in the timing calculation.
### Global Clock Input to Output Delay for LVCMOS25, 12 mA, Fast Slew Rate, Without DCM

**Table 45: Global Clock Input to Output Delay for LVCMOS25, 12 mA, Fast Slew Rate, Without DCM**

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Device</th>
<th>-7</th>
<th>-6</th>
<th>-5</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>LVCMOS25 Global Clock Input to Output Delay using Output Flip-flop, 12 mA, Fast Slew Rate, without DCM. For data output with different standards, adjust the delays with the values shown in IOB Output Switching Characteristics Standard Adjustments, page 94.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Global Clock and OFF without DCM</td>
<td>$T_{ICKOF}$</td>
<td>XC2VP2</td>
<td></td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP4</td>
<td></td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP7</td>
<td></td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP20</td>
<td></td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP30</td>
<td></td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP40</td>
<td></td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP50</td>
<td></td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP70</td>
<td></td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP100</td>
<td></td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP125</td>
<td></td>
<td></td>
<td></td>
<td>ns</td>
</tr>
</tbody>
</table>

**Notes:**
1. Listed above are representative values where one global clock input drives one vertical clock line in each accessible column, and where all accessible IOB and CLB flip-flops are clocked by the global clock net.
2. Output timing is measured at 50% $V_{CC}$ threshold with 35 pF external capacitive load. For other I/O standards and different loads, see Table 31.
3. DCM output jitter is already included in the timing calculation.
Virtex-II Pro Pin-to-Pin Input Parameter Guidelines

All devices are 100% functionally tested. Listed below are representative values for typical pin locations and normal clock loading. Values are expressed in nanoseconds unless otherwise noted.

Global Clock Set-Up and Hold for LVCMOS25 Standard, With DCM

Table 46: Global Clock Set-Up and Hold for LVCMOS25 Standard, With DCM

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Device</th>
<th>-7</th>
<th>-6</th>
<th>-5</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Input Setup and Hold Time Relative to Global Clock Input Signal for LVCMOS25 Standard. For data input with different standards, adjust the setup time delay by the values shown in IOB Input Switching Characteristics Standard Adjustments, page 92.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>No Delay Global Clock and IFF with DCM</td>
<td>$T_{PSDCM}/T_{PHDCM}$</td>
<td>XC2VP2</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP4</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP7</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP20</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP30</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP40</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP50</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP70</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP100</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP125</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Notes:
1. IFF = Input Flip-Flop or Latch
2. Setup time is measured relative to the Global Clock input signal with the fastest route and the lightest load. Hold time is measured relative to the Global Clock input signal with the slowest route and heaviest load.
3. DCM output jitter is already included in the timing calculation.
## Global Clock Set-Up and Hold for LVCMOS25 Standard, Without DCM

*Table 47: Global Clock Set-Up and Hold for LVCMOS25 Standard, Without DCM*

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Device</th>
<th>-7</th>
<th>-6</th>
<th>-5</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Input Setup and Hold Time Relative to Global Clock Input Signal for LVCMOS25 Standard. For data input with different standards, adjust the setup time delay by the values shown in IOB Input Switching Characteristics Standard Adjustments, page 92.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Full Delay Global Clock and IFF without DCM</td>
<td>$T_{PSFD}/T_{PHFD}$</td>
<td>XC2VP2</td>
<td></td>
<td></td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP4</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP7</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP20</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP30</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP40</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP50</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP70</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP100</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP125</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Notes:**
1. IFF = Input Flip-Flop or Latch
2. Setup time is measured relative to the Global Clock input signal with the fastest route and the lightest load. Hold time is measured relative to the Global Clock input signal with the slowest route and heaviest load.
3. A Zero “0” Hold Time listing indicates no hold time or a negative hold time. Negative values can not be guaranteed “best-case”, but if a “0” is listed, there is no positive hold time.
**DCM Timing Parameters**

All devices are 100% functionally tested. Because of the difficulty in directly measuring many internal timing parameters, those parameters are derived from benchmark timing patterns. The following guidelines reflect worst-case values across the recommended operating conditions. All output jitter and phase specifications are determined through statistical measurement at the package pins.

**Operating Frequency Ranges**

<table>
<thead>
<tr>
<th>Description</th>
<th>Speed Grade</th>
<th>Symbol</th>
<th>Constraints</th>
<th>-7</th>
<th>-6</th>
<th>-5</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Output Clocks (Low Frequency Mode)</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLK0, CLK90, CLK180, CLK270</td>
<td></td>
<td>CLKOUT_FREQ_1X_LF_MIN</td>
<td>24.00</td>
<td>24.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>CLKOUT_FREQ_1X_LF_MAX</td>
<td>210.00</td>
<td>180.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLK2X, CLK2X180</td>
<td></td>
<td>CLKOUT_FREQ_2X_LF_MIN</td>
<td>48.00</td>
<td>48.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>CLKOUT_FREQ_2X_LF_MAX</td>
<td>420.00</td>
<td>360.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLKDV</td>
<td></td>
<td>CLKOUT_FREQ_DV_LF_MIN</td>
<td>1.50</td>
<td>1.50 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>CLKOUT_FREQ_DV_LF_MAX</td>
<td>140.00</td>
<td>120.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLKFX, CLKFX180</td>
<td></td>
<td>CLKOUT_FREQ_FX_LF_MIN</td>
<td>24.00</td>
<td>24.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>CLKOUT_FREQ_FX_LF_MAX</td>
<td>240.00</td>
<td>210.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Input Clocks (Low Frequency Mode)</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLkin (using DLL outputs) (1)</td>
<td></td>
<td>CLkin_FREQ_DLL_LF_MIN</td>
<td>24.00</td>
<td>24.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>CLkin_FREQ_DLL_LF_MAX</td>
<td>210.00</td>
<td>180.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLkin (using CLKFX outputs) (2)</td>
<td></td>
<td>CLkin_FREQ_FX_LF_MIN</td>
<td>1.00</td>
<td>1.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>CLkin_FREQ_FX_LF_MAX</td>
<td>240.00</td>
<td>210.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PSCLK</td>
<td></td>
<td>PSCLK_FREQ_LF_MIN</td>
<td>0.01</td>
<td>0.01 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>PSCLK_FREQ_LF_MAX</td>
<td>420.00</td>
<td>360.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Output Clocks (High Frequency Mode)</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLK0, CLK180</td>
<td></td>
<td>CLKOUT_FREQ_1X_HF_MIN</td>
<td>48.00</td>
<td>48.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>CLKOUT_FREQ_1X_HF_MAX</td>
<td>420.00</td>
<td>360.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLKDV</td>
<td></td>
<td>CLKOUT_FREQ_DV_HF_MIN</td>
<td>3.00</td>
<td>3.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>CLKOUT_FREQ_DV_HF_MAX</td>
<td>280.00</td>
<td>240.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLKFX, CLKFX180</td>
<td></td>
<td>CLKOUT_FREQ_FX_HF_MIN</td>
<td>210.00</td>
<td>210.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>CLKOUT_FREQ_FX_HF_MAX</td>
<td>320.00</td>
<td>270.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Input Clocks (High Frequency Mode)</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLkin (using DLL outputs) (1)</td>
<td></td>
<td>CLkin_FREQ_DLL_HF_MIN</td>
<td>48.00</td>
<td>48.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>CLkin_FREQ_DLL_HF_MAX</td>
<td>420.00</td>
<td>360.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLkin (using CLKFX outputs) (2)</td>
<td></td>
<td>CLkin_FREQ_FX_HF_MIN</td>
<td>50.00</td>
<td>50.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>CLkin_FREQ_FX_HF_MAX</td>
<td>320.00</td>
<td>270.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PSCLK</td>
<td></td>
<td>PSCLK_FREQ_HF_MIN</td>
<td>0.01</td>
<td>0.01 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>PSCLK_FREQ_HF_MAX</td>
<td>420.00</td>
<td>360.00 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Notes:**

1. “DLL outputs” is used here to describe the outputs: CLK0, CLK90, CLK180, CLK270, CLK2X, CLK2X180, and CLKDV.
2. If both DLL and CLKFX outputs are used, follow the more restrictive specification.
## Input Clock Tolerances

### Table 49: Input Clock Tolerances

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol Details</th>
<th>Constraints</th>
<th>Speed Grade</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>F&lt;sub&gt;CLKin&lt;/sub&gt;</td>
<td>-7</td>
<td>-6</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Min</td>
<td>Max</td>
<td>Min</td>
</tr>
<tr>
<td>Input Clock Low/high Pulse Width</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PSCLK</td>
<td>PSCLK_PULSE</td>
<td>&lt; 1MHz</td>
<td>25.00</td>
<td>25.00</td>
</tr>
<tr>
<td>PSCLK and CLKin&lt;sup&gt;(2)&lt;/sup&gt;</td>
<td>PSCLK_PULSE and CLKin_PULSE</td>
<td>1 – 10 MHz</td>
<td>25.00</td>
<td>25.00</td>
</tr>
<tr>
<td></td>
<td></td>
<td>10 – 25 MHz</td>
<td>10.00</td>
<td>10.00</td>
</tr>
<tr>
<td></td>
<td></td>
<td>25 – 50 MHz</td>
<td>5.00</td>
<td>5.00</td>
</tr>
<tr>
<td></td>
<td></td>
<td>50 – 100 MHz</td>
<td>3.00</td>
<td>3.00</td>
</tr>
<tr>
<td></td>
<td></td>
<td>100 – 150 MHz</td>
<td>2.40</td>
<td>2.40</td>
</tr>
<tr>
<td></td>
<td></td>
<td>150 – 200 MHz</td>
<td>2.00</td>
<td>2.00</td>
</tr>
<tr>
<td></td>
<td></td>
<td>200 – 250 MHz</td>
<td>1.80</td>
<td>1.80</td>
</tr>
<tr>
<td></td>
<td></td>
<td>250 – 300 MHz</td>
<td>1.50</td>
<td>1.50</td>
</tr>
<tr>
<td></td>
<td></td>
<td>300 – 350 MHz</td>
<td>1.30</td>
<td>1.30</td>
</tr>
<tr>
<td></td>
<td></td>
<td>350 – 400 MHz</td>
<td>1.15</td>
<td>1.15</td>
</tr>
<tr>
<td></td>
<td></td>
<td>&gt; 400 MHz</td>
<td>1.05</td>
<td>1.05</td>
</tr>
<tr>
<td>Input Clock Cycle-Cycle Jitter (Low Frequency Mode)</td>
<td>CLKin_CYC_JITT_DLL_LF</td>
<td>±300</td>
<td>±300</td>
<td>ps</td>
</tr>
<tr>
<td>Input Clock Cycle-Cycle Jitter (High Frequency Mode)</td>
<td>CLKin_CYC_JITT_DLL_HF</td>
<td>±150</td>
<td>±150</td>
<td>ps</td>
</tr>
<tr>
<td>Input Clock Period Jitter (Low Frequency Mode)</td>
<td>CLKin_PER_JITT_DLL_LF</td>
<td>±1</td>
<td>±1</td>
<td>ns</td>
</tr>
<tr>
<td>Input Clock Period Jitter (High Frequency Mode)</td>
<td>CLKin_PER_JITT_DLL_HF</td>
<td>±1</td>
<td>±1</td>
<td>ns</td>
</tr>
<tr>
<td>Feedback Clock Path Delay Variation</td>
<td>CLKFB_DELAY_VAR_EXT</td>
<td>±1</td>
<td>±1</td>
<td>ns</td>
</tr>
</tbody>
</table>

### Notes:
1. “DLL outputs” is used here to describe the outputs: CLK0, CLK90, CLK180, CLK270, CLK2X, CLK2X180, and CLKDV.
2. If both DLL and CLKFX outputs are used, follow the more restrictive specification.
Output Clock Jitter

Table 50: Output Clock Jitter

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Constraints</th>
</tr>
</thead>
<tbody>
<tr>
<td>Clock Synthesis Period Jitter</td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLK0</td>
<td>CLKOUT_PER_JITT_0</td>
<td>±100 ±100 ps</td>
</tr>
<tr>
<td>CLK90</td>
<td>CLKOUT_PER_JITT_90</td>
<td>±150 ±150 ps</td>
</tr>
<tr>
<td>CLK180</td>
<td>CLKOUT_PER_JITT_180</td>
<td>±150 ±150 ps</td>
</tr>
<tr>
<td>CLK270</td>
<td>CLKOUT_PER_JITT_270</td>
<td>±150 ±150 ps</td>
</tr>
<tr>
<td>CLK2X, CLK2X180</td>
<td>CLKOUT_PER_JITT_2X</td>
<td>±200 ±200 ps</td>
</tr>
<tr>
<td>CLKDV (integer division)</td>
<td>CLKOUT_PER_JITT_DV1</td>
<td>±150 ±150 ps</td>
</tr>
<tr>
<td>CLKDV (non-integer division)</td>
<td>CLKOUT_PER_JITT_DV2</td>
<td>±300 ±300 ps</td>
</tr>
<tr>
<td>CLKFX, CLKFX180</td>
<td>CLKOUT_PER_JITT_FX</td>
<td>Note 1 Note 1 ps</td>
</tr>
</tbody>
</table>

Notes:
1. Values for this parameter are available on [www.xilinx.com](http://www.xilinx.com).

Output Clock Phase Alignment

Table 51: Output Clock Phase Alignment

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Constraints</th>
</tr>
</thead>
<tbody>
<tr>
<td>Phase Offset Between CLKin and CLKFB</td>
<td>CLKin_CLKFB_PHASE</td>
<td>±50 ±50 ps</td>
</tr>
<tr>
<td>Phase Offset Between Any DCM Outputs</td>
<td>CLKOUT_PHASE</td>
<td>±140 ±140 ps</td>
</tr>
<tr>
<td>Duty Cycle Precision</td>
<td>CLKOUT_DUTY_CYCLE_DLL</td>
<td>±150 ±150 ps</td>
</tr>
<tr>
<td>CLKFX outputs(1)</td>
<td>CLKOUT_DUTY_CYCLE_FX</td>
<td>±100 ±100 ps</td>
</tr>
</tbody>
</table>

Notes:
1. “DLL outputs” is used here to describe the outputs: CLK0, CLK90, CLK180, CLK270, CLK2X, CLK2X180, and CLKDV.
2. Specification also applies to PSCLK.
## Miscellaneous Timing Parameters

**Table 52: Miscellaneous Timing Parameters**

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Constraints</th>
<th>Speed Grade</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>F&lt;sub&gt;CLKIN&lt;/sub&gt;</td>
<td>-7</td>
</tr>
<tr>
<td>Time Required to Achieve LOCK</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Using DLL outputs&lt;sup&gt;(1)&lt;/sup&gt;</td>
<td>LOCK_DLL:</td>
<td></td>
<td>20.00</td>
</tr>
<tr>
<td></td>
<td>LOCK_DLL_60</td>
<td>&gt; 60MHz</td>
<td></td>
</tr>
<tr>
<td></td>
<td>LOCK_DLL_50_60</td>
<td>50 - 60 MHz</td>
<td></td>
</tr>
<tr>
<td></td>
<td>LOCK_DLL_40_50</td>
<td>40 - 50 MHz</td>
<td></td>
</tr>
<tr>
<td></td>
<td>LOCK_DLL_30_40</td>
<td>30 - 40 MHz</td>
<td></td>
</tr>
<tr>
<td></td>
<td>LOCK_DLL_24_30</td>
<td>24 - 30 MHz</td>
<td></td>
</tr>
<tr>
<td>Using CLKFX outputs</td>
<td>LOCK_FX_MIN</td>
<td></td>
<td>10.00</td>
</tr>
<tr>
<td></td>
<td>LOCK_FX_MAX</td>
<td></td>
<td>10.00</td>
</tr>
<tr>
<td>Additional lock time with fine phase shifting</td>
<td>LOCK_DLL_FINE_SHIFT</td>
<td></td>
<td>50.00</td>
</tr>
</tbody>
</table>

**Fine Phase Shifting**

<table>
<thead>
<tr>
<th></th>
<th>FINE_SHIFT_RANGE</th>
<th>Min</th>
<th>Max</th>
</tr>
</thead>
<tbody>
<tr>
<td>Absolute shifting range</td>
<td></td>
<td>10.00</td>
<td>10.00</td>
</tr>
</tbody>
</table>

**Delay Lines**

<table>
<thead>
<tr>
<th></th>
<th>DCM_TAP_MIN</th>
<th>DCM_TAP_MAX</th>
</tr>
</thead>
<tbody>
<tr>
<td>Tap delay resolution</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Notes:**

1. “DLL outputs” is used here to describe the outputs: CLK0, CLK90, CLK180, CLK270, CLK2X, CLK2X180, and CLKDV.

## Frequency Synthesis

**Table 53: Frequency Synthesis**

<table>
<thead>
<tr>
<th>Attribute</th>
<th>Min</th>
<th>Max</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLKFX_MULTIPLY</td>
<td>2</td>
<td>32</td>
</tr>
<tr>
<td>CLKFX_DIVIDE</td>
<td>1</td>
<td>32</td>
</tr>
</tbody>
</table>

## Parameter Cross-Reference

**Table 54: Parameter Cross-Reference**

<table>
<thead>
<tr>
<th>Libraries Guide</th>
<th>Data Sheet</th>
</tr>
</thead>
<tbody>
<tr>
<td>DLL_CLKOUT_{(MIN</td>
<td>MAX)}_LF</td>
</tr>
<tr>
<td>DFS_CLKOUT_{(MIN</td>
<td>MAX)}_LF</td>
</tr>
<tr>
<td>DLL_CLKIN_{(MIN</td>
<td>MAX)}_LF</td>
</tr>
<tr>
<td>DFS_CLKIN_{(MIN</td>
<td>MAX)}_LF</td>
</tr>
<tr>
<td>DLL_CLKOUT_{(MIN</td>
<td>MAX)}_HF</td>
</tr>
<tr>
<td>DFS_CLKOUT_{(MIN</td>
<td>MAX)}_HF</td>
</tr>
<tr>
<td>DLL_CLKIN_{(MIN</td>
<td>MAX)}_HF</td>
</tr>
<tr>
<td>DFS_CLKIN_{(MIN</td>
<td>MAX)}_HF</td>
</tr>
</tbody>
</table>
Source-Synchronous Switching Characteristics

The parameters in this section provide the necessary values for calculating timing budgets for Virtex-II Pro source-synchronous transmitter and receiver data-valid windows.

Table 55: Duty Cycle Distortion and Clock-Tree Skew

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Device</th>
<th>Speed Grade</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Duty Cycle Distortion(^{(1)})</td>
<td>(T_{\text{DCD,CLK0}})</td>
<td>All</td>
<td>-7</td>
<td>ps</td>
</tr>
<tr>
<td></td>
<td>(T_{\text{DCD,CLK180}})</td>
<td>All</td>
<td>-6</td>
<td>ps</td>
</tr>
<tr>
<td>Clock Tree Skew(^{(2)})</td>
<td>(T_{\text{CKSKEW}})</td>
<td>XC2VP2</td>
<td></td>
<td>ps</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP4</td>
<td></td>
<td>ps</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP7</td>
<td></td>
<td>ps</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP20</td>
<td></td>
<td>ps</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP30</td>
<td></td>
<td>ps</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP40</td>
<td></td>
<td>ps</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP50</td>
<td></td>
<td>ps</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP70</td>
<td></td>
<td>ps</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP100</td>
<td></td>
<td>ps</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP125</td>
<td></td>
<td>ps</td>
</tr>
</tbody>
</table>

Notes:
1. These parameters represent the worst-case duty cycle distortion observable at the pins of the device using LVDS output buffers. For cases where other I/O standards are used, IBIS can be used to calculate any additional duty cycle distortion that might be caused by asymmetrical rise/fall times. 
   \(T_{\text{DCD,CLK0}}\) applies to cases where local (IOB) inversion is used to provide the negative-edge clock to the DDR element in the I/O. 
   \(T_{\text{DCD,CLK180}}\) applies to cases where the CLK180 output of the DCM is used to provide the negative-edge clock to the DDR element in the I/O.
2. This value represents the worst-case clock-tree skew observable between sequential I/O elements. Significantly less clock-tree skew exists for I/O registers that are close to each other and fed by the same or adjacent clock-tree branches. Use the Xilinx FPGA Editor and Timing Analyzer tools to evaluate clock skew specific to your application.

Table 56: Package Skew

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Device/Package</th>
<th>Value</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Package Skew(^{(1)})</td>
<td>(T_{\text{PKGSKEW}})</td>
<td></td>
<td></td>
<td>ps</td>
</tr>
</tbody>
</table>

Notes:
1. These values represent the worst-case skew between any two balls of the package: shortest flight time to longest flight time from Pad to Ball (7.1ps per mm).
2. Package trace length information is available for these device/package combinations. This information can be used to deskew the package.
### Table 57: Sample Window

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Device</th>
<th>Speed Grade</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Sampling Error at Receiver Pins(^{(1)})</td>
<td>(T_{\text{SAMP}})</td>
<td>XC2VP2</td>
<td>-7</td>
<td>ps</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP4</td>
<td>-6</td>
<td>ps</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP7</td>
<td>-5</td>
<td>ps</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP20</td>
<td></td>
<td>ps</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP30</td>
<td></td>
<td>ps</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP40</td>
<td></td>
<td>ps</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP50</td>
<td></td>
<td>ps</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP70</td>
<td></td>
<td>ps</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP100</td>
<td></td>
<td>ps</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP125</td>
<td></td>
<td>ps</td>
</tr>
</tbody>
</table>

**Notes:**
1. This parameter indicates the total sampling error of Virtex-II Pro DDR input registers across voltage, temperature, and process. The characterization methodology uses the DCM to capture the DDR input registers’ edges of operation. These measurements include:
   - CLK0 and CLK180 DCM jitter
   - Worst-case Duty-Cycle Distortion - \(T_{\text{DCD,CLK180}}\)
   - DCM accuracy (phase offset)
   - DCM phase shift resolution.
   These measurements do not include package or clock tree skew.

### Table 58: Pin-to-Pin Setup/Hold: Source-Synchronous Configuration

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Device</th>
<th>Speed Grade</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Data Input Set-Up and Hold Times Relative to a Forwarded Clock Input Pin, Using DCM and Global Clock Buffer. For situations where clock and data inputs conform to different standards, adjust the setup and hold values accordingly using the values shown in IOB Input Switching Characteristics Standard Adjustments, page 92.</td>
<td>(T_{\text{XXX}})</td>
<td>XC2VP2</td>
<td>-7</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP4</td>
<td>-6</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP7</td>
<td>-5</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP20</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP30</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP40</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP50</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP70</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP100</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XC2VP125</td>
<td></td>
<td>ns</td>
</tr>
</tbody>
</table>

**Notes:**
1. IFF = Input Flip-Flop
2. The timing values were measured using the fine-phase adjustment feature of the DCM.
3. The worst-case duty-cycle distortion and DCM jitter on CLK0 and CLK180 is included in these measurements.
Source Synchronous Timing Budgets

This section describes how to use the parameters provided in the Source-Synchronous Switching Characteristics section to develop system-specific timing budgets. The following analysis provides information necessary for determining Virtex-II Pro contributions to an overall system timing analysis; no assumptions are made about the effects of Inter-Symbol Interference or PCB skew.

Virtex-II Pro Transmitter Data-Valid Window (TX)

TX is the minimum aggregate valid data period for a source-synchronous data bus at the pins of the device and is calculated as follows:

\[ TX = Data\ Period - [Jitter(1) + Duty\ Cycle\ Distortion(2) + TCKSKEW(3) + TPKGSKEW(4)] \]

Notes:

1. Jitter values and accumulation methodology to be provided in a future release of this document. The absolute period jitter values found in the DCM Timing Parameters section of the particular DCM output clock used to clock the IOB FF can be used for a best case analysis.
2. This value depends on the clocking methodology used. See Note1 for Table 55.
3. This value represents the worst-case clock-tree skew observable between sequential I/O elements. Significantly less clock-tree skew exists for I/O registers that are close to each other and fed by the same or adjacent clock-tree branches. Use the Xilinx FPGA Editor and Timing Analyzer tools to evaluate clock skew specific to your application.
4. These values represent the worst-case skew between any two balls of the package: shortest flight time to longest flight time from Pad to Ball.

Virtex-II Pro Receiver Data-Valid Window (RX)

RX is the required minimum aggregate valid data period for a source-synchronous data bus at the pins of the device and is calculated as follows:

\[ RX = [TSAMP(1) + TCKSKEW(2) + TPKGSKEW(3)] \]

Notes:

1. This parameter indicates the total sampling error of Virtex-II Pro DDR input registers across voltage, temperature, and process. The characterization methodology uses the DCM to capture the DDR input registers’ edges of operation. These measurements include:
   - CLK0 and CLK180 DCM jitter in a quiet system
   - Worst-case duty-cycle distortion
   - DCM accuracy (phase offset)
   - DCM phase shift resolution.
2. This value represents the worst-case clock-tree skew observable between sequential I/O elements. Significantly less clock-tree skew exists for I/O registers that are close to each other and fed by the same or adjacent clock-tree branches. Use the Xilinx FPGA Editor and Timing Analyzer tools to evaluate clock skew specific to your application.
3. These values represent the worst-case skew between any two balls of the package: shortest flight time to longest flight time from Pad to Ball.

Revision History

This section records the change history for this module of the data sheet.

<table>
<thead>
<tr>
<th>Date</th>
<th>Version</th>
<th>Revision</th>
</tr>
</thead>
<tbody>
<tr>
<td>01/31/02</td>
<td>1.0</td>
<td>Initial Xilinx release.</td>
</tr>
<tr>
<td>06/17/02</td>
<td>2.0</td>
<td>• Added new Virtex-II Pro family members.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Added timing parameters from speedsfile v1.62.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Added Table 37, Pipelined Multiplier Switching Characteristics.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Added 3.3V-vs-2.5V table entries for some parameters.</td>
</tr>
<tr>
<td>09/03/02</td>
<td>2.1</td>
<td>• Added Source-Synchronous Switching Characteristics section.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Added absolute max ratings for 3.3V-vs-2.5V parameters in Table 1.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Added Recommended Operating Conditions for VIN and RocketIO transceiver footnote to Table 2.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Updated SSTL2 values in Table 6. Added SSTL18 values: Table 6, Table 31, Table 32.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Added Table 10, which contains LVPECL DC specifications.</td>
</tr>
<tr>
<td>09/27/02</td>
<td>2.2</td>
<td>Added section General Power Supply Requirements.</td>
</tr>
</tbody>
</table>
Virtex-II Pro Data Sheet Modules
The Virtex-II Pro Data Sheet contains the following modules:

- Virtex-II Pro™ Platform FPGAs: Introduction and Overview (Module 1)
- Virtex-II Pro™ Platform FPGAs: Functional Description (Module 2)
- Virtex-II Pro Platform FPGAs: DC and Switching Characteristics (Module 3)
- Virtex-II Pro Platform FPGAs: Pinout Information (Module 4)
Part II: Virtex-II Pro User Guide

This section contains information on how to configure and use Virtex-II Pro devices. The following topics are covered:

Chapter 1: Timing Models
Chapter 2: Design Considerations
Chapter 3: Configuration
Chapter 4: PCB Design Considerations
Appendix A: BitGen and PROMGen Switches and Options
Appendix B: XC18V00 Series PROMs
Chapter 1

Timing Models

Summary

The following topics are covered in this chapter:

- CLB / Slice Timing Models
- Block SelectRAM Timing Model
- Embedded Multiplier Timing Model
- IOB Timing Models
- Pin-to-Pin Timing Models
- Digital Clock Manager Timing Model
- Additional Timing Models in Other Publications: PPC405 Processor Block and RocketIO Transceiver

Introduction

Due to the large size and complexity of Virtex-II Pro FPGAs, understanding the timing associated with the various paths and functional elements has become a difficult and important problem. Although it is not necessary to understand the various timing parameters in order to implement most designs using Xilinx software, a thorough timing model can assist advanced users in analyzing critical paths or planning speed-sensitive designs.

The Timing Model chapter is broken up into sections consisting of three basic components:

- Functional Element Diagram - basic architectural schematic illustrating pins and connections.
- Timing Parameters - Virtex-II Pro Data Sheet timing parameter definitions.
- Timing Diagram - illustrates functional element timing parameters relative to each other.

This chapter was written with the Xilinx Timing Analyzer software (TRCE) in mind. All pin names, parameter names, and paths are consistent with Post Route Timing and Pre-Route Static Timing reports. Use the models in this chapter in conjunction with both the Timing Analyzer software and the section on switching characteristics in the Virtex-II Pro Data Sheet. Most of the timing parameters found in the section on switching characteristics are described in this chapter.
CLB / Slice Timing Models

The three sections below describe all timing parameters reported in the Virtex-II Pro Data Sheet that are associated with slices and Configurable Logic Blocks (CLBs). The sections correspond to their respective (switching characteristics) sections in the data sheet:

- General Slice Timing Model and Parameters (CLB Switching Characteristics)
- Slice Distributed RAM Timing Model and Parameters (CLB Distributed RAM Switching Characteristics)
- Slice SRL Timing Model and Parameters (CLB SRL Switching Characteristics)

General Slice Timing Model and Parameters

Figure 1-1 illustrates the details of a Virtex-II Pro slice.

Note: Some elements of the Virtex-II Pro slice have been omitted for clarity. Only the elements relevant to the timing paths described in this section are shown.
## CLB / Slice Timing Models

### Timing Parameters

#### Table 1-1: General Slice Timing Parameters

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>$T_{ILO}$</td>
<td>F/G inputs to X/Y outputs</td>
<td></td>
<td>Propagation delay from the F/G inputs of the slice, through the look-up tables (LUTs), to the X/Y outputs of the slice.</td>
</tr>
<tr>
<td>$T_{IF5}$</td>
<td>F/G inputs to F5 output</td>
<td></td>
<td>Propagation delay from the F/G inputs of the slice, through the LUTs and MUXF5 to the F5 output of the slice.</td>
</tr>
<tr>
<td>$T_{IF5X}$</td>
<td>F/G inputs to X output</td>
<td></td>
<td>Propagation delay from the F/G inputs of the slice, through the LUTs and MUXF5 to the X output of the slice.</td>
</tr>
<tr>
<td>$T_{IFXY}$</td>
<td>FXINA/FXINB inputs to Y output</td>
<td></td>
<td>Propagation delay from the FXINA/FXINB inputs, through MUXFX to the Y output of the slice.</td>
</tr>
<tr>
<td>$T_{IFNCTL}$</td>
<td>Transparent Latch input to XQ/YQ outputs</td>
<td></td>
<td>Incremental delay through a transparent latch to XQ/YQ outputs.</td>
</tr>
</tbody>
</table>

#### Sequential Delays

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>$T_{CKO}$</td>
<td>FF Clock (CLK) to XQ/YQ outputs</td>
<td></td>
<td>Time after the clock that data is stable at the XQ/YQ outputs of the slice sequential elements (configured as a flip-flop).</td>
</tr>
<tr>
<td>$T_{CKLO}$</td>
<td>Latch Clock (CLK) to XQ/YQ outputs</td>
<td></td>
<td>Time after the clock that data is stable at the XQ/YQ outputs of the slice sequential elements (configured as a latch).</td>
</tr>
</tbody>
</table>

#### Setup and Hold for Slice Sequential Elements

$T_{xxCK} =$ Setup time (before clock edge)  
$T_{CKxx} =$ Hold time (after clock edge)  

The following descriptions are for setup times only.

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>$T_{DICK}/T_{CKDI}$</td>
<td>BX/BY inputs</td>
<td></td>
<td>Time before Clock (CLK) that data from the BX or BY inputs of the slice must be stable at the D-input of the slice sequential elements (configured as a flip-flop).</td>
</tr>
<tr>
<td>$T_{DYCK}/T_{CKDY}$</td>
<td>DY input</td>
<td></td>
<td>Time before Clock (CLK) that data from the DY input of the slice must be stable at the D-input of the slice sequential elements (configured as a flip-flop).</td>
</tr>
<tr>
<td>$T_{DXCK}/T_{CKDX}$</td>
<td>DX input</td>
<td></td>
<td>Time before Clock (CLK) that data from the DX input of the slice must be stable at the D-input of the slice sequential elements (configured as a flip-flop).</td>
</tr>
<tr>
<td>$T_{CECK}/T_{CKCE}$</td>
<td>CE input</td>
<td></td>
<td>Time before Clock (CLK) that the CE (Clock Enable) input of the slice must be stable at the CE-input of the slice sequential elements (configured as a flip-flop).</td>
</tr>
</tbody>
</table>
Table 1-1: General Slice Timing Parameters (Continued)

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>(T_{RCK}/T_{CKR})</td>
<td>SR/BY inputs</td>
<td></td>
<td>Time before CLK that the SR (Set/Reset) and the BY (Rev) inputs of the slice must be stable at the SR/Rev-inputs of the slice sequential elements (configured as a flip-flop). Synchronous set/reset only.</td>
</tr>
<tr>
<td>(T_{CH})</td>
<td></td>
<td></td>
<td>Minimum Pulse Width, High.</td>
</tr>
<tr>
<td>(T_{CL})</td>
<td></td>
<td></td>
<td>Minimum Pulse Width, Low.</td>
</tr>
</tbody>
</table>

Set/Reset

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>(T_{RPW})</td>
<td></td>
<td></td>
<td>Minimum Pulse Width for the SR (Set/Reset) and BY (Rev) pins.</td>
</tr>
<tr>
<td>(T_{RQ})</td>
<td></td>
<td></td>
<td>Propagation delay for an asynchronous Set/Reset of the slice sequential elements. From SR/BY inputs to XQ/YQ outputs.</td>
</tr>
<tr>
<td>(F_{TOG})</td>
<td></td>
<td></td>
<td>Toggle Frequency - Maximum Frequency that a CLB flip-flop can be clocked: (1/(T_{CH}+T_{CL}))</td>
</tr>
</tbody>
</table>

Timing Characteristics

Figure 1-2 illustrates general timing characteristics of a Virtex-II Pro slice.

- At time \(T_{CECK}\) before Clock Event 1, the Clock-Enable signal becomes valid-high at the CE input of the slice register.
- At time \(T_{DYCK}\) before Clock Event 1, data from the DY input becomes valid-high at the D input of the slice register and is reflected on the YQ pin at time \(T_{CKO}\) after Clock Event 1*.
- At time \(T_{RCK}\) before Clock Event 3, the SR signal (configured as synchronous reset in this case) becomes valid-high, resetting the slice register, and this is reflected on the YQ pin at time \(T_{CKO}\) after Clock Event 3.

NOTE: In most cases software uses the DX/DY inputs to route data to the slice registers when at all possible. This is the fastest path to the slice registers and saves other slice routing resources.
Slice Distributed RAM Timing Model and Parameters

Figure 1-3 illustrates the details of distributed RAM implemented in a Virtex-II Pro slice. Note: Some elements of the Virtex-II Pro slice have been omitted for clarity. Only the elements relevant to the timing paths described in this section are shown.

Figure 1-3: Virtex-II Pro Slice Distributed RAM
### Timing Parameters

**Table 1-2: Slice Distributed RAM Timing Parameters**

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>$T_{SHCKO16}$</td>
<td>CLK to X/Y outputs (WE active) in 16x1 mode</td>
<td></td>
<td>Time after the Clock (CLK) of a WRITE operation that the data written to the distributed RAM (in 16x1 mode) is stable on the X/Y outputs of the slice.</td>
</tr>
<tr>
<td>$T_{SHCKO32}$</td>
<td>CLK to X/Y outputs (WE active) in 32x1 mode</td>
<td></td>
<td>Time after the Clock (CLK) of a WRITE operation that the data written to the distributed RAM (in 32x1 mode) is stable on the X/Y outputs of the slice.</td>
</tr>
<tr>
<td>$T_{SHCKOF5}$</td>
<td>CLK to F5 output (WE active)</td>
<td></td>
<td>Time after the Clock (CLK) of a WRITE operation that the data written to the distributed RAM is stable on the F5 output of the slice.</td>
</tr>
</tbody>
</table>

#### Setup and Hold for Slice LUT Configured as RAM (Distributed RAM)

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>$T_S$</td>
<td>Setup time (before clock edge)</td>
<td></td>
<td>The following descriptions are for setup times only.</td>
</tr>
<tr>
<td>$T_{xH}$</td>
<td>Hold time (after clock edge)</td>
<td></td>
<td>Time before the clock that data must be stable at the DI input of the slice LUT (configured as RAM), via the slice BX/BY inputs.</td>
</tr>
<tr>
<td>$T_Ds/T_{DH}$</td>
<td>BX/BY Data inputs (DI)</td>
<td></td>
<td>Time before the clock that address signals must be stable at the F/G inputs of the slice LUT (configured as RAM).</td>
</tr>
<tr>
<td>$T_{AS}/T_{AH}$</td>
<td>F/G Address inputs</td>
<td></td>
<td>Time before the clock that the Write Enable signal must be stable at the WE input of the slice LUT (configured as RAM).</td>
</tr>
<tr>
<td>$T_{WES}/T_{WEH}$</td>
<td>WE input (SR)</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

#### Clock CLK

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>$T_{WPH}$</td>
<td></td>
<td></td>
<td>Minimum Pulse Width, High (for a Distributed RAM clock).</td>
</tr>
<tr>
<td>$T_{WPL}$</td>
<td></td>
<td></td>
<td>Minimum Pulse Width, Low (for a Distributed RAM clock).</td>
</tr>
<tr>
<td>$T_{WC}$</td>
<td></td>
<td></td>
<td>Minimum clock period to meet address write cycle time.</td>
</tr>
</tbody>
</table>
Timing Characteristics

Figure 1-4 illustrates the timing characteristics of a 16-bit distributed RAM implemented in a Virtex-II Pro slice (LUT configured as RAM).

Clock Event 1: WRITE Operation

During a WRITE operation, the contents of the memory at the address on the ADDR inputs is changed. The data written to this memory location is reflected on the X/Y outputs synchronously.

- At time $T_{WES}$ before Clock Event 1, the Write Enable signal (WE) becomes valid-high, enabling the RAM for the following WRITE operation.
- At time $T_{AS}$ before Clock Event 1, the address (2) becomes valid at the F/G inputs of the RAM.
- At time $T_{DS}$ before Clock Event 1, the DATA becomes valid (1) at the DI input of the RAM and is reflected on the X/Y output at time $T_{SHCK016}$ after Clock Event 1.

Clock Event 2: READ Operation

All READ operations are asynchronous in distributed RAM. As long as write-enable (WE) is Low, the address bus can be asserted at any time, and the contents of the RAM at that address are reflected on the X/Y outputs after a delay of length $T_{ILO}$ (propagation delay through a LUT). Note that the Address (F) is asserted after Clock Event 2, and that the contents of the RAM at that location are reflected on the output after a delay of length $T_{ILO}$. 
Slice SRL Timing Model and Parameters

Figure 1-5 illustrates shift register implementation in a Virtex-II Pro slice.

Note: Some elements of the Virtex-II Pro slice have been omitted for clarity. Only the elements relevant to the timing paths described in this section are shown.

Figure 1-5: Virtex-II Pro Slice SRL
Timing Parameters

<table>
<thead>
<tr>
<th>Table 1-3: Slice SRL Timing Parameters</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>T&lt;sub&gt;REG&lt;/sub&gt;</td>
<td>CLK to X/Y outputs</td>
<td></td>
<td>Time after the Clock (CLK) of a WRITE operation that the data written to the SRL is stable on the X/Y outputs of the slice.</td>
</tr>
<tr>
<td>T&lt;sub&gt;CKSH&lt;/sub&gt;</td>
<td>CLK to Shiftout</td>
<td></td>
<td>Time after the Clock (CLK) of a WRITE operation that the data written to the SRL is stable on the Shiftout or XB/YB outputs of the slice.</td>
</tr>
<tr>
<td>T&lt;sub&gt;REGF5&lt;/sub&gt;</td>
<td>CLK to F5 output</td>
<td></td>
<td>Time after the Clock (CLK) of a WRITE operation that the data written to the SRL is stable on the F5 output of the slice.</td>
</tr>
</tbody>
</table>

Setup/Hold for Slice LUT Configured as SRL (Select Shift Register)

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>T&lt;sub&gt;SXS&lt;/sub&gt; = Setup time (before clock edge)</td>
<td></td>
<td></td>
<td>Time before the clock that data must be stable at the DI input of the slice LUT (configured as SRL), via the slice BX/BY inputs.</td>
</tr>
<tr>
<td>T&lt;sub&gt;xH&lt;/sub&gt; = Hold time (after clock edge)</td>
<td></td>
<td></td>
<td>Time before the clock that the Write Enable signal must be stable at the WE input of the slice LUT (configured as SRL).</td>
</tr>
</tbody>
</table>

Clock CLK

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>T&lt;sub&gt;SRP&lt;/sub&gt;H</td>
<td>Minimum Pulse Width, High (for SRL clock).</td>
<td></td>
<td></td>
</tr>
<tr>
<td>T&lt;sub&gt;SRL&lt;/sub&gt;L</td>
<td>Minimum Pulse Width, Low (for SRL clock).</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Timing Characteristics

Figure 1-6 illustrates the timing characteristics of a 16-bit shift register implemented in a Virtex-II Pro slice (LUT configured as SRL).
Clock Event 1: Shift_In

During a WRITE (Shift_In) operation, the single-bit content of the register at the address on the ADDR inputs is changed, as data is shifted through the SRL. The data written to this register is reflected on the X/Y outputs synchronously, if the address is unchanged during the clock event. If the ADDR inputs are changed during a clock event, the value of the data at the addressable output (D) is invalid.

- At time $T_{WSS}$ before Clock Event 1, the Write Enable signal (SR) becomes valid-high, enabling the SRL for the WRITE operation that follows.
- At time $T_{SRLDS}$ before Clock Event 1 the data becomes valid (0) at the DI input of the SRL and is reflected on the X/Y output after a delay of length $T_{REG}$ after Clock Event 1$^*$. 
  NOTE: Since the address 0 is specified at Clock Event 1, the data on the DI input is reflected at the D output, because it is written to Register 0.

Clock Event 2: Shift_In

- At time $T_{SRLDS}$ before Clock Event 2, the data becomes valid (1) at the DI input of the SRL and is reflected on the X/Y output after a delay of length $T_{REG}$ after Clock Event 2$^*$. 
  NOTE: Since the address 0 is still specified at Clock Event 2, the data on the DI input is reflected at the D output, because it is written to Register 0.

Clock Event 3: Shift_In / Addressable (Asynchronous) READ

All READ operations are asynchronous. If the address is changed (between clock events), the contents of the register at that address are reflected at the addressable output (X/Y outputs) after a delay of length $T_{ILO}$ (propagation delay through a LUT).

- At time $T_{SRLDS}$ before Clock Event 3 the Data becomes valid (1) at the DI input of the SRL, and is reflected on the X/Y output $T_{REG}$ time after Clock Event 3.
- Notice that the address is changed (from 0 to 2) some time after Clock Event 3. The value stored in Register 2 at this time is a 0 (in this example, this was the first data shifted in), and it is reflected on the X/Y output after a delay of length $T_{ILO}$.

Clock Event 16: MSB (Most Significant Bit) Changes

- At time $T_{REGXB}$ after Clock Event 16, the first bit shifted into the SRL becomes valid (logical 0 in this case) on the XB output of the slice via the MC15 output of the LUT (SRL).
Block SelectRAM Timing Model

Introduction

This section describes the timing parameters associated with the block SelectRAM (illustrated in Figure 1-7) in Virtex-II Pro FPGA devices. This section is intended to be used with the section on switching characteristics in the Virtex-II Pro Data Sheet and the Timing Analyzer (TRCE) report from Xilinx software. For specific timing parameter values, refer to the switching characteristics section in the Virtex-II Pro Data Sheet.

Timing Parameters

Table 1-4: Block SelectRAM Timing Parameters

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Setup and Hold Relative to Clock (CLK)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{BCK}$ = Setup time (before clock edge)</td>
<td>Time before the clock that address signals must be stable at the ADDR inputs of the block RAM.</td>
<td>ADDR</td>
<td></td>
</tr>
<tr>
<td>$T_{BCKS}$ = Hold time (after clock edge)</td>
<td>Time before the clock that address signals must be stable at the ADDR inputs of the block RAM.</td>
<td>ADDR</td>
<td></td>
</tr>
<tr>
<td>$T_{BACK}$/ $T_{BCKA}$</td>
<td>Address inputs</td>
<td>ADDR</td>
<td>Time before the clock that address signals must be stable at the ADDR inputs of the block RAM.</td>
</tr>
<tr>
<td>$T_{BDCK}$/ $T_{BCKD}$</td>
<td>Data inputs</td>
<td>DI</td>
<td>Time before the clock that data must be stable at the DI inputs of the block RAM.</td>
</tr>
<tr>
<td>$T_{BECK}$/ $T_{BCKE}$</td>
<td>Enable</td>
<td>EN</td>
<td>Time before the clock that the enable signal must be stable at the EN input of the block RAM.</td>
</tr>
<tr>
<td>$T_{BRCK}$/ $T_{BCKR}$</td>
<td>Synchronous Set/Reset</td>
<td>SSR</td>
<td>Time before the clock that the synchronous set/reset signal must be stable at the SSR input of the block RAM.</td>
</tr>
<tr>
<td>$T_{BWCK}$/ $T_{BCKW}$</td>
<td>Write Enable</td>
<td>WE</td>
<td>Time before the clock that the write enable signal must be stable at the WE input of the block RAM.</td>
</tr>
<tr>
<td>Clock to Out</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{BCKO}$</td>
<td>Clock to Output</td>
<td>CLK</td>
<td>Time after the clock that the output data is stable at the DO outputs of the block RAM.</td>
</tr>
<tr>
<td>Clock</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{BPWH}$</td>
<td>Clock</td>
<td>CLK</td>
<td>Minimum pulse width, high.</td>
</tr>
<tr>
<td>$T_{BPWL}$</td>
<td>Clock</td>
<td>CLK</td>
<td>Minimum pulse width, low.</td>
</tr>
</tbody>
</table>
Timing Characteristics

The timing diagram in Figure 1-8 describes a single-port block RAM in Write-First mode. The timing for Read-First and No-Change modes are similar (see Design Considerations.)

At time 0, the block RAM is disabled; EN (enable) is low.

Clock Event 1

READ Operation:
During a read operation, the contents of the memory at the address on the ADDR inputs are unchanged.

- \( T_{BACK} \) before Clock Event 1, address 00 becomes valid at the ADDR inputs of the block RAM.
- At time \( T_{BECK} \) before Clock Event 1, Enable goes High at the EN input of the block RAM, enabling the memory for the READ operation that follows.
- At time \( T_{BCKO} \) after Clock Event 1, the contents of the memory at address 00 become stable at the DO pins of the block RAM.

Clock Event 2

WRITE Operation:
During a write operation, the content of the memory at the location specified by the address on the ADDR inputs is replaced by the value on the DI pins and is immediately reflected on the output latches (in WRITE-FIRST mode); EN (enable) is high.

- At time \( T_{BACK} \) before Clock Event 2, address 0F becomes valid at the ADDR inputs of the block RAM.
- At time \( T_{BDCK} \) before Clock Event 2, data CCCC becomes valid at the DI inputs of the block RAM.
- At time \( T_{BWCK} \) before Clock Event 2, Write Enable becomes valid at the WE following the block RAM.
- At time \( T_{BCKO} \) after Clock Event 2, data CCCC becomes valid at the DO outputs of the block RAM.
Clock Event 4

SSR (Synchronous Set/Reset) Operation

During an SSR operation, initialization parameter value SRVAL is loaded into the output latches of the block SelectRAM. The SSR operation does NOT change the contents of the memory and is independent of the ADDR and DI inputs.

- At time $T_{BRCK}$ before Clock Event 4, the synchronous set/reset signal becomes valid (High) at the SSR input of the block RAM.
- At time $T_{BECKO}$ after Clock Event 4, the SRVAL 0101 becomes valid at the DO outputs of the block RAM.

Clock Event 5

Disable Operation:

De-asserting the enable signal EN disables any write, read or SSR operation. The disable operation does NOT change the contents of the memory or the values of the output latches.

- At time $T_{BECK}$ before Clock Event 5, the enable signal becomes valid (Low) at the EN input of the block RAM.
- After Clock Event 5, the data on the DO outputs of the block RAM is unchanged.

Timing Model

Figure 1-9 illustrates the delay paths associated with the implementation of block SelectRAM. This example takes the simplest paths on and off chip (these paths can vary greatly depending on the design). This timing model demonstrates how and where the block SelectRAM timing parameters are used.

![Block SelectRAM Timing Model](image)

NET = Varying interconnect delays

$T_{IOPI}$ = Pad to I-output of IOB delay

$T_{IOOP}$ = O-input of IOB to pad delay

$T_{GI0O}$ = BUFGMUX delay
Embedded Multiplier Timing Model

Introduction

This section explains all timing parameters associated with the use of embedded 18-bit x 18-bit multipliers in Virtex-II Pro FPGAs (see Figure 1-10). The propagation delays through the embedded multiplier differ based on the size of the multiplier function implemented. The longest delay through the multiplier is to the highest order bit output (P35). Therefore, if an 18-bit x 18-bit signed multiplier is implemented, the worst-case delay for this function is the longest delay associated with the embedded multiplier block. If smaller (LSB) multipliers are used, shorter delays can be realized.

This section is intended to be used in conjunction with the section on switching characteristics in the Virtex-II Pro Data Sheet and the Timing Analyzer (TRCE) report from Xilinx software. For specific timing parameter values, refer to the Virtex-II Pro Data Sheet.

Timing Parameters

Propagation Delays (All Worst-Case)

Table 1-5 lists the different values for the \( T_{MULT} \) timing parameter reported by the Timing Analyzer software. These values correspond to the propagation delay through the multiplier to a specific output pin of the multiplier block.

Table 1-5: Multiplier Switching Characteristics

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
</tr>
</thead>
<tbody>
<tr>
<td>Propagation Delay to Output Pin</td>
<td></td>
</tr>
<tr>
<td>Input to Pin35</td>
<td>( T_{MULT} )</td>
</tr>
<tr>
<td>Input to Pin34</td>
<td>( T_{MULT} )</td>
</tr>
<tr>
<td>Input to Pin33</td>
<td>( T_{MULT} )</td>
</tr>
<tr>
<td>Input to Pin32</td>
<td>( T_{MULT} )</td>
</tr>
<tr>
<td>Input to Pin31</td>
<td>( T_{MULT} )</td>
</tr>
<tr>
<td>Input to Pin30</td>
<td>( T_{MULT} )</td>
</tr>
<tr>
<td>Input to Pin29</td>
<td>( T_{MULT} )</td>
</tr>
<tr>
<td>Input to Pin28</td>
<td>( T_{MULT} )</td>
</tr>
<tr>
<td>Input to Pin27</td>
<td>( T_{MULT} )</td>
</tr>
<tr>
<td>Input to Pin26</td>
<td>( T_{MULT} )</td>
</tr>
<tr>
<td>Input to Pin25</td>
<td>( T_{MULT} )</td>
</tr>
<tr>
<td>Input to Pin24</td>
<td>( T_{MULT} )</td>
</tr>
<tr>
<td>Input to Pin23</td>
<td>( T_{MULT} )</td>
</tr>
<tr>
<td>Input to Pin22</td>
<td>( T_{MULT} )</td>
</tr>
</tbody>
</table>
The shortest delay is to pin 0 and the longest delay to pin 35. Notice that the delay-to-pin ratio is essentially linear (see Figure 1-11). This implies that smaller multiply functions are faster than larger ones. This is true as long as the LSB inputs are used.

Table 1-5: Multiplier Switching Characteristics (Continued)

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
</tr>
</thead>
<tbody>
<tr>
<td>Input to Pin21</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin20</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin19</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin18</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin17</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin16</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin15</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin14</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin13</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin12</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin11</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin10</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin9</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin8</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin7</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin6</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin5</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin4</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin3</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin2</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin1</td>
<td>T_{MULT}</td>
</tr>
<tr>
<td>Input to Pin0</td>
<td>T_{MULT}</td>
</tr>
</tbody>
</table>

Figure 1-11: Pin-to-Delay Ratio Curve
Timing Characteristics

Figure 1-12 illustrates the result (outputs) of a 4-bit x 4-bit unsigned multiply implemented in an embedded multiplier block.

At time 0 the two 4-bit numbers to be multiplied become valid at the A[0..3], B[0..3] inputs to the embedded multiplier. The result appears on the output pins P[0..7] in a staggered fashion. First, P0 becomes valid at time $T_{MULT}(P0)$, followed by each subsequent output pin, until P7 becomes valid at time $T_{MULT}(P7)$. In this case, the delay for this multiply function should correspond to that of Pin 7. In other words, the result is not valid until all output pins become valid.
IOB Timing Models

The following three sections describe all timing parameters associated with the Virtex-II Pro IOB. These three sections are:

- IOB Input Timing Model and Parameters
- IOB Output Timing Model and Parameters
- IOB 3-State Timing Model and Parameters

These sections are intended to be used in conjunction with the section on switching characteristics in the Virtex-II Pro Data Sheet and the Timing Analyzer (TRCE) report from Xilinx software. For specific timing parameter values, refer to the Virtex-II Pro Data Sheet.

A Note on I/O Standard Adjustments:

The "IOB Input and Output Switching Characteristics Standard Adjustments" tables in Module 3 of the Virtex-II Pro Data Sheet are delay adders (+/-) to be added to all timing parameter values associated with the IOB and the Global Clock (see Pin-to-Pin Timing Models, page 149), if an I/O standard other than LVCMOS_25 12 mA is used.

All values specified in the Virtex-II Pro Data Sheet for the parameters covered in this section are specified for LVCMOS_25 12 mA. If another I/O standard is used, these delays change. However, there are several exceptions. The following parameters associated with the pad going to high-impedance (3-State buffer OFF) should NOT be adjusted:

- TIOTHZ
- TIOTLPHZ
- TGTS
- TIOCKHZ
- TIOSRHZ
IOB Input Timing Model and Parameters

Figure 1-13 illustrates IOB inputs.

Figure 1-13: Virtex-II Pro IOB Inputs

Timing Parameters

Table 1-6: IOB Input Timing Parameters

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>T_{IOPI}</td>
<td>Propagation delay from the pad to I output of the IOB with no delay adder.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>T_{IOPID}</td>
<td>Propagation delay from the pad to I output of the IOB with the delay adder.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>T_{IOPLI}</td>
<td>Propagation delay from the pad to IQ output of the IOB via transparent latch with no delay adder.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>T_{IOPLID}</td>
<td>Propagation delay from the pad to IQ output of the IOB via transparent latch with the delay adder.</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
### Table 1-6: IOB Input Timing Parameters

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>( T_{xxCK} ) = Setup time (before clock edge) ( T_{xxCKxx} ) = Hold time (after clock edge)</td>
<td></td>
<td></td>
<td>The following descriptions are for setup times only.</td>
</tr>
<tr>
<td>( T_{IOPick}/T_{IOlckp} )</td>
<td>ID input with NO delay</td>
<td></td>
<td>Time before the clock that the input signal from the pad must be stable at the ID input of the IOB Input Register, with no delay.</td>
</tr>
<tr>
<td>( T_{IOpickd}/T_{IOlckpd} )</td>
<td>ID input with delay</td>
<td></td>
<td>Time before the clock that the input signal from the pad must be stable at the ID input of the IOB Input Register, with delay.</td>
</tr>
<tr>
<td>( T_{IOiceck}/T_{IOckice} )</td>
<td>ICE input</td>
<td></td>
<td>Time before the clock that the Clock Enable signal must be stable at the ICE input of the IOB Input Register.</td>
</tr>
<tr>
<td>( T_{Iosrcki} )</td>
<td>SR input (IFE, synchronous)</td>
<td></td>
<td>Time before the clock that the Set/Reset signal must be stable at the SR input of the IOB Input Register.</td>
</tr>
<tr>
<td>( T_{Iockiq} )</td>
<td>Clock (CLK) to (IQ) output</td>
<td></td>
<td>Time after the clock that the output data is stable at the IQ output of the IOB Input Register.</td>
</tr>
<tr>
<td>( T_{Iosriq} )</td>
<td>SR Input to IQ (asynchronous)</td>
<td></td>
<td>Time after the Set/Reset signal of the IOB is toggled that the output of the IOB input register (IQ) reflects the signal.</td>
</tr>
<tr>
<td>( T_{Gsrq} )</td>
<td>GSR to output IQ</td>
<td></td>
<td>Time after the Global Set/Reset is toggled that the output of the IOB input register (IQ) reflects the set or reset.</td>
</tr>
</tbody>
</table>
Timing Characteristics

Figure 1-14 illustrates IOB input register timing.

Clock Event 1
- At time T\textsubscript{IOICECK} before Clock Event 1, the input clock enable signal becomes valid-high at the ICE input of the input register, enabling the input register for incoming data.
- At time T\textsubscript{IOPICK} before Clock Event 1, the input signal becomes valid-high at the I input of the input register and is reflected on the IQ output of the input register at time T\textsubscript{IOCKIQ} after Clock Event 1.

Clock Event 4
- At time T\textsubscript{IOSRCKI} before Clock Event 4, the SR signal (configured as synchronous reset in this case) becomes valid-high resetting the input register and reflected at the IQ output of the IOB at time T\textsubscript{IOCKIQ} after Clock Event 4.
Timing Characteristics, DDR

Figure 1-15 illustrates IOB DDR input register timing.

Clock Event 1
- At time $T_{IOICECK}$ before Clock Event 1 the input clock enable signal becomes valid-high at the ICE input of both of the DDR input registers, enabling them for incoming data. Since the ICE and I signals are common to both DDR registers, care must be taken to toggle these signals between the rising edges of ICLK1 and ICLK2 as well as meeting the register setup-time relative to both clocks.
- At time $T_{IOPICK}$ before Clock Event 1 (rising edge of ICLK1) the input signal becomes valid-high at the I input of both registers and is reflected on the IQ1 output of input-register 1 at time $T_{IOCKIQ}$ after Clock Event 1.

Clock Event 2
At time $T_{IOPICK}$ before Clock Event 2 (rising edge of ICLK2) the input signal becomes valid-low at the I input of both registers and is reflected on the IQ2 output of input-register 2 at time $T_{IOCKIQ}$ after Clock Event 2 (no change in this case).

Clock Event 9
At time $T_{IOSRCK1}$ before Clock Event 9 the SR signal (configured as synchronous reset in this case) becomes valid-high resetting input-register 1 (IQ1) at time $T_{IOCKIQ}$ after Clock Event 9, and input-register 2 (IQ2) at time $T_{IOCKIQ}$ after Clock Event 10.
IOB Output Timing Model and Parameters

Figure 1-16 illustrates IOB outputs.

![Virtex-II Pro IOB Output Diagram]

Timing Parameters

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Propagation Delays</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{IOOP}$</td>
<td></td>
<td></td>
<td>Propagation delay from the O input of the IOB to the pad.</td>
</tr>
<tr>
<td>$T_{IOOLP}$</td>
<td></td>
<td></td>
<td>Propagation delay from the O input of the IOB to the pad via transparent latch.</td>
</tr>
<tr>
<td><strong>Setup and Hold With Respect to Clock at IOB Output Register</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{xxCK}$</td>
<td></td>
<td></td>
<td>The following descriptions are for setup times only.</td>
</tr>
<tr>
<td>$T_{xxCKxx}$</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$T_{IOOCLK}/T_{IOCKO}$</td>
<td>O input</td>
<td></td>
<td>Time before the clock that data must be stable at the O input of the IOB Output Register.</td>
</tr>
<tr>
<td>$T_{IOOCECK}/T_{IOCKOCE}$</td>
<td>OCE input</td>
<td></td>
<td>Time before the clock that the Clock Enable signal must be stable at the OCE input of the IOB Output Register.</td>
</tr>
<tr>
<td>$T_{IOSRCKO}/T_{IOCKOSR}$</td>
<td>SR input (OFF)</td>
<td></td>
<td>Time before the clock that the Set/Reset signal must be stable at the SR input of the IOB Output Register.</td>
</tr>
</tbody>
</table>
Timing Characteristics

Figure 1-17 illustrates IOB output register timing.

Clock Event 1
- At time $t_{IOOCECK}$ before Clock Event 1, the output clock enable signal becomes valid-high at the OCE input of the output register, enabling the output register for incoming data.
- At time $t_{IOOCLK}$ before Clock Event 1, the output signal becomes valid-high at the O input of the output register and is reflected on the pad at time $t_{IOCKP}$ after Clock Event 1.

Clock Event 4
At time $t_{IOSRCKO}$ before Clock Event 4, the SR signal (configured as synchronous reset in this case) becomes valid-high, resetting the output register and reflected on the pad at time $t_{IOCKP}$ after Clock Event 4.

Table 1-7: IOB Output Timing Parameters

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>$T_{IOCKP}$</td>
<td>Clock (CLK) to pad</td>
<td></td>
<td>Time after the clock that the output data is stable at the pad.</td>
</tr>
</tbody>
</table>

Set/Reset Delays

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>$T_{IOSRP}$</td>
<td>SR Input to pad (asynchronous)</td>
<td>Time after the Set/Reset input of the IOB is toggled that the pad reflects the set or reset.</td>
</tr>
<tr>
<td>$T_{IOGSRQ}$</td>
<td>GSR to pad</td>
<td>Time after the Global Set/Reset is toggled that the pad reflects the set or reset.</td>
</tr>
</tbody>
</table>
Timing Characteristics, DDR

Figure 1-18 illustrates IOB DDR output register timing.

Clock Event 1

- At time $T_{I\text{OOCECK}}$ before Clock Event 1, the output clock enable signal becomes valid-high at the OCE input of both of the DDR output registers, enabling them for incoming data. Since the OCE signal is common to both DDR registers, care must be taken to toggle this signal between the rising edges of OTCLK1 and OTCLK2 as well as meeting the register setup-time relative to both clocks.

- At time $T_{I\text{OOCK}}$ before Clock Event 1 (rising edge of OTCLK1), the output signal O1 becomes valid-high at the O1 input of output register 1 and is reflected on the pad at time $T_{I\text{OCKP}}$ after Clock Event 1.

Clock Event 2

At time $T_{I\text{OOCK}}$ before Clock Event 2 (rising edge of OTCLK2), the output signal O2 becomes valid-high at the O2 input of output register 2 and is reflected on the pad at time $T_{I\text{OCKP}}$ after Clock Event 2 (no change on the pad in this case).

Clock Event 9

At time $T_{I\text{OSRCKO}}$ before Clock Event 9, the SR signal (configured as synchronous reset in this case) becomes valid-high, resetting output-register 1 (reflected on the pad at time $T_{I\text{OCKP}}$ after Clock Event 9) (no change in this case) and output-register 2 (reflected on the pad at time $T_{I\text{OCKP}}$ after Clock Event 10) (no change in this case).
IOB 3-State Timing Model and Parameters

Figure 1-19 illustrates IOB 3-state timing.

Timing Parameters

Table 1-8: IOB 3-State Timing Parameters

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>$T_{IOTHZ}$</td>
<td></td>
<td></td>
<td>Time after T input of the IOB is toggled that the pad goes to high-impedance.</td>
</tr>
<tr>
<td>$T_{IOTON}$</td>
<td></td>
<td></td>
<td>Time after the T input of the IOB is toggled that the pad goes from high-impedance to valid data.</td>
</tr>
<tr>
<td>$T_{IOTLPHZ}$</td>
<td></td>
<td></td>
<td>Time after the T input of the IOB via transparent latch is toggled that the pad goes to high-impedance.</td>
</tr>
<tr>
<td>$T_{IOTLPON}$</td>
<td></td>
<td></td>
<td>Time after the T input of the IOB via transparent latch is toggled that the pad goes from high-impedance to valid data.</td>
</tr>
</tbody>
</table>
Table 1-8: IOB 3-State Timing Parameters (Continued)

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>$T_{GTS}$</td>
<td></td>
<td></td>
<td>Time after the Global 3-state signal is asserted that the pad goes to high-impedance.</td>
</tr>
</tbody>
</table>

Setup and Hold With Respect to Clock at IOB 3-State Register

- $T_{xxCK} = $ Setup time (before clock edge)
- $T_{xxCKxx} =$ Hold time (after clock edge)

The following descriptions are for setup times only.

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>$T_{TOTCK}/T_{TOCKT}$</td>
<td>$T$ input</td>
<td></td>
<td>Time before the clock that the signal must be stable at the $T$ input of the IOB 3-state Register.</td>
</tr>
<tr>
<td>$T_{TOTCECK}/T_{TOCKTCE}$</td>
<td>TCE input</td>
<td></td>
<td>Time before the clock that the clock enable signal must be stable at the TCE input of the IOB 3-state Register.</td>
</tr>
<tr>
<td>$T_{IOSRCKT}/T_{IOCKTSR}$</td>
<td>SR input (TFF)</td>
<td></td>
<td>Time before the clock that the set/reset signal.</td>
</tr>
</tbody>
</table>

Clock to Out

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>$T_{IOCKHZ}$</td>
<td>Clock (CLK) to pad High-Z</td>
<td></td>
<td>Time after clock that the pad goes to high-impedance.</td>
</tr>
<tr>
<td>$T_{IOCKON}$</td>
<td>Clock (CLK) to valid data on pad</td>
<td></td>
<td>Time after clock that the pad goes from high-impedance to valid data.</td>
</tr>
</tbody>
</table>

Set/Reset Delays

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Function</th>
<th>Control Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>$T_{IOSRHZ}$</td>
<td>SR Input to pad High-Z (asynchronous)</td>
<td></td>
<td>Time after the SR signal is toggled that the pad goes to high-impedance.</td>
</tr>
<tr>
<td>$T_{IOSRON}$</td>
<td>SR Input to valid data on pad (asynchronous)</td>
<td></td>
<td>Time after the SR signal is toggled that the pad goes from high-impedance to valid data.</td>
</tr>
</tbody>
</table>
Timing Characteristics

Figure 1-20 illustrates IOB 3-state register timing.

Clock Event 1
- At time $T_{IOTCECK}$ before Clock Event 1, the 3-state clock enable signal becomes valid-high at the TCE input of the 3-state register, enabling the 3-state register for incoming data.
- At time $T_{IOTCK}$ before Clock Event 1 the 3-state signal becomes valid-high at the T input of the 3-state register, returning the pad to high-impedance at time $T_{IOCKHZ}$ after Clock Event 1.

Clock Event 2
At time $T_{IOSRCKT}$ before Clock Event 2, the SR signal (configured as synchronous reset in this case) becomes valid-high, resetting the 3-state register and returning the pad to valid data at time $T_{IOSRON}$ after Clock Event 2.
Timing Characteristics, DDR

Figure 1-21 illustrates IOB DDR 3-state register timing.

Clock Event 1
At time $T_{IOTCECK}$ before Clock Event 1, the 3-state clock enable signal becomes valid-high at the TCE input of both of the DDR 3-state registers, enabling them for incoming data. Since the TCE signal is common to both DDR registers, care must be taken to toggle this signal between the rising edges of OTCLK1 and OTCLK2 as well as meeting the register setup-time relative to both clocks.

Clock Event 2
At time $T_{IOTCK}$ before Clock Event 2 (rising edge of OTCLK2), the 3-state signal $T_2$ becomes valid-high at the $T_2$ input of 3-state register 2, switching the pad to high-impedance at time $T_{IOCKHZ}$ after Clock Event 2.

Clock Event 3
At time $T_{IOTCK}$ before Clock Event 3 (rising edge of OTCLK1), the 3-state signal $T_1$ becomes valid-high at the $T_1$ input of 3-state register 1, keeping the pad at high-impedance for another half clock cycle (half the period of OTCLK1 or 2).

Clock Event 4
At time $T_{IOTCK}$ before Clock Event 4 (rising edge of OTCLK2), the 3-state signal $T_2$ becomes valid-low at the $T_2$ input of 3-state register 2, switching the pad to valid data at time $T_{IOCKON}$ after Clock Event 4. This is repeated for 3-state signal $T_1$ at the following clock event (5) maintaining valid data on the pad until Clock Event 8.

Clock Event 8
At time $T_{IOTCK}$ before Clock Event 8 (rising edge of OTCLK2), the 3-state signal $T_2$ becomes valid-high at the $T_2$ input of 3-state register 2, switching the pad to high-impedance at time $T_{IOCKHZ}$ after Clock Event 8.
Pin-to-Pin Timing Models

Clock Event 9
At time $T_{IOSRCKT}$ before Clock Event 9 (rising edge of OTCLK1), the SR signal (configured as synchronous reset in this case) becomes valid-high at the SR input of 3-state Register 1, returning the pad to valid data at time $T_{IOSRON}$ after Clock Event 9.

Pin-to-Pin Timing Models

This section explains the delays and timing parameters associated with the use of the Global Clock network and the DCM. These delays are true pin-to-pin delays relative to the Global Clock pin and an output or input pin with or without the DCM.

This section consists of two parts:

- **Global Clock Input to Output**
- **Global Clock Setup and Hold**

The former describes the delay from the Global Clock pin (with and without the DCM) to an output pin via an Output flip-flop. The latter describes the set-up time for an Input flip-flop from an input pin relative to the Global Clock pin (with and without the DCM).

The values reported in the switching characteristics section of the Virtex-II Pro Data Sheet are for LVCMOS_25 12 mA I/O standards. For different I/O standards, adjust these values with those shown in the “IOB Switching Characteristics Standard Adjustments” tables.

This section is intended to be used in conjunction with the section on switching characteristics in the Virtex-II Pro Data Sheet and the Timing Analyzer (TRCE) report from Xilinx software. For specific timing parameter values, refer to the Virtex-II Pro Data Sheet.

Global Clock Input to Output

Figure 1-22 illustrates the paths associated with the timing parameters defined in this section. Note that they differ only in their use of the DCM.
Timing Parameters

Table 1-9: Global Clock Input to Output Timing Parameters

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>( \text{TICKOFDLL} )</td>
<td>Time after the Global Clock (pin), using the DCM, that the output data from an IOB Output flip-flop is stable at the output pin.</td>
</tr>
<tr>
<td>( \text{TICKOF} )</td>
<td>Time after the Global Clock (pin), without the DCM, that the output data from an IOB Output flip-flop is stable at the output pin.</td>
</tr>
</tbody>
</table>

Timing Characteristics

The waveforms depicted in Figure 1-23 demonstrate the relation of the Global Clock pin, the output data, and the use of the timing parameters.

Figure 1-23: Global Clock Input to Output Timing Characteristics
Global Clock Setup and Hold

Figure 1-24 illustrates the paths associated with the timing parameters defined in this section. Note, they differ only in their use of the DCM.

![Global Clock Setup and Hold Model](image)

**Timing Parameters**

Setup and Hold for Input Registers Relative to the Global Clock (pin):

- $T_{PSDLL} / T_{PHDLL}$ - Time before the Global Clock (pin), with DCM, that the input signal must be stable at the D-input of the IOB input register.

- $T_{PSFD} / T_{PHFD}$ - Time before the Global Clock (pin), without DCM, that the input signal must be stable at the D-input of the IOB input register.

Note: $T_{PSFD} = \text{Setup time (before clock edge)}$ and $T_{PHFD} = \text{Hold time (after clock edge)}$. The previous descriptions are for setup times only.
Timing Characteristics

The waveforms depicted in Figure 1-25 demonstrate the relation of the Global Clock pin, the input data, and the use of the timing parameters.

![Waveforms](UG002_C3_016_101300)

*Figure 1-25:  Global Clock Setup and Hold Timing Characteristics*

**Digital Clock Manager Timing Model**

This section describes the timing parameters associated with the Digital Clock Manager (DCM), which are reported in the Virtex-II Pro Data Sheet. Note that these parameters are not used by the Timing Analyzer software in the production of timing reports; they are all measured values and are fully characterized in silicon. For specific timing parameter values, refer to the Virtex-II Pro Data Sheet. This section discusses the following:

- **Operating Frequency Ranges:** The minimum and maximum frequencies supported by the DCM for all clock inputs and outputs.
- **Input Clock Tolerances:** Input clock period (pulse widths), jitter, and drift requirements for proper function of the DCM for all clock inputs.
- **Output Clock Precision:** Output clock period jitter, phase offsets, and duty cycle for all clock outputs of the DCM (worst case).
- **Miscellaneous Timing Parameters:** DCM lock times, Tap delay and shifting range.

For a detailed description of input clock tolerance, jitter, and phase offset see the waveforms at the end of this section.
Operating Frequency Ranges

Figure 1-26 illustrates the DCM functional block and corresponding timing parameters for all clock inputs and outputs.

Table 1-10: Operating Frequency Range Parameters

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Low Frequency Mode</strong></td>
<td></td>
</tr>
<tr>
<td>CLKOUT_FREQ_1X_LF</td>
<td>The minimum and maximum frequency for the CLK0, CLK90, CLK180, CLK270 outputs of the DCM in low-frequency mode.</td>
</tr>
<tr>
<td>CLKOUT_FREQ_2X_LF</td>
<td>The minimum and maximum frequency for the CLK2X and CLK2X180 outputs of the DCM in low-frequency mode.</td>
</tr>
<tr>
<td>CLKOUT_FREQ_DV_LF</td>
<td>The minimum and maximum frequency for the CLKDV output of the DCM in low-frequency mode.</td>
</tr>
<tr>
<td>CLKOUT_FREQ_FX_LF</td>
<td>The minimum and maximum frequency for the CLKFX and CLKFX180 outputs of the DCM in low-frequency mode.</td>
</tr>
<tr>
<td>CLKin_FREQ_DLL_LF(1)</td>
<td>The minimum and maximum frequency for the CLKIN input to the DCM in low-frequency mode when using the delay-locked loop (DLL) outputs.</td>
</tr>
<tr>
<td>CLKin_FREQ_FX_LF(2)</td>
<td>The minimum and maximum frequency for the CLKIN input to the DCM in low-frequency mode when using the FX outputs.</td>
</tr>
<tr>
<td>PSCLK_FREQ_LF</td>
<td>The minimum and maximum frequency for the PSCLK input to the DCM in low-frequency mode.</td>
</tr>
</tbody>
</table>
### Input Clock Tolerances

#### Table 1-10: Operating Frequency Range Parameters (Continued)

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>High Frequency Mode</strong></td>
<td></td>
</tr>
<tr>
<td>CLKOUT_FREQ_1X_HF</td>
<td>The minimum and maximum frequency for the CLK0, CLK180 outputs of the DCM in high-frequency mode.</td>
</tr>
<tr>
<td>CLKOUT_FREQ_DV_HF</td>
<td>The minimum and maximum frequency for the CLKDV output of the DCM in high-frequency mode.</td>
</tr>
<tr>
<td>CLKOUT_FREQ_FX_HF</td>
<td>The minimum and maximum frequency for the CLKFX and CLKFX180 outputs of the DCM in high-frequency mode.</td>
</tr>
<tr>
<td>CLKIN_FREQ_DLL_HF</td>
<td>The minimum and maximum frequency for the CLKIN input to the DCM in high-frequency mode when using the DLL outputs.</td>
</tr>
<tr>
<td>CLKIN_FREQ_FX_HF</td>
<td>The minimum and maximum frequency for the CLKIN input to the DCM in high-frequency mode when using the FX outputs.</td>
</tr>
<tr>
<td>PSCLK_FREQ_HF</td>
<td>The minimum and maximum frequency for the PSCLK input to the DCM in high-frequency mode.</td>
</tr>
</tbody>
</table>

**Notes:**
1. Delay-locked loop (DLL) outputs include: CLK0, CLK90, CLK180, CLK270, CLK2X, CLK2X180, and CLKDV.
2. FX outputs include: CLKFX and CLKFX180

#### Table 1-11: Input Clock Tolerance Parameters

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>PSCLK_PULSE(1)</td>
<td>The minimum pulse width (HIGH and LOW) that the PSCLK input to the DCM can have over a range of frequencies.</td>
</tr>
<tr>
<td>CLKIN_PULSE</td>
<td>The minimum pulse width (HIGH and LOW) that the CLKIN input to the DCM can have over a range of frequencies. Also applies to PSCLK.</td>
</tr>
<tr>
<td>CLKFB_DELAY_VAR_EXT</td>
<td>The maximum allowed variation in delay (across environmental changes) of the feedback clock path when routed externally for board-level de-skew.</td>
</tr>
</tbody>
</table>

#### Low Frequency Mode

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLKIN_CYC_JITT_DLL_LF</td>
<td>The maximum cycle-to-cycle jitter the CLKIN input to the DCM can have when using the DLL outputs in low-frequency mode.</td>
</tr>
<tr>
<td>CLKIN_CYC_JITT_FX_LF</td>
<td>The maximum cycle-to-cycle jitter the CLKIN input to the DCM can have when using the FX outputs in low-frequency mode.</td>
</tr>
<tr>
<td>CLKIN_PER_JITT_DLL_LF</td>
<td>The maximum period jitter the CLKIN input to the DCM can have when using the DLL outputs in low-frequency mode.</td>
</tr>
</tbody>
</table>
### Digital Clock Manager Timing Model

**Table 1-11: Input Clock Tolerance Parameters (Continued)**

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLKIN_PER_JITT_FX_LF</td>
<td>The maximum period jitter the CLKIN input to the DCM can have when using the FX outputs in low-frequency mode.</td>
</tr>
</tbody>
</table>

**High Frequency Mode**

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLKIN_CYC_JITT_DLL_HF</td>
<td>The maximum cycle-to-cycle jitter the CLKIN input to the DCM can have when using the DLL outputs in high-frequency mode.</td>
</tr>
<tr>
<td>CLKIN_CYC_JITT_FX_HF</td>
<td>The maximum cycle-to-cycle jitter the CLKIN input to the DCM can have when using the FX outputs in high-frequency mode.</td>
</tr>
<tr>
<td>CLKIN_PER_JITT_DLL_HF</td>
<td>The maximum period jitter the CLKIN input to the DCM can have when using the DLL outputs in high-frequency mode.</td>
</tr>
<tr>
<td>CLKIN_PER_JITT_FX_HF</td>
<td>The maximum period jitter the CLKIN input to the DCM can have when using the FX outputs in high-frequency mode.</td>
</tr>
</tbody>
</table>

**Notes:**

1. The frequencies applicable to CLKIN_PULSE range from 1 to >400 MHz. These frequencies also apply to PSCLK_PULSE. Since PSCLK can be less than 1 MHz, the pulse width under this condition is specified for PSCLK only.

### Output Clock Precision

**Table 1-12: Output Clock Precision Parameters**

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLKOUT_PER_JITT_0</td>
<td>The maximum period jitter of the CLK0 output clock from the DCM (worst case).</td>
</tr>
<tr>
<td>CLKOUT_PER_JITT_90</td>
<td>The maximum period jitter of the CLK90 output clock from the DCM (worst case).</td>
</tr>
<tr>
<td>CLKOUT_PER_JITT_180</td>
<td>The maximum period jitter of the CLK180 output clock from the DCM (worst case).</td>
</tr>
<tr>
<td>CLKOUT_PER_JITT_270</td>
<td>The maximum period jitter of the CLK270 output clock from the DCM (worst case).</td>
</tr>
<tr>
<td>CLKOUT_PER_JITT_2X</td>
<td>The maximum period jitter of the CLK2X and CLK2X180 output clocks from the DCM (worst case).</td>
</tr>
<tr>
<td>CLKOUT_PER_JITT_DV1</td>
<td>The maximum period jitter of the CLKDV (integer division) output clock from the DCM (worst case).</td>
</tr>
<tr>
<td>CLKOUT_PER_JITT_DV2</td>
<td>The maximum period jitter of the CLKDV (non-integer division) output clock from the DCM (worst case).</td>
</tr>
<tr>
<td>CLKOUT_PER_JITT_FX</td>
<td>The maximum period jitter of the FX output clocks from the DCM (worst case).</td>
</tr>
<tr>
<td>CLKIN_CLKFB_PHASE</td>
<td>Maximum phase offset between the CLKIN and CLKFB inputs to the DCM.</td>
</tr>
</tbody>
</table>
Table 1-12: Output Clock Precision Parameters (Continued)

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLKOUT_PHASE</td>
<td>Maximum phase offset between any DCM clock outputs.</td>
</tr>
<tr>
<td>CLKOUT_DUTY_CYCLE_DLL</td>
<td>The duty-cycle precision for all DLL outputs.</td>
</tr>
<tr>
<td>CLKOUT_DUTY_CYCLE_FX</td>
<td>The duty-cycle precision for the FX outputs.</td>
</tr>
</tbody>
</table>

Miscellaneous DCM Timing Parameters

Table 1-13: Miscellaneous DCM Timing Parameters

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>LOCK_DLL</td>
<td>Time required for DCM to lock over a range of clock frequencies when using the DLL outputs.</td>
</tr>
<tr>
<td>LOCK_FX</td>
<td>Time required for DCM to lock when using the FX outputs.</td>
</tr>
<tr>
<td>LOCK_DLL_FINE_SHIFT</td>
<td>Additional lock time when performing fine phase shifting.</td>
</tr>
<tr>
<td>FINE_SHIFT_RANGE</td>
<td>Absolute range for fine phase shifting.</td>
</tr>
<tr>
<td>DCM_TAP</td>
<td>Resolution of delay line.</td>
</tr>
</tbody>
</table>

The waveforms in Figure 1-27 demonstrate the relationship between clock tolerance, jitter, and phase.

**Period Tolerance**: the allowed input clock period change in nanoseconds.

**Output Jitter**: the difference between an ideal reference clock edge and the actual design.

**Phase Offset and Maximum Phase Difference**:

Output jitter is period jitter measured on the DLL output clocks, excluding input clock jitter.

Phase offset between CLKin and CLKFB is the worst-case fixed time difference between rising edges of CLKin and CLKFB, excluding output jitter and input clock jitter.
Phase offset between clock outputs on the DLL is the worst-case fixed time difference between rising edges of any two DLL outputs, excluding output jitter and input clock jitter.

Maximum phase difference between CLkin and CLKFB is the sum of output jitter and phase offset between CLkin and CLKFB, or the greatest difference between CLkin and CLKFB rising edges due to DLL alone (excluding input clock jitter).

Maximum phase difference between clock outputs on the DLL is the sum of output jitter and phase offset between any DLL clock outputs, or the greatest difference between any two DLL output rising edges due to DLL alone (excluding input clock jitter).

**Additional Timing Models in Other Publications:**

**PPC405 Processor Block and RocketIO Transceiver**

Due to their length and complexity, timing models for the IBM PPC405 Processor Block and the RocketIO Multi-Gigabit Transceiver are not included in this Handbook. They can be found in the publications described below, which cover in detail the operation and implementation of these Virtex-II Pro components:

**IBM PPC405 Processor Block Timing Models**

Timing models for the IBM PPC405 Processor Block can be found in the *PPC405 Processor Block Manual*, UG018. The most current version of this volume is available on the Xilinx website at [www.xilinx.com/publications/products/v2pro/handbook/](http://www.xilinx.com/publications/products/v2pro/handbook/). It is intended to be used in conjunction with Module 3 of the *Virtex-II Pro Data Sheet* and the Timing Analyzer (TRCE) report from Xilinx software. For specific timing parameter values, refer to the data sheet.

**RocketIO Transceiver Timing Models**

Timing models for the RocketIO Transceiver can be found in the *RocketIO Transceiver User Guide*, UG024. The most current version of this volume is available on the Xilinx website at [www.xilinx.com/publications/products/v2pro/handbook/](http://www.xilinx.com/publications/products/v2pro/handbook/).
Chapter 2

Design Considerations

Summary

This chapter covers the following topics:

- RocketIO Transceiver
- Processor Block
- Global Clock Networks
- Digital Clock Managers (DCMs)
- Block SelectRAM™ Memory
- Distributed SelectRAM Memory
- Look-Up Tables as Shift Registers (SRLs)
- Large Multiplexers
- Sum of Products (SOP) Logic
- Embedded Multipliers
- Single-Ended SelectIO™-Ultra Resources
- Digitally Controlled Impedance (DCI)
- Double-Data-Rate (DDR) I/O
- LVDS I/O
- LVPECL I/O
- Bitstream Encryption
- CORE Generator System

Introduction

This chapter describes how to take advantage of the many special features of Virtex-II Pro architecture to achieve maximum density and performance. In many cases, the functions described can be automatically generated using the Xilinx CORE Generator™ tool. This is noted throughout the chapter, in the following sections specifically:

- Block SelectRAM™ Memory
- Distributed SelectRAM Memory
- Look-Up Tables as Shift Registers (SRLs)
- Large Multiplexers
- Embedded Multipliers
RocketIO Transceiver

Virtex-II Pro devices provide up to twenty-four multi-gigabit transceivers capable of various high-speed serial standards such as Gigabit Ethernet, FiberChannel, Infiniband, and XAUI. In addition, the channel-bonding feature aggregates multiple channels allowing for even higher data transfer rate.

For the most up-to-date information on RocketIO transceiver features, design examples, power considerations, and board layout suggestions, refer to the most current revision of RocketIO Transceiver User Guide on the Xilinx website at www.xilinx.com/publications/products/v2pro/handbook/.

Processor Block

Two additional user manuals detail the hardware and software design aspects of the processor block. The Virtex-II Pro Processor Block Manual provides information on input/output signals, timing relationships between signals, and the mechanisms software can use to control the interface operation. The Virtex-II Pro PPC405 User Manual serves as a stand-alone reference for application and system programmers of the PPC405 processor core.

For the most up-to-date information on the PPC405 processor core, refer to the current revisions of these manuals on the Xilinx website at www.xilinx.com/publications/products/v2pro/handbook/.

Global Clock Networks

Introduction

Virtex-II Pro devices support very high frequency designs and thus require low-skew advanced clock distribution. With device density up to 10 million system gates, numerous global clocks are necessary in most designs. Therefore, to provide a uniform and portable solution (soft-IP), all Virtex-II Pro devices from XC2VP2 to XC2VP125 have 16 global clock buffers and support 16 global clock domains. Up to eight of these clocks can be used in any quadrant of the device by the synchronous logic elements (that is, registers, 18Kb block RAM, pipeline multipliers) and the IOBs. The software tools place and route these global clocks automatically.

If the design uses between 8 and 16 clocks, it must be partitioned into quadrants, with up to 8 clocks per quadrant. If more than 16 clocks are required, the backbone (24 horizontal and vertical long lines routing resources) can be used as additional clock network.

In addition to clock distribution, the 16 clock buffers are also “glitch-free” synchronous 2:1 multiplexers. These multiplexers are capable of switching between two asynchronous (or synchronous) clocks at any time. No particular phase relations between the two clocks are needed. The clock multiplexers can also be configured as a global clock buffer with a clock enable. The clock can be stopped High or Low at the clock buffer output.

Clock Distribution Resources

The various resources available to manage and distribute the clocks include:

- Sixteen clock pads that can be used as regular user I/Os if not used as clock inputs. The sixteen clock pads can be configured for any I/O standard, including differential standards (for example, LVDS).
- Sixteen “IBUFG” elements that represent the clock inputs in a VHDL or Verilog design.
- Eight “IBUFGDS” elements (that is, attributes LVPECL_25, LVDS_25, LDT_25, or
ULVDS_25) that represent the differential clock input pairs in a VHDL or Verilog design. Each IBUFGDS replaces two IBUFG elements.

- Four to twelve Digital Clock Managers (DCMs), depending on the device size, to de-skew and generate the clocks. For more information on DCMs, see Digital Clock Managers (DCMs), page 180.
- Sixteen “BUFGMUX” elements that can consist of up to sixteen global clock buffers (BUFG), global clock buffers with a clock enable (BUFGCE), or global clock multiplexers (BUFGMUX).

Figure 2-1 illustrates the placement of these clock resources in Virtex-II Pro devices (the XC2VP30 through the XC2VP70) that have eight DCMs.

![Figure 2-1: Clock Resources in Virtex-II Pro Devices](image-url)

Figure 2-1: Clock Resources in Virtex-II Pro Devices

The simple scheme to distribute an external clock in the device is to implement a clock pad with an IBUF input buffer connected to a BUFG global buffer, as shown in Figure 2-2 and Figure 2-3, page 162. The primary (GCLKP) and secondary (GCLKS) clock pads have no relationship with the P-side and N-side of differential clock inputs. In banks 0 and 1, the GCLKP corresponds to the N-side, and the GCLKS corresponds to the P-side of a differential clock input. In banks 4 and 5, this correspondence is reversed.
Major synthesis tools automatically infer the IBUF and BUF when the corresponding input signal is used as a clock in the VHDL or Verilog code.

A high frequency or adapted (frequency, phase, and so forth) clock distribution with low skew is implemented by using a DCM between the output of the IBUF and the input of the BUF, as shown in Figure 2-4. Digital Clock Managers (DCMs), page 180 provides details about DCMs and their use.

Clock distribution from internal sources is also possible with a BUF only or with a DCM, as shown in Figure 2-5, page 163.
Global Clock Networks

Global Clock Inputs

The clock buffer inputs are fed either by one of the 16 clock pads (refer to the Virtex-II Pro Data Sheet), by the outputs of the DCM, or by local interconnect. Each clock buffer can be a synchronous “glitch-free” 2:1 multiplexer with two clock inputs and one select input. Internal logic (or alternatively a regular IOB) can feed the clock inputs. Any internal or external signal can drive the select input or clock enable input.

The possible inputs driving a global clock buffer or multiplexer are summarized in Table 2-1.

Table 2-1: Inputs Driving Global Clock Buffers or DCMs

<table>
<thead>
<tr>
<th>Source</th>
<th>BUFG(I) or BUFGCE(I)</th>
<th>BUFGCE (CE)</th>
<th>BUFGMUX (I0 or I1)</th>
<th>BUFGMUX (S)</th>
<th>DCM (CLkin)</th>
</tr>
</thead>
<tbody>
<tr>
<td>External Clock via IBUFG(O)</td>
<td>Dedicated in same quadrant(1)</td>
<td>NA</td>
<td>Dedicated in same quadrant(1)</td>
<td>NA</td>
<td>Same edge</td>
</tr>
<tr>
<td>DCM Clock Outputs</td>
<td>Same edge (top or bottom)(2)</td>
<td>NA</td>
<td>Same edge (top or bottom)(2)</td>
<td>NA</td>
<td>General interconnect(3)</td>
</tr>
<tr>
<td>Internal Logic</td>
<td>General interconnect</td>
<td>General interconnect</td>
<td>General interconnect</td>
<td>General interconnect</td>
<td>General interconnect(3)</td>
</tr>
<tr>
<td>User I/O Pad via IBUF(O) (not IBUFG)</td>
<td>General interconnect</td>
<td>General interconnect</td>
<td>General interconnect</td>
<td>General interconnect</td>
<td>General interconnect(3)</td>
</tr>
<tr>
<td>BUFG(O)</td>
<td>NA</td>
<td>NA</td>
<td>NA</td>
<td>NA</td>
<td>Global clock net</td>
</tr>
<tr>
<td>BUFGMUX(O)</td>
<td>NA</td>
<td>NA</td>
<td>General interconnect</td>
<td>NA</td>
<td>Global clock net</td>
</tr>
</tbody>
</table>

Notes:
1. Not all IBUFGs in the quadrant have a dedicated connection to a specific BUFG. Others would require general interconnect to be hooked up.
2. Same edge (top or bottom) enables use of dedicated routing resources.
3. Pad to DCM input skew is not compensated.

All BUFG (BUFGCE, BUFGMUX) outputs are available at the quadrant boundaries.
The output of the global clock buffer can be routed to non-clock pins.
Primary and Secondary Global Multiplexers

Each global clock buffer is a self-synchronizing circuit called a clock multiplexer. The 16 global clock buffers or multiplexers are divided as follows:

- Eight primary clock multiplexers
- Eight secondary clock multiplexers

No hardware difference exists between a primary and a secondary clock multiplexer. However, some restrictions apply to primary/secondary multiplexers, because they share input connections, as well as access to a quadrant.

Each Virtex-II Pro device is divided into four quadrants: North-West, South-West, North-East, and South-East. Each quadrant has two primary and two secondary clock multiplexers. The clock multiplexers are indexed 0 to 7, with one primary and one secondary for each index, alternating on the top and on the bottom (i.e., clock multiplexer “0P” at the bottom is facing clock multiplexer “0S” at the top).

In each device, the eight top/bottom clock multiplexers are divided into four primary and four secondary, indexed 0 to 7, as shown in Figure 2-6.

![Figure 2-6: Primary and Secondary Clock Multiplexer Locations](image-url)
Global Clock Networks

Primary/Secondary: Rule 1
Considering two “facing” clock multiplexers (BUFG#P and BUFG#S), one or the other of these clock outputs can enter any quadrant of the chip to drive a clock within that quadrant, as shown in Figure 2-7. Note that the clock multiplexers “xP” and “xS” compete for quadrant access. For example, BUFG0P output cannot be used in the same quadrant as BUFG0S.

Figure 2-7: Facing BUFG#P and BUFG#S Connections
Primary/Secondary: Rule 2

In a BUFGCE or BUFGMUX configuration, shared inputs have to be considered. Any two adjacent clock multiplexers share two inputs, as shown in Figure 2-8. The clock multiplexer “1P” and “0S” have common I0/I1 and I1/I0 inputs.

Table 2-2 lists the clock multiplexer pairs in any Virtex-II Pro device. The primary multiplexer inputs I1/I0 are common with the corresponding secondary multiplexer inputs I0/I1 (i.e., Primary I1 input is common with secondary I0 input, and primary I0 input is common with secondary I1 input).

Table 2-2: Top Clock Multiplexer Pairs

<table>
<thead>
<tr>
<th>Primary I1/I0</th>
<th>1P</th>
<th>3P</th>
<th>5P</th>
<th>7P</th>
</tr>
</thead>
<tbody>
<tr>
<td>Secondary I0/I1</td>
<td>0S</td>
<td>2S</td>
<td>4S</td>
<td>6S</td>
</tr>
</tbody>
</table>

Table 2-3: Bottom Clock Multiplexer Pairs

<table>
<thead>
<tr>
<th>Primary I1/I0</th>
<th>0P</th>
<th>2P</th>
<th>4P</th>
<th>6P</th>
</tr>
</thead>
<tbody>
<tr>
<td>Secondary I0/I1</td>
<td>1S</td>
<td>3S</td>
<td>5S</td>
<td>7S</td>
</tr>
</tbody>
</table>
Global Clock Networks

Primary/Secondary Usage

For up to eight global clocks, it is safe to use the eight primary global multiplexers (1P, 3P, 5P, 7P on the top and 0P, 2P, 4P, 6P on the bottom). Because of the shared inputs, a maximum of eight independent global clock multiplexers can be used in a design, as shown in Figure 2-9.

DCM Clocks

The four clock pins (IBUFG) in a quadrant can feed all DCMs in the same edge of the device. The clock-to-out and setup times are identical for all DCMs. Up to four clock outputs per DCM can be used to drive any clock multiplexer on the same edge (top or bottom), as shown in Figure 2-10.

BUFG Exclusivity

Each DCM has a restriction on the number of BUFGs it can drive on its (top or bottom) edge. Pairs of buffers with shared dedicated routing resources exist such that only one buffer from each dedicated pair can be driven by a single DCM. The exclusive pairs for each edge are: 1:5, 2:6, 3:7, and 4:8.
Clock Output

The clock distribution is based on eight clock trees per quadrant. Each clock multiplexer output is driving one global clock net. The Virtex-II Pro device has eight dedicated low-skew clock nets. The device is divided into four quadrants (NW, NE, SW and SE) with eight global clocks available per quadrant.

Eight clock buffers are in the middle of the top edge and eight are in the middle of the bottom edge. Any of these 16 clock buffer outputs can be used in any quadrant, up to a maximum of eight clocks per quadrant, as illustrated in Figure 2-11, provided there is not a primary vs. secondary conflict.

Figure 2-10: DCM Clocks

Figure 2-11: Clock Buffer Outputs per Quadrant
Designs with more than eight clocks must be floorplanned manually or automatically, distributing the clocks in each quadrant. As an example, a design with 16 clocks can be floorplanned as shown in Figure 2-12.

![16-Clock Floorplan](image)

The clock nets and clock buffers in this example are associated as shown in Table 2-4.

**Table 2-4: Clock Net Association With Clock Buffers**

<table>
<thead>
<tr>
<th>Clock Net (top edge)</th>
<th>CLK_A</th>
<th>CLK_B</th>
<th>CLK_C</th>
<th>CLK_D</th>
<th>CLK_E</th>
<th>CLK_F</th>
<th>CLK_G</th>
<th>CLK_H</th>
</tr>
</thead>
<tbody>
<tr>
<td>BUFG</td>
<td>7P</td>
<td>6S</td>
<td>5P</td>
<td>4S</td>
<td>3P</td>
<td>2S</td>
<td>1P</td>
<td>0S</td>
</tr>
<tr>
<td>Clock Net (bottom edge)</td>
<td>CLK_I</td>
<td>CLK_J</td>
<td>CLK_K</td>
<td>CLK_L</td>
<td>CLK_M</td>
<td>CLK_N</td>
<td>CLK_O</td>
<td>CLK_P</td>
</tr>
<tr>
<td>BUFG</td>
<td>7S</td>
<td>6P</td>
<td>5S</td>
<td>4P</td>
<td>3S</td>
<td>2P</td>
<td>1S</td>
<td>0P</td>
</tr>
<tr>
<td>Quadrant NW</td>
<td>CLK_A</td>
<td>CLK_B</td>
<td>CLK_C</td>
<td>–</td>
<td>–</td>
<td>CLK_F</td>
<td>–</td>
<td>CLK_P</td>
</tr>
<tr>
<td>Quadrant SW</td>
<td>CLK_A</td>
<td>–</td>
<td>CLK_C</td>
<td>CLK_L</td>
<td>CLK_M</td>
<td>CLK_N</td>
<td>CLK_G</td>
<td>CLK_H</td>
</tr>
<tr>
<td>Quadrant NE</td>
<td>CLK_I</td>
<td>CLK_B</td>
<td>CLK_K</td>
<td>CLK_D</td>
<td>CLK_E</td>
<td>CLK_N</td>
<td>CLK_O</td>
<td>CLK_H</td>
</tr>
<tr>
<td>Quadrant SE</td>
<td>CLK_A</td>
<td>CLK_J</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>CLK_P</td>
</tr>
</tbody>
</table>
CLK_A is used in three quadrants, and the other clocks are used in one or two quadrants, regardless of the position of the clock buffers (multiplexers), as long as they are not competing to access the same quadrant. (That is, CLK_A (BUFG7P) cannot be used in the same quadrant with CLK_I (BUFG7S). Refer to Primary/Secondary: Rule 1, page 165.) In other words, two buffers with the same index (0 to 7) cannot be used in the same quadrant. Each register, block RAM, registered multiplier, or DDR register (IOB) can be connected to any of the eight clock nets available in a particular quadrant.

Note that if a global clock (primary buffer) is used in four quadrants, the corresponding secondary buffer is not available.

Power Consumption

Clock trees have been designed for low skew and low-power operation. Any unused branch is disconnected, as shown in Figure 2-13.

![Figure 2-13: Low-Power Clock Network](image)

Also available to reduce overall power consumption are the BUFGCE feature, for dynamically driving a clock tree only when the corresponding module is used, and the BUFGMUX feature, for switching from a high-frequency clock to a low-frequency clock. The frequency synthesizer capability of the DCM can generate the low (or high) frequency clock from a single source clock, as illustrated in Figure 2-14. (See Digital Clock Managers (DCMs), page 180).

![Figure 2-14: Dynamic Power Reduction Scheme](image)
Global Clock Networks

Library Primitives and Submodules

The primitives in Table 2-5 are available with the input, output, and control pins listed.

Table 2-5:  Clock Primitives

<table>
<thead>
<tr>
<th>Primitive</th>
<th>Input</th>
<th>Output</th>
<th>Control</th>
</tr>
</thead>
<tbody>
<tr>
<td>IBUFG</td>
<td>I</td>
<td>O</td>
<td>–</td>
</tr>
<tr>
<td>IBUFGDS</td>
<td>I, IB</td>
<td>O</td>
<td>–</td>
</tr>
<tr>
<td>BUFG</td>
<td>I</td>
<td>O</td>
<td>–</td>
</tr>
<tr>
<td>BUFGMUX</td>
<td>I0, I1</td>
<td>O</td>
<td>S</td>
</tr>
<tr>
<td>BUFGMUX_1</td>
<td>I0, I1</td>
<td>O</td>
<td>S</td>
</tr>
</tbody>
</table>

Refer to Single-Ended SelectIO™-Ultra Resources, page 261 for a list of the attributes available for IBUFG and Refer to LVDS I/O, page 324 for a list of the attributes available for IBUFGDS.

The submodules in Table 2-6 are available with the input, output, and control pins listed.

Table 2-6:  Clock Submodules

<table>
<thead>
<tr>
<th>Submodule</th>
<th>Input</th>
<th>Output</th>
<th>Control</th>
</tr>
</thead>
<tbody>
<tr>
<td>BUFGCE</td>
<td>I</td>
<td>O</td>
<td>CE</td>
</tr>
<tr>
<td>BUFGCE_1</td>
<td>I</td>
<td>O</td>
<td>CE</td>
</tr>
</tbody>
</table>

Primitive Functions

IBUFG
IBUFG is an input clock buffer with one clock input and one clock output.

IBUFGDS
IBUFGDS is a differential input clock buffer with two clock inputs (positive and negative polarity) and one clock output.

BUFG
All Virtex-II Pro devices have 16 global clock buffers (each of which can be used as BUFG, BUFGMUX, or BUFGCE).

BUFG is a global clock buffer with one clock input and one clock output, driving a low-skew clock distribution network. The output follows the input, as shown in Figure 2-15.

BUFGMUX and BUFGMUX_1

BUFGMUX (see Figure 2-16) can switch between two unrelated, even asynchronous clocks. Basically, a Low on S selects the I0 input, a High on S selects the I1 input. Switching from one clock to the other is done in such a way that the output High and Low time is never shorter than the shortest High or Low time of either input clock. As long as the presently selected clock is High, any level change of S has no effect. (For BUFGMUX_1, as long as the presently selected clock is Low, any level change of S has no effect.)
BUFGMUX is the preferred circuit for rising edge clocks, while BUFGMUX_1 is preferred for falling edge clocks.

![BUFGMUX Circuit Diagram](DS083-2_63_121701)

**Figure 2-16: Virtex-II Pro BUFGMUX or BUFGMUX_1 Function**

**Operation of the BUFGMUX Circuit**

If the presently selected clock is Low while S changes, or if it goes Low after S has changed, the output is kept Low until the other ("to-be-selected") clock has made a transition from High to Low. At that instant, the new clock starts driving the output.

The two clock inputs can be asynchronous with regard to each other, and the S input can change at any time, except for a short setup time prior to the rising edge of the presently selected clock; that is, prior to the rising edge of the BUFGMUX output O. Violating this setup time requirement can result in an undefined runt pulse output.

Figure 2-17 shows a switch-over from CLK0 to CLK1.

![BUFGMUX Waveform Diagram](DS083-2_66_121701)

**Figure 2-17: BUFGMUX Waveform Diagram**

- The current clock is CLK0.
- S is activated High.
- If CLK0 is currently High, the multiplexer waits for CLK0 to go Low.
- Once CLK0 is Low, the multiplexer output stays Low until CLK1 transitions High to Low.
- When CLK1 transitions from High to Low, the output switches to CLK1.
- No glitches or short pulses can appear on the output.

**Operation of the BUFGMUX_1 Circuit**

If the presently selected clock is High while S changes, or if it goes High after S has changed, the output is kept High until the other ("to-be-selected") clock has made a transition from Low to High. At that instant, the new clock starts driving the output.

The two clock inputs can be asynchronous with regard to each other, and the S input can change at any time, except for a short setup time prior to the falling edge of the presently selected clock; that is, prior to the falling edge of the BUFGMUX output O. Violating this setup time requirement can result in an undefined runt pulse output.
Figure 2-18 shows a switch-over from CLK0 to CLK1.

![BUFGMUX_1 Waveform Diagram](DS083-2_46a_121701)

- The current clock is CLK0.
- S is activated High.
- If CLK0 is currently Low, the multiplexer waits for CLK0 to go High.
- Once CLK0 is High, the multiplexer output stays High until CLK1 transitions Low to High.
- When CLK1 transitions from Low to High, the output switches to CLK1.
- No glitches or short pulses can appear on the output.

### Submodules

**BUFGCE and BUFGCE_1**

BUFGCE and BUFGCE_1 are submodules based on BUFGMUX and BUFGMUX_1, respectively. BUFGCE and BUFGCE_1 are global clock buffers incorporating a smart enable function that avoids output glitches or runt pulses. The select signal must meet the setup time for the clock.

BUFGCE is the preferred circuit for clocking on the rising edge, while BUFGCE_1 is preferred when clocking on the falling edge.

### Operation of the BUFGCE Circuit

If the CE input (see Figure 2-19) is active (High) prior to the incoming rising clock edge, this Low-to-High-to-Low clock pulse passes through the clock buffer. Any level change of CE during the incoming clock High time has no effect.

![Virtex-II Pro BUFGCE or BUFGCE_1 Function](DS031_62_101200)

If the CE input is inactive (Low) prior to the incoming rising clock edge, the following clock pulse does not pass through the clock buffer, and the output stays Low. Any level change of CE during the incoming clock High time has no effect. CE must not change during a short setup window just prior to the rising clock edge on the BUFGCE_1 input I. Violating this setup time requirement can result in an undefined runt pulse output.
This means the output stays Low when the clock is disabled, but it completes the clock-
High pulse when the clock is being disabled, as shown in Figure 2-20.

![BUFGCE Waveforms](image1)

**Figure 2-20: BUFGCE Waveforms**

Operation of the BUFGCE_1 circuit

If the CE input is active (High) prior to the incoming falling clock edge, this High-to-Low-
to-High clock pulse passes through the clock buffer. Any level change of CE during the 
incoming clock Low time has no effect.

If the CE input is inactive (Low) prior to the incoming falling clock edge, the following 
clock pulse does not pass through the clock buffer, and the output stays High. Any level 
change of CE during the incoming clock Low time has no effect. CE must not change 
during a short setup window just prior to the falling clock edge on the BUFGCE input I. 
Violating this setup time requirement can result in an undefined runt pulse output.

This means the output stays High when the clock is disabled, but it completes the clock-
Low pulse when the clock is being disabled, as shown in Figure 2-21.

![BUFGCE_1 Waveforms](image2)

**Figure 2-21: BUFGCE_1 Waveforms**

When BUFGCE (or BUFGCE_1) is used with DCM outputs, a second BUFG can be used for 
clock feedback. Buffer sharing the inputs with BUFGCE is the preferred solution.

Summary

Table 2-7 shows the maximum resources available per Virtex-II Pro device.

<table>
<thead>
<tr>
<th>Table 2-7: Resources per Virtex-II Pro Device (from XC2VP2 to XC2VP125)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Resource</td>
</tr>
<tr>
<td>----------</td>
</tr>
<tr>
<td>Single-ended IBUFG (pads)</td>
</tr>
<tr>
<td>Differential IBUFDS (pairs)</td>
</tr>
<tr>
<td>BUFG (Global Clock Buffer)</td>
</tr>
<tr>
<td>BUFGCE (or BUFGCE_1)</td>
</tr>
<tr>
<td>BUFGMUX (or BUFGMUX_1)</td>
</tr>
</tbody>
</table>

Characteristics

The following are characteristics of global clocks in Virtex-II Pro devices:

- Low-skew clock distribution.
- Synchronous “glitch-free” multiplexer that avoids runt pulses. Switching between 
two asynchronous clock sources is usually considered unsafe, but it is safe with the 
Virtex-II Pro global clock multiplexer.
Global Clock Networks

- Any level change on S must meet a setup time requirement with respect to the signal on the output O (rising edge for BUFGMUX, falling edge for BUFGMUX_1). Any level change on CE must meet a setup time requirement with respect to the signal on the Input I (rising edge for BUFGCE, falling edge for BUFGCE_1).

- Two BUFGMUX (or BUFGMUX_1) resources can be cascaded to create a 3 to 1 clock multiplexer.

Location Constraints

BUFGMUX and BUFGMUX_1 (primitives) and IBUFG (IBUFGDS) instances can have LOC properties attached to them to constrain placement. The LOC properties use the following form to constrain a clock net:

```
NET "clock_name" LOC="BUFGMUX#P/S";
```

Each clock pad (or IBUFG) has a direct connection with a specific global clock multiplexer (input I0). A placement that does not conform to this rule causes the software to send a warning.

If the clock pad (or IBUFG) has LOC properties attached, the DCM allows place and route software maximum flexibility, as compared to a direct connection to the global clock buffer (BUFG).

Secondary Clock Network

If more clocks are required, the 24 horizontal and vertical long lines in Virtex-II Pro devices can be used to route additional clock nets. Skew is minimized by the place and route software, if the USELOWSKEWLINES constraint is attached to the net.

VHDL and Verilog Instantiation

VHDL and Verilog instantiation templates are available as examples (see “The following are templates for primitives:” on page 175) for all primitives and submodules.

In VHDL, each template has a component declaration section and an architecture section. Each part of the template should be inserted within the VHDL design file. The port map of the architecture section should include the design signal names.

The following are templates for primitives:

- BUFGMUX_INST
- BUFGMUX_1_INST

The following are templates for submodules:

- BUFGCE_SUBM
- BUFGCE_1_SUBM

As examples, the BUFGMUX_INST.vhd, BUFGMUX_1_INST.vhd, BUFGCE_SUBM.vhd, and BUFGCE_1_SUBM.vhd VHDL templates are shown. In addition, the BUFGMUX_INST.v, BUFGMUX_1_INST.v, BUFGCE_1_SUBM.v, and BUFGCE_SUBM.v Verilog templates are shown.

VHDL Template

```vhdl
-- Module: BUFGMUX_INST
-- Description: VHDL instantiation template
-- Global Clock Multiplexer (Switch Low)
-- Device: Virtex-II Pro Family
---------------------------------------------------------------------
-- Component Declarations:
--
component BUFGMUX
port (
I0 : in std_logic;
I1 : in std_logic;
S : in std_logic;
O : out std_logic
);
end component;
--
-- Architecture section:
--
-- Global Clock Buffer Instantiation
U_BUFGMUX : BUFGMUX
  port map (
    I0 => , -- insert clock input used when select (S) is Low
    I1 => , -- insert clock input used when select (S) is High
    S => , -- insert Mux-Select input
    O => -- insert clock output
  );
--
---------------------------------------------------------------------
-- Module: BUFGMUX_1_INST
-- Description: VHDL instantiation template
-- Global Clock Multiplexer (Switch High)
--
-- Device: Virtex-II Pro Family
--
-- Component Declarations:
component BUFGMUX_1
  port (>
    I0 : in std_logic;
    I1 : in std_logic;
    S : in std_logic;
    O : out std_logic
  );
end component;
--
-- Architecture section:
--
-- Global Clock Buffer Instantiation
U_BUFGMUX_1 : BUFGMUX_1
  port map (>
    I0 => , -- insert clock input used when select (S) is Low
    I1 => , -- insert clock input used when select (S) is High
    S => , -- insert Mux-Select input
    O => -- insert clock output
  );
--
---------------------------------------------------------------------
-- Module: BUFGCE_SUBM
-- Description: VHDL instantiation template
-- Global Clock Buffer with Clock Enable:
-- Input Clock Buffer to BUFGMUX - Clock disabled = Low
-- Device: Virtex-II Pro Family
--
library IEEE;
use IEEE.std_logic_1164.all;
--
-- pragma translate_off
library UNISIM;
use UNISIM.VCOMPONENTS.ALL;
-- pragma translate_on
--
entity BUFGCE_SUBM is
Global Clock Networks

port (  
  I: in std_logic;  
  CE: in std_logic;  
  O: out std_logic  
);  
end BUFGCE_SUBM;  
--  
architecture BUFGCE_SUBM_arch of BUFGCE_SUBM is  
--  
-- Component Declarations:  
component BUFGMUX  
  port (  
    I0 : in std_logic;  
    I1 : in std_logic;  
    S : in std_logic;  
    O : out std_logic  
  );  
end component;  
--  
-- signal declarations  
signal GND : std_logic;  
signal CE_B : std_logic;  
--  
begin  
  GND <= '0';  
  --  
  CE_B <= not CE;  
  --  
  -- Global Clock Buffer Instantiation  
  U_BUFGMUX: BUFGMUX  
  port map (  
    I0 => I,  
    I1 => GND,  
    S => CE_B,  
    O => O  
  );  
--  
end BUFGCE_SUBM_arch;

---------------------------------------------------------------------
-- Module: BUFGCE_1_SUBM
-- Description: VHDL instantiation template
-- Global Clock Buffer with Clock Enable:
-- Input Clock Buffer to BUFGMUX_1 - Clock disabled = High
-- Device: Virtex-II Pro Family
---------------------------------------------------------------------
library IEEE;
use IEEE.std_logic_1164.all;
--  
-- pragma translate_off
library UNISIM;
use UNISIM.VCOMPONENTS.ALL;
-- pragma translate_on
--  
entity BUFGCE_1_SUBM is  
  port (  
    I: in std_logic;  
    CE: in std_logic;  
    O: out std_logic  
  );  
end BUFGCE_1_SUBM;
--  
architecture BUFGCE_1_SUBM_arch of BUFGCE_1_SUBM is
-- Component Declarations:
component BUFGMUX_1
   port ( 
      I0 : in std_logic; 
      I1 : in std_logic; 
      S : in std_logic; 
      O : out std_logic 
   );
end component;
--
-- signal declarations
signal VCC : std_logic;
--
signal CE_B : std_logic;
--
begin
  VCC <= '1';
  --
  CE_B <= not CE;
--
-- Global Clock Buffer Instantiation
U_BUFGMUX_1: BUFGMUX_1
   port map ( 
      I0 => I, 
      I1 => VCC, 
      S => CE_B, 
      O => O 
   );
end BUFGCE_1_SUBM_arch;

Verilog Template

//-------------------------------------------------------------------
// Module:      BUFGMUX_INST
// Description: Verilog Instantiation Template
// Global Clock Multiplexer (Switch Low)
//
// Device: Virtex-II Pro Family
//-------------------------------------------------------------------

BUFGMUX  U_BUFGMUX
   (.I0(), // insert clock input used when select(S) is Low
   .I1(), // insert clock input used when select(S) is High
   .S(),  // insert Mux-Select input
   .O()   // insert clock output
);

//-------------------------------------------------------------------
// Module:      BUFGMUX_1_INST
// Description: Verilog Instantiation Template
// Global Clock Multiplexer (Switch High)
//
// Device: Virtex-II Pro Family
//-------------------------------------------------------------------

BUFGMUX_1  U_BUFGMUX_1
   (.I0(), // insert clock input used when select(S) is Low
// Module: BUFGCE_SUBM
// Description: Verilog Submodule
// Global Clock Buffer with Clock Enable:
// Input Clock Buffer to BUFGMUX - Clock disabled = Low
// Device: Virtex-II Pro Family
//---------------------------------------------------------------
module BUFGCE_SUBM (I, CE, O);
input I, CE;
output O;
wire GND;
assign GND = 1'b0;
BUFGMUX U_BUFGMUX (.I0(I),
                    .I1(GND),
                    .S(~CE),
                    .O(O)
   );
// endmodule
// Module: BUFGCE_1_SUBM
// Description: Verilog Submodule
// Global Clock Buffer with Clock Enable:
// Input Clock Buffer to BUFGMUX_1 - Clock disabled = High
// Device: Virtex-II Pro Family
//---------------------------------------------------------------
module BUFGCE_1_SUBM (I, CE, O);
input I, CE;
output O;
wire VCC;
assign VCC = 1'b1;
BUFGMUX_1 U_BUFGMUX_1 (.I0(I),
                         .I1(VCC),
                         .S(~CE),
                         .O(O)
   );
// endmodule
Digital Clock Managers (DCMs)

Overview

Virtex-II Pro devices have four to twelve DCMs, and each DCM provides a wide range of powerful clock management features:

- **Clock De-skew**: The DCM contains a digitally-controlled feedback circuit (delay-locked loop) that can completely eliminate clock distribution delays. Clock de-skew works as follows:
  The incoming clock drives a long chain of delay elements (individual small buffers). A wide multiplexer selects any one of these buffers as an output. A controller drives the select inputs of this multiplexer. The phase detector in this controller compares the incoming clock signal (CLKIN) against a feedback input (CLKFB), which must be another version of the same clock signal, usually from the far end of the internal clock distribution network (but it can also be from an output pin).
  The phase detector steers the controller to adjust the tap selection, and thus the through-delay in the DCM, in such a way that the two inputs to the phase comparator coincide. (This is a typical servo loop.) The tap controller adds exactly the right amount of delay to the clock distribution network to give it a total delay of one full clock period. For a repetitive clock signal, this effectively eliminates the clock distribution delay completely.

- **Frequency Synthesis**: Separate outputs provide a doubled frequency (CLK2X and CLK2X180). Another output (CLKDV) provides a frequency that is a specified fraction of the input frequency (÷1.5, ÷2, ÷2.5, and so forth, up to ÷15 and ÷16.)
  Two other outputs (CLKFX and CLKFX180) provide an output frequency that is derived from the input clock by simultaneous frequency division and multiplication. The user can specify any integer multiplier (M) and divisor (D) within the range specified in the DCM Timing Parameters section of the Virtex-II Pro Data Sheet. An internal calculator figures out the appropriate tap selection, so that the output edge coincides with the input clock whenever that is mathematically possible. For example, M=9 and D=5, multiply the frequency by 1.8, and the output rising edge is coincident with the input rising edge every 5 input periods = every 9 output periods.

- **Phase Shifting**: Three outputs drive the same frequency as CLK0 but are delayed by 1/4, 1/2, and 3/4 of a clock period. An additional control optionally shifts all nine clock outputs by a fixed fraction of the clock period (defined during configuration, and described in multiples of the clock period divided by 256).
  The user can also dynamically and repetitively move the phase forwards or backwards by one unit of the clock period divided by 256. Note that any such phase shift is always invoked as a specific fraction of the clock period, but is always implemented by moving delay taps with a resolution of DCM_TAP (see DCM Timing Parameters in the Virtex-II Pro Data Sheet).

- **General Control Signals**: The RST input, when High, resets the entire DCM. The LOCKED output is High when all enabled DCM circuits have locked. The active High STATUS outputs indicate the following:
  - Phase Shift Overflow (STATUS[0])
  - CLKIN Stopped (STATUS[1])
  - CLKFX Stopped (STATUS[2])

When using DCMs it is important to observe the $V_{CCAUX}$ recommended operating noise specification in the Virtex-II Pro Data Sheet. Power distribution design details are available in Xilinx Application Note XAPP623.
Clock De-Skew

The Virtex-II Pro Digital Clock Manager (DCM) offers a fully digital, dedicated on-chip de-skew circuit providing zero propagation delay, low clock skew between output clock signals distributed throughout the device, and advanced clock domain control. These features can be used to implement several circuits that improve and simplify system level design.

Any four of the nine outputs of the DCM can be used to drive a global clock network. All DCM outputs can drive general interconnect at the same time; for example, DCM output can be used to generate board-level clocks. The well-buffered global clock distribution network minimizes clock skew caused by loading differences. By monitoring a sample of the output clock (CLK0 or CLK2X), the de-skew circuit compensates for the delay on the routing network, effectively eliminating the delay from the external input port to the individual clock loads within the device.

Figure 2-22 shows all of the inputs and outputs relevant to the DCM de-skew feature.

![Figure 2-22: Clock De-Skew Outputs](image)

The de-skew feature can also act as a clock mirror. By driving the CLK0 or CLK2X output off-chip and then back in again, the de-skew feature can be used to de-skew a board-level clock serving multiple devices.

By taking advantage of the de-skew circuit to remove on-chip clock delay, the designer can greatly simplify and improve system level design involving high-fanout, high-performance clocks.

**Operation**

A de-skew circuit in its simplest form consists of variable delay line and control logic. The delay line produces a delayed version of the input clock (CLKIN). The clock distribution network routes the clock to all internal registers and to the clock feedback CLKFB pin. The control logic samples the input clock, as well as the feedback clock, and adjusts the delay line.

For optimum performance, the Virtex-II Pro DCM uses a discrete digital delay line, which is a series of buffer elements each with an intrinsic delay of less than DCM_TAP (see AC characteristics in the [Virtex-II Pro Data Sheet](http://www.xilinx.com)).

A de-skew circuit works by inserting delay between the input clock and the feedback clock until the two rising edges align, putting the two clocks 360 degrees out of phase, which means they are in phase. When the edges from the input clock line up with the edges from the feedback clock, the DCM achieves “lock.” The two clocks have no discernible
difference. Thus, the DCM output clock compensates for the delay in the clock distribution network, effectively removing the delay between the source clock and its loads.

Input Clock Requirements

The clock input of the DCM can be driven either by an IBUFG, an IBUF, or a BUFGMUX. An LVDS clock can also be used as input.

The output clock signal of a DCM, essentially a delayed version of the input clock signal, reflects any instability on the input clock in the output waveform. A DCM cannot improve the input jitter. The DCM input clock requirements are specified in the Virtex-II Pro Data Sheet.

Once locked, the DCM can tolerate input clock period variations of up to the value specified by CLKIN_PER_JITT_DLL_HF (at high frequencies) or CLKIN_PER_JITT_DLL_LF (at low frequencies). Larger frequency changes can cause the DCM to lose lock, which is indicated by the LOCKED output going low. The user must then reset the DCM. The cycle-to-cycle input jitter must be kept to less than CLKIN_CYC_JITT_DLL_LF in the low frequencies and CLKIN_CYC_JITT_DLL_HF for the high frequencies.

Input Clock Changes

Changing the period of the input clock beyond the maximum drift amount requires a manual reset of the DCM. Failure to reset the DCM produces an unreliable lock signal and output clock.

It is possible to stop the input clock with little impact to the de-skew circuit. The clock should be stopped for no more than 100 ms to minimize the effect of device cooling, which would change the tap delays. The clock should be stopped during a Low phase, and when restored, must generate a full High half-period. During this time, LOCKED stays High and remains High when the clock is restored. So a High on LOCKED does not necessarily mean that a valid clock is available.

When the clock is being stopped, one to four more clock cycles are still generated as the delay line is flushed. When the clock is restarted, the output clock cycles are not generated for one to four clocks as the delay line is filled. The most common case is two or three clocks. In a similar manner, a phase shift of the input clock is also possible. The phase shift propagates to the output one to four clocks after the original shift, with no disruption to the DCM control.

Output Clocks

Some restrictions apply regarding the connectivity of the output pins. The DCM clock outputs can each drive an OBUF, a global clock buffer BUFGMUX, or they can route directly to the clock input of a synchronous element. The DCM clock outputs can drive BUFGMUXs that are on the same edge of the device (top or bottom).

Do not use the DCM output clock signals until after activation of the LOCKED signal. Prior to the activation of the LOCKED signal, the DCM output clocks are not valid and can exhibit glitches, spikes, or other spurious movement.

Characteristics of the De-skew Circuit

- Can eliminate clock distribution delay by effectively adding one clock period delay. Clocks are de-skewed to within CLKOUT_PHASE, specified in the Virtex-II Pro Data Sheet.
- Can be used to eliminate on-chip as well as off-chip clock delay.
- Has no restrictions on the delay in the feedback clock path.
- Requires a continuously running input clock.
- Adapts to a wide range of frequencies. However, once locked to a frequency, cannot tolerate large variations of the input frequency.
- De-skew circuit is part of the DCM, which also includes phase adjustment, frequency synthesis, and spread spectrum techniques that are described in this document.
Digital Clock Managers (DCMs)

- Does not eliminate jitter. The de-skew circuit output jitter is the sum of input jitter and some jitter value that the de-skew circuit might add.
- The completion of configuration can be delayed until after DCM locks to guarantee the system clock is established prior to initiating the device.

Port Signals

Source Clock Input — CLKin

The CLKin pin provides the user source clock (the clock signal on which the de-skew circuit operates) to the DCM. The CLKin frequency must fall in the ranges specified in the Virtex-II Pro Data Sheet. The clock input signal can be provided by one of the following:

- IBUF — Input buffer
- IBUFG — Global clock input buffer on the same edge of the device (top or bottom)
- BUFGMUX — Internal global clock buffer

Feedback Clock Input — CLKFB

A reference or feedback signal is required to delay-compensate the output. Connect only the CLK0 or CLK2X DCM outputs to the feedback clock input (CLKFB) pin to provide the necessary feedback to the DCM. The feedback clock input signal can be driven by an internal global clock buffer (BUFGMUX), one of the global clock input buffers (IBUFG) on the same edge of the device (top or bottom), or IBUF (the input buffer.)

If an IBUFG sources the CLKFB pin, the following special rules apply:
1. An external input port must source the signal that drives the IBUFG input pin.
2. That signal must directly drive only OBUFs and nothing else.

Reset Input — RST

When the reset pin is activated, the LOCKED signal deactivates within four source clock cycles. The RST pin, active High, must either connect to a dynamic signal or be tied to ground. For all designs that use the feedback feature of the DCM, applying a reset signal after configuration is strongly recommended for both production and ES device in order to ensure consistent locking. As the DCM delay taps reset to zero, glitches can occur on the DCM clock output pins. Activation of the RST pin can also severely affect the duty cycle of the clock output pins. Furthermore, the DCM output clocks no longer de-skew with respect to one another. For these reasons, use the reset pin only when reconfiguring the device or changing the input frequency. The reset input signal is asynchronous and should be held HIGH for at least 2 ns. It takes approximately 120 µs for the DCM to achieve lock after a reset in the slowest frequency range. The DCM locks faster at higher frequencies. See the LOCK_DLL timing parameter in the Virtex-II Pro Data Sheet.

Locked Output — LOCKED

In order to achieve lock, the DCM may need to sample several thousand clock cycles. After the DCM achieves lock, the LOCKED signal goes High. The DCM timing parameter section of the Virtex-II Pro Data Sheet provides estimates for locking times.

To guarantee that the system clock is established prior to the device “waking up,” the DCM can delay the completion of the device configuration process until after the DCM locks. The STARTUP_WAIT attribute activates this feature.

Until the LOCKED signal activates, the DCM output clocks are not valid and can exhibit glitches, spikes, or other spurious movement. In particular, the CLK2X output appears as a 1x clock with a 25/75 duty cycle.

Status - STATUS

The STATUS output is an 8-bit output, of which STATUS[1] reveals the loss of the input clock, CLKin to the DCM.
Attributes

The following attributes provide access to some of the Virtex-II Pro Series de-skew features, (for example, clock division and duty cycle correction).

Frequency Mode

The de-skew feature of the DCM is achieved with a delay-locked loop (DLL). This attribute specifies either the high or low-frequency mode of the DLL. The default is low-frequency mode. In high-frequency mode, the only outputs available from the DLL are the CLK0, CLK180, CLKDV, and LOCKED. (CLK90, CLK270, CLK2X, and CLK2X180 are not available in high-frequency mode.) The frequency ranges for both frequency modes are specified in the Virtex-II Pro Data Sheet. To set the DLL to high-frequency mode, attach the DLL_FREQUENCY_MODE=HIGH attribute in the source code or schematic.

Feedback Input

This attribute specifies the feedback input to the DCM (CLK0, or CLK2x). CLK0 is the default feedback. When both the CLK0 and the CLK2x outputs are used internally or externally to the device, the feedback input can be either the CLK0 or CLK2x. In order to set the feedback to CLK2X, attach the CLK_FEEDBACK=2X attribute in the source code or schematic.

Duty Cycle Correction

The 1x clock outputs, CLK0, CLK90, CLK180, and CLK270, use the duty cycle corrected default such that they exhibit a 50/50 duty cycle. The DUTY_CYCLE_CORRECTION attribute (by default TRUE) controls this feature.

To deactivate the DCM duty cycle correction for the 1x clock outputs, attach the DUTY_CYCLE_CORRECTION=FALSE attribute in the source code or schematic. This makes the output clocks have the same duty cycle as the source clock.

Startup Delay

The default value of the STARTUP_WAIT attribute is FALSE. When STARTUP_WAIT is set to TRUE, and the LCK_cycle BitGen option is used, then the configuration startup sequence waits in the specified cycle until the DCM locks. For details, see Chapter 3: Configuration and Appendix A: BitGen and PROMGen Switches and Options.

Legacy Support

The Virtex/Virtex-E library primitives/sub modules are supported in Virtex-II Pro for legacy purposes. The following are supported primitives/submodules:

- CLKDLL
- CLKDLLE
- CLKDLLHF
- BUFGDLL

Library Primitive

Only a single library primitive is available for the DLL, a part of the DCM. It is labeled the 'DCM' primitive.
Submodules

Figure 2-23: **BUFG_CLK0_SUBM**

Figure 2-24: **BUFG_CLK2X_SUBM**

Figure 2-25: **BUFG_CLK0_FB_SUBM**
Frequency Synthesis

The DCM provides several flexible methods for generating new clock frequencies. Each method has a different operating frequency range and different AC characteristics. The CLK2X and CLK2X180 outputs double the clock frequency. The CLKDV output provides divided output clocks with division options of 1.5, 2, 2.5, 3, 3.5, 4, 4.5, 5, 5.5, 6, 6.5, 7, 7.5, 8, 9, 10, 11, 12, 13, 14, 15, and 16.

The DCM also offers a fully digital, dedicated Frequency Synthesizer output (CLKFX) and its opposite phase (CLKFX180). The output frequency can be any function of the input clock frequency described by $M \div D$, where $M$ is the multiplier (numerator) and $D$ is the divisor (denominator).

The two counter-phase frequency synthesized outputs can drive global clock routing networks within the device. The well-buffered global clock distribution network minimizes clock skew due to differences in distance or loading. See Figure 2-28.

Operation

The DCM clock output CLKFX is any $M/D$ product of the clock input to the DCM. Specifications for $M$ and $D$, as well as input and output frequency ranges for the frequency synthesizer, are provided in the Virtex-II Pro Data Sheet. The frequency synthesizer
output is phase aligned to the clock output, CLK0, only if feedback is provided to the
CLKFB input of the DCM.

The internal operation of the frequency synthesizer is complex and beyond the scope of
this document. The frequency synthesizer multiplies the incoming frequencies by the pre-
calculated quotient M/D and generates the correct output frequencies as long as it is
within the range specified in the *Virtex-II Pro Data Sheet*.

For example, assume input frequency = 50 MHz, M = 25, and D = 8 (note that M and D
values have no common factors and hence cannot be reduced). The output frequency is
correctly 156.25 MHz, although 25 x 50 MHz = 1.25 GHz and 50 MHz / 8 = 6.25 MHz, and
both of these values are far outside the range of the input frequency.

**Frequency Synthesizer Characteristics**

- The frequency synthesizer provides an output frequency equal to the input frequency
multiplied by M and divided by D.
- The outputs CLKFX and CLKFX180 always have a 50/50 duty-cycle.
- Smaller M and D values achieve faster lock times. The user should divide M and D by
the largest common factor.
- The outputs are phase aligned with CLK0 when CLKFB is connected.

**Port Signals**

**Source Clock Input — CLKin**

The CLKin pin provides the user source clock to the DCM. The CLKin frequency must fall
in the ranges specified in the *Virtex-II Pro Data Sheet*. The clock input signal can be
provided by one of the following:

- IBUF — Input buffer
- IBUFG — Global clock input buffer
- BUFGMUX — Internal global clock buffer

**2x Clock Output — CLK2X**

The CLK2X output provides a frequency-doubled clock with an automatic 50/50 duty-
cycle correction. This output is not available in high-frequency mode.
Until the DCM has achieved lock, the CLK2X output appears as a 1x version of the input clock with a 25/75 duty cycle. This behavior allows the DCM to lock on the correct edge with respect to source clock.

**Clock Divide Output — CLKDV**

The clock divide output pin CLKDV provides a lower frequency version of the source clock. The CLKDV_DIVIDE property controls CLKDV such that the source clock is divided by N where N is either 1.5, 2, 2.5, 3, 3.5, 4, 4.5, 5, 5.5, 6, 6.5, 7, 7.5, 8, 9, 10, 11, 12, 13, 14, 15, or 16.

This feature provides automatic duty cycle correction such that the CLKDV output pin has a 50/50 duty cycle always in low-frequency mode, as well as for all integer values of the division factor N in high-frequency mode.

**Frequency Synthesized Clock Output - CLKFX**

The CLKFX output provides a frequency-synthesized clock (M/D * CLKIN) with a 50/50 duty cycle. For the CLKFX output to be phase-aligned with CLKIN, the clock feedback (CLK0) must be provided at the CLKFB input. With M and D adjusted such that they have no common factor, the alignment occurs only once every D input clock cycles.

**Frequency Synthesized Clock Output 180° Phase Shifted - CLKFX180**

The CLKFX180 output is a 180° phase shifted version of the CLKFX clock output, also with a 50/50 duty cycle.

**Locked Output — LOCKED**

The LOCKED signal is activated after the DCM has achieved the parameter values set by the user parameters. To guarantee that the system clock is established prior to the device “waking up,” the DCM can delay the completion of the device configuration process until after the DCM locks. The STARTUP_WAIT attribute activates this feature. Until the LOCKED signal activates, the DCM output clocks are not valid and can exhibit glitches, spikes, or other spurious signals.

**Reset Input — RST**

When the reset pin activates, the LOCKED signal deactivates within four source clock cycles. The M and D values at configuration are maintained after the reset. The RST pin, active High, must either connect to a dynamic signal or be tied to ground. Activation of the RST pin can also severely affect the duty cycle of the clock output pins. For this reason, activate the reset pin only when reconfiguring the device or changing the input frequency. The reset input signal is asynchronous and should be held High for at least 2 ns.

**Status - STATUS**

The STATUS output is an 8-bit output:

- STATUS[1] indicates the loss of the input clock, CLKIN, only when CLKFB is connected.
- STATUS[2] indicates loss of CLKFX and CLKFX180 even though LOCKED might still be High. Note that this “CLKFX stopped” status functions only when CLKIN is present.

**Attributes**

The following attributes provide access to some of the Virtex-II Pro Series frequency synthesis features, (for example, clock multiplication, clock division).

**Clock Divide**

The CLKDV_DIVIDE attribute specifies how the signal on the CLKDV pin is frequency divided with respect to the CLK0 pin. The values allowed for this attribute are 1.5, 2, 2.5, 3, 3.5, 4, 4.5, 5, 5.5, 6, 6.5, 7, 7.5, 8, 9, 10, 11, 12, 13, 14, 15, or 16; the default value is 2.
Frequency Mode for Frequency Synthesis

This attribute specifies either the high or low-frequency mode of the frequency synthesizer. The default is low-frequency mode. The frequency ranges for both frequency modes are specified in the Virtex-II Pro Data Sheet.

To set the frequency synthesizer to high-frequency mode, attach the DFS_FREQUENCY_MODE=HIGH attribute in the source code or schematic.

Multiply/Divide Attribute

The M and D values can be set using the CLKFX_MULTIPLY and the CLKFX_DIVIDE attributes. The default settings are M = 4 and D = 1.

Startup Delay

The default value of the STARTUP_WAIT attribute is FALSE. When STARTUP_WAIT is set to TRUE, and the LCK_cycle BitGen option is used, then the configuration startup sequence waits in the specified cycle until the DCM locks. For details, see Chapter 3: Configuration and Appendix A: BitGen and PROMGen Switches and Options.

Submodules

Figure 2-29: BUFG_DFS_SUBM

Figure 2-30: BUFG_DFS_FB_SUBM
Phase Shifting

The DCM can also provide coarse and fine-grained phase shifting. The CLK0, CLK90, CLK180, and CLK270 outputs are each phase shifted by \( \frac{1}{4} \) of the input clock period relative to each other, providing coarse phase control. Note that CLK90 and CLK270 are not available in high-frequency mode.

Operation

Figure 2-31 shows a block diagram of the DCM and all of the outputs affected by the circuitry of the phase shift feature.

![Phase Shift Outputs Diagram](image)

**Figure 2-31:** Phase Shift Outputs

Fine-phase adjustment affects all nine DCM output clocks. When activated, the phase shift between the rising edges of CLKIN and CLKFB is a specified fraction of the input clock period. In variable mode, the PHASE_SHIFT value can also be dynamically incremented or decremented as determined by PSINCDEC synchronously to PSCLK, when the PSEN input is active. Figure 2-32 illustrates the effects of fine-phase shifting.

![Phase Shift Effects Diagram](image)

**Figure 2-32:** Phase Shift Effects
Two separate components of the phase shift range must be understood:

- PHASE_SHIFT attribute range
- FINE_SHIFT_RANGE DCM timing parameter range

The PHASE_SHIFT attribute is the numerator in the following equation:

\[
\text{Phase Shift (ns)} = \left( \frac{\text{PHASE_SHIFT}}{256} \right) \times \text{PERIODCLKin}
\]

The full range of this attribute is always -255 to +255, but its practical range varies with CLKin frequency, as constrained by the FINE_SHIFT_RANGE component, which represents the total delay achievable by the phase shift delay line. Total delay is a function of the number of delay taps used in the circuit. Across process, voltage, and temperature, this absolute range is guaranteed to be as specified in the DCM Timing Parameters section of the Virtex-II Pro Data Sheet.

Absolute range (fixed mode) = ± FINE_SHIFT_RANGE

Absolute range (variable mode) = ± FINE_SHIFT_RANGE/2

The reason for the difference between fixed and variable modes is as follows. For variable mode to allow symmetric, dynamic sweeps from -255/256 to +255/256, the DCM sets the "zero phase skew" point as the middle of the delay line, thus dividing the total delay line range in half. In fixed mode, since the PHASE_SHIFT value never changes after configuration, the entire delay line is available for insertion into either the CLKin or CLKFB path (to create either positive or negative skew).

Taking both of these components into consideration, the following are some usage examples:

- If PERIOD_CLKin = two times FINE_SHIFT_RANGE, then PHASE_SHIFT in fixed mode is limited to ± 128, and in variable mode it is limited to ± 64.
- If PERIOD_CLKin = FINE_SHIFT_RANGE, then PHASE_SHIFT in fixed mode is limited to ± 255, and in variable mode it is limited to ± 128.
- If PERIOD_CLKin ≤ half of the FINE_SHIFT_RANGE, then PHASE_SHIFT is limited to ± 255 in either mode.

In variable mode, the phase factor can be changed by activating PSEN for one period of PSCLK. Increments or decrements to the phase factor can be made by setting the PSINCDEC pin to a High or Low, respectively. When the de-skew circuit has completed an increment or decrement operation, the signal PSDONE goes High for a single PSCLK cycle. This indicates to the user that the next change may be made.

The user interface and the physical implementation are different. The user interface describes the phase shift as a fraction of the clock period (N/256). The physical implementation adds the appropriate number of buffer stages (each DCM_TAP) to the clock delay. The DCM_TAP granularity limits the phase resolution at higher clock frequencies.

**Phase Shift Characteristics**

- Offers fine-phase adjustment with a resolution of ±1/256 of the clock period (or ± one DCM_TAP, whichever is greater) by configuration and also dynamically under user control.
- The phase shift settings affect all nine DCM outputs.
- \( V_{CC} \) and temperature do not affect the phase shift.
Port Signals

1x Clock Outputs — CLK[0|90|180|270]

The 1x clock output pin CLK0 represents a delay-compensated version of the source clock (CLKIN) signal. In low-frequency mode, the DCM provides three phase-shifted versions of the CLK0 signal (CLK90, CLK180, and CLK270), whereas in high-frequency mode, only the 180 phase-shifted version is provided. All four (including CLK0) of the phase shifted outputs can be used simultaneously in low-frequency mode. The relationship between phase shift and the corresponding period shift appears in Table 2-8. The timing diagrams in Figure 2-33 illustrate the DLL clock output characteristics.

Table 2-8: Relationship of Phase-Shifted Output Clock to Period Shift

<table>
<thead>
<tr>
<th>Phase (degrees)</th>
<th>% Period Shift</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0%</td>
</tr>
<tr>
<td>90</td>
<td>25%</td>
</tr>
<tr>
<td>180</td>
<td>50%</td>
</tr>
<tr>
<td>270</td>
<td>75%</td>
</tr>
</tbody>
</table>

By default, the DCM provides a 50/50 duty cycle correction on all 1x clock outputs. The DUTY_CYCLE_CORRECTION attribute (TRUE by default), controls this feature. Attach the DUTY_CYCLE_CORRECTION=FALSE property to the DCM symbol in order to deactivate the DCM duty cycle correction. With duty cycle correction deactivated, the output clocks have the same duty cycle as the source clock.

The DCM clock outputs can drive an OBUF, a BUFGMUX, or they can route directly to the clock input of a synchronous element.

Figure 2-33: DLL Output Characteristics
Digital Clock Managers (DCMs)

Source Clock Input — CLKIN
The CLKIN pin provides the user source clock to the DCM. The CLKIN frequency must fall in the ranges specified in the Virtex-II Pro Data Sheet. The clock input signal can be provided by one of the following:

- IBUF — Input buffer
- IBUFG — Global clock input buffer
- BUFGMUX — Internal global clock buffer

Feedback Clock Input — CLKFB
A DCM requires a reference or feedback signal to provide delay-compensated output. Connect only the CLK0 or CLK2X DCM outputs to the feedback clock input (CLKFB) pin to provide the necessary feedback to the DCM. The feedback clock input signal can be driven by an internal global clock buffer (BUFGMUX), one of the global clock input buffers (IBUFG) on the same edge of the device (top or bottom), or IBUF (the input buffer.)

If an IBUFG sources the CLKFB pin, the following special rules apply:
1. An external input port must source the signal that drives the IBUFG input pin.
2. That signal must directly drive only OBUFs and nothing else.

Phase Shift Clock - PSCLK
The PSCLK input can be sourced by the CLKIN signal to the DCM, or it can be a lower or higher frequency signal provided from any clock source (external or internal). The frequency range of PSCLK is defined by PSCLK_FREQ_LF/HF (see the Virtex-II Pro Data Sheet). This input has to be tied to ground when the CLKOUT_PHASE_SHIFT attribute is set to NONE or FIXED.

Phase Shift Increment/Decrement - PSINCDEC
The PSINCDEC signal is synchronous to PSCLK and is used to increment or decrement the phase shift factor. In order to increment or decrement the phase shift by 1/256 of clock period, the PSINCDEC signal must be High for increment or Low for decrement. This input has to be tied to ground when the CLKOUT_PHASE_SHIFT attribute is set to NONE or FIXED.

Phase Shift Enable - PSEN
To initiate a variable phase-shift operation, the PSEN input must be activated for one period of PSCLK. The phase change becomes effective after up to 100 CLKIN pulse cycles plus three PSCLK cycles, and is indicated by a High pulse on PSDONE. During the phase transition there are no sporadic changes or glitches on any output. PSEN must be tied to ground when the CLKOUT_PHASE_SHIFT attribute is set to NONE or FIXED.

Reset Input — RST
When the reset pin is activated, the LOCKED signal deactivates within four source clock cycles. After reset, the phase shift value is set to its value at configuration in both the fixed and variable modes. The RST pin, active High, must either connect to a dynamic signal or be tied to ground. Activation of the RST pin can also severely affect the duty cycle of the clock output pins. For this reason, activate the reset pin only when reconfiguring the device or changing the input frequency. The reset input signal is asynchronous and should be held High for at least 2 ns.

Locked Output — LOCKED
The LOCKED signal activates after the DCM has achieved lock. To guarantee that the system clock is established prior to the device “waking up,” the DCM can delay the completion of the device configuration process until after the DCM locks. The STARTUP_WAIT attribute activates this feature. Until the LOCKED signal activates, the DCM output clocks are not valid and can exhibit glitches, spikes, or other spurious movement. For details, see Chapter 3: Configuration.
Phase Shift DONE - PSDONE

The PSDONE signal is synchronous to PSCLK and it indicates, by pulsing High for one period of PSCLK, that the requested phase shift was achieved. This signal also indicates to the user that a new change to the phase shift numerator can be made. This output signal is not valid if the phase shift feature is not being used or is in FIXED mode.

Status - STATUS

STATUS[0] indicates the overflow of the phase shift numerator and that the absolute delay range of the phase shift delay line is exceeded.

Attributes

The following attributes provide access to the Virtex-II Pro fine-phase adjustment capability.

Clock Out Phase Shift

The CLKOUT_PHASE_SHIFT attribute controls the use of the PHASE_SHIFT value. It can be set to NONE, FIXED, or VARIABLE.

By default, this attribute is set to NONE, indicating that the phase shift feature is not being used. If the attribute is set to either FIXED or NONE, then the PSEN, PSINCDEC, and the PSCLK inputs must be tied to ground. When the attribute is set to FIXED, a positive PHASE_SHIFT value must be used. If a negative phase shift is required, one of the workarounds described in Solution Record 13349 can be used. When the attribute is set to NONE, the PHASE_SHIFT value has no effect on the DCM outputs.

The effects of the CLKOUT_PHASE_SHIFT attribute are shown in Figure 2-32.

PHASE_SHIFT

This attribute specifies the phase shift numerator as any value from -255 to 255.

Submodules

![Diagram](image-url)
Digital Clock Managers (DCMs)

**Figure 2-35:** BUFG_PHASE_CLK0_SUBM

**Figure 2-36:** BUFG_PHASE_CLK2X_SUBM

**Figure 2-37:** BUFG_PHASE_CLKDV_SUBM
VHDL and Verilog Instantiation

VHDL and Verilog instantiation templates are available as examples (see "VHDL and Verilog Templates" on page 196) for all submodules.

In VHDL, each template has a component declaration section and an architecture section. Each part of the template should be inserted within the VHDL design file. The port map of the architecture section should include the design signal names.

VHDL and Verilog Templates

The following submodules described in this section are available:

- BUFG_CLK0_SUBM
- BUFG_CLK2X_SUBM
- BUFG_CLK0_FB_SUBM
- BUFG_CLK2X_FB_SUBM
- BUFG_CLKDV_SUBM
- BUFG_DFS_SUBM
- BUFG_DFS_FB_SUBM
- BUFG_PHASE_CLKFX_FB_SUBM
- BUFG_PHASE_CLK0_SUBM
- BUFG_PHASE_CLK2X_SUBM
- BUFG_PHASE_CLKDV_SUBM

The corresponding submodules must be synthesized with the design. The BUFG_CLK0_SUBM submodule is provided in VHDL and Verilog as an example.

VHDL Template

```
-- Module: BUFG_CLK0_SUBM
-- Description: VHDL submodule
-- DCM with CLK0 deskew
-- Device: Virtex-II Pro Family
---------------------------------------------------------------------
library IEEE;
use IEEE.std_logic_1164.all;
--
-- pragma translate_off
library UNISIM;
use UNISIM.VCOMPONENTS.ALL;
-- pragma translate_on
--
entity BUFG_CLK0_SUBM is
port (
    CLK_IN : in std_logic;
    RST    : in std_logic;
    CLK1X  : out std_logic;
    LOCK   : out std_logic
);
end BUFG_CLK0_SUBM;
--
architecture BUFG_CLK0_SUBM_arch of BUFG_CLK0_SUBM is
-- Components Declarations:
component BUFG
    port (   
        I : in std_logic;
        O : out std_logic
    );
end component;
component DCM
```
-- pragma translate_off

generic (
  DLL_FREQUENCY_MODE : string := "LOW";
  DUTY_CYCLE_CORRECTION : boolean := TRUE;
  STARTUP_WAIT : boolean := FALSE
);
-- pragma translate_on

port ( CLKIN : in  std_logic;
       CLKFB : in  std_logic;
       DSSEN : in  std_logic;
       PSINCDEC : in  std_logic;
       PSEN : in  std_logic;
       PSLCK : in  std_logic;
       RST : in  std_logic;
       CLK0 : out std_logic;
       CLK90 : out std_logic;
       CLK180 : out std_logic;
       CLK270 : out std_logic;
       CLK2X : out std_logic;
       CLK2X180 : out std_logic;
       CLKDV : out std_logic;
       CLKFX : out std_logic;
       CLKFX180 : out std_logic;
       LOCKED : out std_logic;
       PSDONE : out std_logic;
       STATUS : out std_logic_vector(7 downto 0)
);
end component;
-- Attributes
attribute DLL_FREQUENCY_MODE : string;
attribute DUTY_CYCLE_CORRECTION : string;
attribute STARTUP_WAIT : string;
attribute DLL_FREQUENCY_MODE of U_DCM: label is "LOW";
attribute DUTY_CYCLE_CORRECTION of U_DCM: label is "TRUE";
attribute STARTUP_WAIT of U_DCM: label is "FALSE";
-- Signal Declarations:
signal GND : std_logic;
signal CLK0_W: std_logic;
begin
  GND <= '0';
  CLK1X <= CLK0_W;
-- DCM Instantiation
U_DCM: DCM
  port map (CLKIN => CLK_IN,
            CLKFB => CLK1X_W,
            DSSEN => GND,
            PSINCDEC => GND,
            PSEN => GND,
            PSLCK => GND,
            RST => RST,
            CLK0 => CLK0_W,
            LOCKED => LOCK
);
-- BUFG Instantiation
U_BUFG: BUFG
  port map (I => CLK0_W,
            O => CLK1X_W);
end BUFG_CLK0_SUBM_arch;
Verilog Template

// Module: BUFG_CLK0_SUBM
// Description: Verilog Submodule
// DCM with CLK0 deskew
//
// Device: Virtex-II Pro Family
//=================================================================

module BUFG_CLK0_SUBM (
    CLK_IN,
    RST,
    CLK1X,
    LOCK
);

input CLK_IN;
input RST;
output CLK1X;
output LOCK;
wire CLK0_W;
wire GND;
assign GND = 1'b0;

//BUFG Instantiation
//
BUFG U_BUFG (.I(CLK0_W),
               .O(CLK1X)
);

// Attributes for functional simulation//
// synopsys translate_off
defparam U_DCM.DLL_FREQUENCY_MODE = "LOW";
defparam U_DCM.DUTY_CYCLE_CORRECTION = "TRUE";
defparam U_DCM.STARTUP_WAIT = "FALSE";
// synopsys translate_on
// Instantiate the DCM primitive//
DCM U_DCM (.CLKFB(CLK1X),
            .CLKIN(CLK_IN),
            .DSSEN(GND),
            .PSCLK(GND),
            .PSEN(GND),
            .PSINCDEC(GND),
            .RST(RST),
            .CLK0(CLK0_W),
            .LOCKED(LOCK)
);

// synthesis attribute declarations
/* synopsys attribute
DLL_FREQUENCY_MODE "LOW"
DUTY_CYCLE_CORRECTION "TRUE"
STARTUP_WAIT "FALSE"
*/
endmodule
DCM Waveforms

The DCM waveforms shown below are the results of functional simulation using Model Technology's ModelSim EE/Plus 5.3a_p1 simulator. Note that the time scale for these simulations were set to 1ns/1ps. It is important to set the unused inputs of the DCM to logic 0 and to set the attribute values to the correct data types. For example, the PHASE_SHIFT, CLKFX_DIVIDE, and CLKFX_MULTIPLY attributes are integers and should be set to values as shown.

```
defparam U_DCM.DFS_FREQUENCY_MODE = "LOW";
defparam U_DCM.CLKFX_DIVIDE = 1; (this value’s range is specified under Frequency Synthesis in the Virtex-II Pro Data Sheet)
defparam U_DCM.CLKFX_MULTIPLY = 4; (this value’s range is specified under Frequency Synthesis in the Virtex-II Pro Data Sheet)
defparam U_DCM.CLKOUT_PHASE_SHIFT = "FIXED";
defparam U_DCM.PHASE_SHIFT = 150;       (Any value from 1 to 255)
defparam U_DCM.STARTUP_WAIT = "FALSE";
```

The input clock, 'clk_in' (CLKIN input of DCM) in all these waveforms is 50 MHz. The DCM_DLL waveforms in Figure 2-38 shows four DCM outputs, namely, clk1x (CLK0 output of DCM), clk2x (CLK2X output of DCM), clk90 (CLK90 output of DCM), and clk180 (CLK180 output of DCM).

![DCM_DLL Waveforms](image)

**Figure 2-38: DCM_DLL Waveforms**

The DCM_DFS Waveforms in Figure 2-39 shows four DCM outputs namely, clk1x (CLK0 output of DCM), clk2x (CLK2X output of DCM), clkfx (CLKFX output of DCM), and clkfx180 (CLKFX180 output of DCM). In this case the attributes, CLKFX_DIVIDE = 1, and the CLKFX_MULTIPLY = 3.
The DCM_DPS waveforms in Figure 2-40 shows four DCM outputs, namely, clk1x (CLK0 output of DCM), clk2x (CLK2X output of DCM), clk90 (CLK90 output of DCM), and clk180 (CLK180 output of DCM). In this case, the attribute PHASE_SHIFT = 150 which translates to a phase shift of (150 x 20 ns)/256 = 11.719 ns, where 20 ns is the clock period.

Figure 2-39: DCM_DFS Waveforms

The DCM_DPS waveforms in Figure 2-40 shows four DCM outputs, namely, clk1x (CLK0 output of DCM), clk2x (CLK2X output of DCM), clk90 (CLK90 output of DCM), and clk180 (CLK180 output of DCM). In this case, the attribute PHASE_SHIFT = 150 which translates to a phase shift of (150 x 20 ns)/256 = 11.719 ns, where 20 ns is the clock period.

Figure 2-40: DCM_DPS Waveforms
The DCM_DPS_DFS waveforms in Figure 2-41 shows four DCM outputs namely, clk1x (CLK0 output of DCM), clk90 (CLK90 output of DCM), clkfx (CLKFX output of DCM), and clkfx180 (CLKFX180 output of DCM). In this case, the attributes, CLKFX_DIVIDE = 1, and the CLKFX_MULTIPLY = 4. The attribute, PHASE_SHIFT = 150 which translates to a phase shift of \((150 \times 20 \text{ ns})/256 = 11.719 \text{ ns}\), where 20 ns is the clock period.

---

**Block SelectRAM™ Memory**

**Introduction**

In addition to distributed SelectRAM memory, Virtex-II Pro devices feature a large number of 18 Kb block SelectRAM memories. The block SelectRAM memory is a True Dual-Port™ RAM, offering fast, discrete, and large blocks of memory in the device. The memory is organized in columns, and the total amount of block SelectRAM memory depends on the size of the Virtex-II Pro device. The 18 Kb blocks are cascadable to enable a deeper and wider memory implementation, with a minimal timing penalty incurred through specialized routing resources.

Embedded dual- or single-port RAM modules, ROM modules, synchronous FIFOs, and data width converters are easily implemented using the Xilinx CORE Generator “Block Memory” modules. Asynchronous FIFOs can be generated using the CORE Generator Asynchronous FIFO and “Block Memory” module. Starting with IP Update #3, the designer can also generate synchronous FIFOs using Block Memory.

**Synchronous Dual-Port and Single-Port RAM**

**Data Flow**

The 18Kb block SelectRAM dual-port memory consists of an 18 Kb storage area and two completely independent access ports, A and B. The structure is fully symmetrical, and both ports are interchangeable.
Data can be written to either port and can be read from the same or the other port. Each port is synchronous, with its own clock, clock enable, and write enable. Note that the read operation is also synchronous and requires a clock edge.

As described below, there are three options for the behavior of the data output during a write operation on its port. There is no dedicated monitor to arbitrate the result of identical addresses on both ports. It is up to the user to time the two clocks appropriately. However, conflicting simultaneous writes to the same location never cause any physical damage.

Operating Modes
To maximize utilization of the True Dual-Port memory at each clock edge, the block SelectRAM memory supports three different write modes for each port. The “read during write” mode offers the flexibility of using the data output bus during a write operation on the same port. Output behavior is determined by the configuration. This choice increases the efficiency of block SelectRAM memory at each clock cycle and allows designs that use maximum bandwidth.

Read Operation
The read operation uses one clock edge. The read address is registered on the read port, and the stored data is loaded into the output latches after the RAM access interval passes.

Write Operations
A write operation is a single clock-edge operation. The write address is registered on the write port, and the data input is stored in memory. Three different modes are used to determine data available on the output latches after a write clock edge.
**WRITE_FIRST or Transparent Mode (Default)**

In WRITE_FIRST mode, the input data is simultaneously written into memory and stored in the data output (transparent write), as shown in [Figure 2-43](#).

**READ_FIRST or Read-Before-Write Mode**

In READ_FIRST mode, data previously stored at the write address appears on the output latches, while the input data is being stored in memory (read before write). See [Figure 2-44](#).
NO_CHANGE Mode

In NO_CHANGE mode, the output latches remain unchanged during a write operation. As shown in Figure 2-45, data output is still the last read data and is unaffected by a write operation on the same port.

Mode selection is set by configuration. One of these three modes is set individually for each port by an attribute. The default mode is WRITE_FIRST.

![Figure 2-45: NO_CHANGE Mode Waveforms](DS631_17_040400)
Conflict Resolution

Virtex-II Pro block SelectRAM memory is a True Dual-Port RAM that allows both ports to simultaneously access the same memory cell. When one port writes to a given memory cell, the other port must not address that memory cell (for a write or a read) within the clock-to-clock setup window. Figure 2-46 describes this asynchronous operation.

Asynchronous Clocks

The first CLK_A clock edge violates the clock-to-clock setup parameter, because it occurs too soon after the last CLK_B clock edge. The write operation on port B is valid, and the read operation on port A is invalid.

At the second rising edge of the CLK_B pin, the write operation is valid. The memory location (bb) contains 4444. The second rising edge of CLK_A reads the new data at the same location (bb), which now contains 4444.

The clock-to-clock setup timing parameter is specified together with other block SelectRAM switching characteristics in the Virtex-II Pro Data Sheet.

Synchronous Clocks

When both clocks are synchronous or identical, the result of simultaneous accesses from both ports to the same memory cell is best described in words:

- If both ports read simultaneously from the same memory cell:
  Both Data_out ports will have the same data.

- If both ports write simultaneously into the same memory cell:
  The data stored in that cell becomes invalid (unless both ports write identical data).

- If one port writes and the other one reads from the same memory cell:
  The write operation succeeds, and the write port’s Data_out behaves as determined by the read output mode (write_first, read_first, or no_change).

If the write port is in read_first mode, the read port’s Data_out represents the previous content of the memory cell. If the write port is in write_first mode or in no_change mode, the read port’s Data_out becomes invalid. Obviously, the read port’s mode setting does not affect this operation.

Figure 2-46: READ-WRITE Conditions
Characteristics

- A write operation requires only one clock edge.
- A read operation requires only one clock edge.
- All inputs are registered with the port clock and have a setup-to-clock timing specification.
- All outputs have a read-through function or one of three read-during-write functions, depending on the state of the WE pin. The outputs relative to the port clock are available after the clock-to-out timing interval.
- Block SelectRAM cells are true synchronous RAM memories and do not have a combinatorial path from the address to the output.
- The ports are completely independent of each other (that is, clocking, control, address, read/write functions, initialization, and data width) without arbitration.
- Output ports are latched with a self-timed circuit, guaranteeing glitch-free reads. The state of the output port does not change until the port executes another read or write operation.
- Data input and output signals are always buses; that is, in a 1-bit width configuration, the data input signal is DI[0] and the data output signal is DO[0].

Library Primitives

The input and output data buses are represented by two buses for 9-bit width (8+1), 18-bit width (16+2), and 36-bit width (32+4) configurations. The ninth bit associated with each byte can store parity or error correction bits. No specific function is performed on this bit. The separate bus for parity bits facilitates some designs. However, other designs safely use a 9-bit, 18-bit, or 36-bit bus by merging the regular data bus with the parity bus. Read/write and storage operations are identical for all bits, including the parity bits.

Figure 2-47 shows the generic dual-port block RAM primitive. DIA, DIPA, ADDRA, DOA, DOPA, and the corresponding signals on port B are buses.

![Dual-Port Block RAM Primitive](image-url)
Table 2-9 lists the available dual-port primitives for synthesis and simulation.

**Table 2-9: Dual-Port Block RAM Primitives**

<table>
<thead>
<tr>
<th>Primitive</th>
<th>Port A Width</th>
<th>Port B Width</th>
</tr>
</thead>
<tbody>
<tr>
<td>RAMB16_S1_S1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>RAMB16_S1_S2</td>
<td>2</td>
<td>2</td>
</tr>
<tr>
<td>RAMB16_S1_S4</td>
<td>4</td>
<td>(8+1)</td>
</tr>
<tr>
<td>RAMB16_S1_S9</td>
<td>(16+2)</td>
<td>(32+4)</td>
</tr>
<tr>
<td>RAMB16_S1_S36</td>
<td>(32+4)</td>
<td></td>
</tr>
<tr>
<td>RAMB16_S2_S2</td>
<td>2</td>
<td>2</td>
</tr>
<tr>
<td>RAMB16_S2_S4</td>
<td>4</td>
<td>(8+1)</td>
</tr>
<tr>
<td>RAMB16_S2_S9</td>
<td>(16+2)</td>
<td>(32+4)</td>
</tr>
<tr>
<td>RAMB16_S2_S18</td>
<td>(32+4)</td>
<td></td>
</tr>
<tr>
<td>RAMB16_S2_S36</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RAMB16_S4_S4</td>
<td>4</td>
<td>(8+1)</td>
</tr>
<tr>
<td>RAMB16_S4_S9</td>
<td>(16+2)</td>
<td>(32+4)</td>
</tr>
<tr>
<td>RAMB16_S4_S18</td>
<td>(32+4)</td>
<td></td>
</tr>
<tr>
<td>RAMB16_S4_S36</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RAMB16_S9_S9</td>
<td>(8+1)</td>
<td>(8+1)</td>
</tr>
<tr>
<td>RAMB16_S9_S18</td>
<td>(16+2)</td>
<td>(32+4)</td>
</tr>
<tr>
<td>RAMB16_S9_S36</td>
<td>(32+4)</td>
<td></td>
</tr>
<tr>
<td>RAMB16_S18_S18</td>
<td>(16+2)</td>
<td>(32+4)</td>
</tr>
<tr>
<td>RAMB16_S18_S36</td>
<td>(32+4)</td>
<td></td>
</tr>
<tr>
<td>RAMB16_S36_S36</td>
<td>(32+4)</td>
<td></td>
</tr>
</tbody>
</table>

Figure 2-48 shows the generic single-port block RAM primitive. DI, DIP, ADDR, DO, and DOP are buses.

**Figure 2-48: Single-Port Block RAM Primitive**

Table 2-10 lists all of the available single-port primitives for synthesis and simulation.

**Table 2-10: Single-Port Block RAM Primitives**

<table>
<thead>
<tr>
<th>Primitive</th>
<th>Port Width</th>
</tr>
</thead>
<tbody>
<tr>
<td>RAMB16_S1</td>
<td>1</td>
</tr>
<tr>
<td>RAMB16_S2</td>
<td>2</td>
</tr>
<tr>
<td>RAMB16_S4</td>
<td>4</td>
</tr>
<tr>
<td>RAMB16_S9</td>
<td>(8+1)</td>
</tr>
<tr>
<td>RAMB16_S18</td>
<td>(16+2)</td>
</tr>
<tr>
<td>RAMB16_S36</td>
<td>(32+4)</td>
</tr>
</tbody>
</table>
VHDL and Verilog Instantiation

VHDL and Verilog instantiation templates are available as examples (see "VHDL and Verilog Templates" on page 212).

In VHDL, each template has a component declaration section and an architecture section. Each part of the template should be inserted within the VHDL design file. The port map of the architecture section should include the design signal names.

The SelectRAM_Ax templates (with x = 1, 2, 4, 9, 18, or 36) are single-port modules and instantiate the corresponding RAMB16_Sx module.

SelectRAM_Ax_By templates (with x = 1, 2, 4, 9, 18, or 36 and y = = 1, 2, 4, 9, 18, or 36) are dual-port modules and instantiate the corresponding RAMB16_Sx_Sy module.

Port Signals

Each block SelectRAM port operates independently of the other while accessing the same set of 18K-bit memory cells.

Clock - CLK[A|B]

Each port is fully synchronous with independent clock pins. All port input pins have setup time referenced to the port CLK pin. The data bus has a clock-to-out time referenced to the CLK pin. Clock polarity is configurable (rising edge by default).

Enable - EN[A|B]

The enable pin affects the read, write, and set/reset functionality of the port. Ports with an inactive enable pin keep the output pins in the previous state and do not write data to the memory cells. Enable polarity is configurable (active High by default).

Write Enable - WE[A|B]

Both EN and WE are active when the contents of the data input bus is written to memory at the address pointed to by the address bus. The output latches are loaded or not loaded according to the write configuration (WRITE_FIRST, READ_FIRST, NO_CHANGE). When inactive, a read operation occurs, and the contents of the memory cells referenced by the address bus reflect on the data-out bus, regardless of the write mode attribute. Write enable polarity is configurable (active High by default).

Set/Reset - SSR[A|B]

The SSR pin forces the data output latches to contain the value “SRVAL” (see "Attributes" on page 210). The data output latches are synchronously asserted to 0 or 1, including the parity bit. In a 36-bit width configuration, each port has an independent SRVAL[A | B] attribute of 36 bits. This operation does not affect RAM memory cells and does not disturb write operations on the other port. Like the read and write operation, the set/reset function is active only when the enable pin of the port is active. Set/reset polarity is configurable (active High by default).

Address Bus - ADDR[A|B]<#:0>

The address bus selects the memory cells for read or write. The width of the port determines the required address bus width, as shown in Table 2-11.
Data-In Buses - DI[A|B]<#:0> & DIP[A|B]<#:0>

Data-in buses provide the new data value to be written into RAM. The regular data-in bus (DI) and the parity data-in bus (when available) have a total width equal to the port width. For example the 36-bit port data width is represented by DI<31:0> and DIP<3:0>, as shown in Table 2-11.

Data-Out Buses - DO[A|B]<#:0> & DOP[A|B]<#:0>

Data-out buses reflect the contents of memory cells referenced by the address bus at the last active clock edge during a read operation. During a write operation (WRITE_FIRST or READ_FIRST configuration), the data-out buses reflect either the data-in buses or the stored value before write. During a write operation in NO_CHANGE mode, data-out buses are not affected. The regular data-out bus (DO) and the parity data-out bus (DOP) (when available) have a total width equal to the port width, as shown in Table 2-11.

Inverting Control Pins

For each port, the four control pins (CLK, EN, WE, and SSR) each have an individual inversion option. Any control signal can be configured as active High or Low, and the clock can be active on a rising or falling edge (active High on rising edge by default) without requiring other logic resources.

Unused Inputs

Non-connected Data and/or address inputs should be connected to logic “1”.

GSR

The global set/reset (GSR) signal of a Virtex-II Pro device is an asynchronous global signal that is active at the end of device configuration. The GSR can also restore the initial Virtex-II Pro state at any time. The GSR signal initializes the output latches to the INIT, or to the INIT_A and INIT_B value (see “Attributes” on page 210). A GSR signal has no impact on internal memory contents. Because it is a global signal, the GSR has no input pin at the functional level (block SelectRAM primitive).

Address Mapping

Each port accesses the same set of 18,432 memory cells using an addressing scheme dependent on the width of the port. The physical RAM locations addressed for a particular width are determined using the following formula (of interest only when the two ports use different aspect ratios):

\[
\text{END} = ((\text{ADDR} + 1) \times \text{Width}) - 1 \quad \text{START} = \text{ADDR} \times \text{Width}
\]

Table 2-12 shows low-order address mapping for each port width.
Attributes

Content Initialization - INIT_xx

INIT_xx attributes define the initial memory contents. By default block SelectRAM memory is initialized with all zeros during the device configuration sequence. The 64 initialization attributes from INIT_00 through INIT_3F represent the regular memory contents. Each INIT_xx is a 64-digit hex-encoded bit vector. The memory contents can be partially initialized and are automatically completed with zeros.

The following formula is used for determining the bit positions for each INIT_xx attribute. Given yy = conversion hex-encoded to decimal (xx), INIT_xx corresponds to the memory cells as follows:

- from [(yy + 1) * 256] -1
- to (yy) * 256

For example, for the attribute INIT_1F, the conversion is as follows:

- yy = conversion hex-encoded to decimal X”1F” = 31
- from [(31+1) * 256] -1 = 8191
- to 31 * 256 = 7936

More examples are given in Table 2-13.

Table 2-13: Block SelectRAM Initialization Attributes

<table>
<thead>
<tr>
<th>Attribute</th>
<th>Memory Cell</th>
<th>from</th>
<th>to</th>
</tr>
</thead>
<tbody>
<tr>
<td>INIT_00</td>
<td>255</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>INIT_01</td>
<td>511</td>
<td>256</td>
<td></td>
</tr>
<tr>
<td>INIT_02</td>
<td>767</td>
<td>512</td>
<td></td>
</tr>
<tr>
<td>...</td>
<td>...</td>
<td>...</td>
<td></td>
</tr>
<tr>
<td>INIT_0E</td>
<td>3839</td>
<td>3584</td>
<td></td>
</tr>
<tr>
<td>INIT_0F</td>
<td>4095</td>
<td>3840</td>
<td></td>
</tr>
<tr>
<td>INIT_10</td>
<td>4351</td>
<td>4096</td>
<td></td>
</tr>
<tr>
<td>...</td>
<td>...</td>
<td>...</td>
<td></td>
</tr>
<tr>
<td>INIT_1F</td>
<td>8191</td>
<td>7936</td>
<td></td>
</tr>
<tr>
<td>INIT_20</td>
<td>8447</td>
<td>8192</td>
<td></td>
</tr>
<tr>
<td>...</td>
<td>...</td>
<td>...</td>
<td></td>
</tr>
<tr>
<td>INIT_2F</td>
<td>12287</td>
<td>12032</td>
<td></td>
</tr>
<tr>
<td>INIT_30</td>
<td>12543</td>
<td>12288</td>
<td></td>
</tr>
<tr>
<td>...</td>
<td>...</td>
<td>...</td>
<td></td>
</tr>
<tr>
<td>INIT_3F</td>
<td>16383</td>
<td>16128</td>
<td></td>
</tr>
</tbody>
</table>

Table 2-12: Port Address Mapping

<table>
<thead>
<tr>
<th>Port Width</th>
<th>Parity Locations</th>
<th>Data Locations</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>N.A.</td>
<td>31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0</td>
</tr>
<tr>
<td>2</td>
<td>15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>7 6 5 4 3 2 1 0</td>
<td></td>
</tr>
<tr>
<td>8 + 1</td>
<td>3 2 1 0</td>
<td></td>
</tr>
<tr>
<td>16 + 2</td>
<td>1 0</td>
<td></td>
</tr>
<tr>
<td>32 + 4</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>
Content Initialization - INITP_xx

INITP_xx attributes define the initial contents of the memory cells corresponding to DIP/DOP buses (parity bits). By default these memory cells are also initialized to all zeros. The eight initialization attributes from INITP_00 through INITP_07 represent the memory contents of parity bits. Each INITP_xx is a 64-digit hex-encoded bit vector and behaves like a regular INIT_xx attribute. The same formula can be used to calculate the bit positions initialized by a particular INITP_xx attribute.

Output Latches Initialization - INIT (INIT_A & INIT_B)

The INIT (single-port) or INIT_A and INIT_B (dual-port) attributes define the output latches values after configuration. The width of the INIT (INIT_A & INIT_B) attribute is the port width, as shown in Table 2-14. These attributes are hex-encoded bit vectors and the default value is 0.

Output Latches Synchronous Set/Reset - SRVAL (SRVAL_A & SRVAL_B)

The SRVAL (single-port) or SRVAL_A and SRVAL_B (dual-port) attributes define output latch values when the SSR input is asserted. The width of the SRVAL (SRVAL_A and SRVAL_B) attribute is the port width, as shown in Table 2-14. These attributes are hex-encoded bit vectors and the default value is 0.

Table 2-14: Port Width Values

<table>
<thead>
<tr>
<th>Port Data Width</th>
<th>DOP Bus</th>
<th>DO Bus</th>
<th>INIT / SRVAL</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>NA</td>
<td>&lt;0&gt;</td>
<td>1</td>
</tr>
<tr>
<td>2</td>
<td>NA</td>
<td>&lt;1:0&gt;</td>
<td>2</td>
</tr>
<tr>
<td>4</td>
<td>NA</td>
<td>&lt;3:0&gt;</td>
<td>4</td>
</tr>
<tr>
<td>9</td>
<td>&lt;0&gt;</td>
<td>&lt;7:0&gt;</td>
<td>(1+8) = 9</td>
</tr>
<tr>
<td>18</td>
<td>&lt;1:0&gt;</td>
<td>&lt;15:0&gt;</td>
<td>(2+16) = 18</td>
</tr>
<tr>
<td>36</td>
<td>&lt;3:0&gt;</td>
<td>&lt;31:0&gt;</td>
<td>(4 + 32) = 36</td>
</tr>
</tbody>
</table>

Initialization in VHDL or Verilog Codes

Block SelectRAM memory structures can be initialized in VHDL or Verilog code for both synthesis and simulation. For synthesis, the attributes are attached to the block SelectRAM instantiation and are copied in the EDIF output file to be compiled by Xilinx Alliance Series™ tools. The VHDL code simulation uses a generic parameter to pass the attributes. The Verilog code simulation uses a defparam parameter to pass the attributes. The XC2V_RAMB_1_PORT block SelectRAM instantiation code examples (in VHDL and Verilog) illustrate these techniques (see “VHDL and Verilog Templates” on page 212).

Location Constraints

Block SelectRAM instances can have LOC properties attached to them to constrain placement. Block SelectRAM placement locations differ from the convention used for naming CLB locations, allowing LOC properties to transfer easily from array to array. The LOC properties use the following form:

LOC = RAMB16_X#Y#

The RAMB16_X0Y0 is the bottom-left block SelectRAM location on the device.
Applications

Creating Larger RAM Structures

Block SelectRAM columns have specialized routing to allow cascading blocks with minimal routing delays. Wider or deeper RAM structures are achieved with a smaller timing penalty than is encountered when using normal routing resources.

The CORE Generator program offers the designer a painless way to generate wider and deeper memory structures using multiple block SelectRAM instances. This program outputs VHDL or Verilog instantiation templates and simulation models, along with an EDIF file for inclusion in a design.

Multiple RAM Organizations

The flexibility of block SelectRAM memories allows designs with various types of RAM in addition to regular configurations. Application notes at www.xilinx.com describe some of these designs, with VHDL and Verilog reference designs included.

Virtex-II Pro block SelectRAM can be used as follows:

- Two independent single-port RAM resources
- One 72-bit single-port RAM resource
- One triple-port (1 Read/Write and 2 Read ports) RAM resource

Application notes with VHDL and Verilog reference designs at www.xilinx.com also describe other implementations using block SelectRAM memory, such as:

- XAPP258, FIFOs Using Virtex-II Block RAM
- XAPP260, Using Virtex-II Block RAM for High Performance Read/Write CAMs

VHDL and Verilog Templates

VHDL and Verilog templates are available for all single-port and dual-port primitives. The A and B numbers indicate the width of the ports.

The following are single-port templates:

- SelectRAM_A1
- SelectRAM_A2
- SelectRAM_A4
- SelectRAM_A9
- SelectRAM_A18
- SelectRAM_A36

The following are dual-port templates:

- SelectRAM_A1_B1
- SelectRAM_A1_B2
- SelectRAM_A1_B4
- SelectRAM_A1_B9
- SelectRAM_A1_B18
- SelectRAM_A1_B36
- SelectRAM_A2_B2
- SelectRAM_A2_B4
- SelectRAM_A2_B9
- SelectRAM_A2_B18
- SelectRAM_A2_B36
- SelectRAM_A4_B4
Block SelectRAM™ Memory

- SelectRAM_A4_B9
- SelectRAM_A4_B18
- SelectRAM_A4_B36
- SelectRAM_A9_B9
- SelectRAM_A9_B18
- SelectRAM_A9_B36
- SelectRAM_A18_B18
- SelectRAM_A18_B36
- SelectRAM_A36_B36

VHDL Template

As an example, the XC2V_RAMB_1_PORT.vhd file uses the SelectRAM_A36 template:

```vhdl
-- Module: XC2V_RAMB_1_PORT
-- Description: 18Kb Block SelectRAM example
-- Single Port 512 x 36 bits
-- Use template "SelectRAM_A36.vhd"
--
-- Device: Virtex-II Pro Family
library IEEE;
use IEEE.std_logic_1164.all;
--
-- Syntax for Synopsys FPGA Express
-- pragma translate_off
library UNISIM;
use UNISIM.VCOMPONENTS.ALL;
-- pragma translate_on
-- entity XC2V_RAMB_1_PORT is
end XC2V_RAMB_1_PORT;
--
architecture XC2V_RAMB_1_PORT_arch of XC2V_RAMB_1_PORT is
--
-- Components Declarations:
--
component BUFG
port (I: in std_logic; O: out std_logic);
end component;
--
-- Syntax for Synopsys FPGA Express
component RAMB16_S36
-- pragma translate_off
generic (
  -- "Read during Write" attribute for functional simulation
  WRITE_MODE : string := "READ_FIRST" ; -- WRITE_FIRST(default)/READ_FIRST/ NO_CHANGE
```
-- Output value after configuration
INIT : bit_vector (35 downto 0) := \text{X"000000000"};

-- Output value if SSR active
SRVAL : bit_vector (35 downto 0) := \text{X"012345678"};

-- Plus bits initial content
INITP_00 : bit_vector (255 downto 0) :=
X"0000000000000000000000000000000000000000000000000FEDCBA9876543210";
INITP_01 : bit_vector (255 downto 0) :=
X"0000000000000000000000000000000000000000000000000000000000000000";
INITP_02 : bit_vector (255 downto 0) :=
X"0000000000000000000000000000000000000000000000000000000000000000";
INITP_03 : bit_vector (255 downto 0) :=
X"0000000000000000000000000000000000000000000000000000000000000000";
INITP_04 : bit_vector (255 downto 0) :=
X"0000000000000000000000000000000000000000000000000000000000000000";
INITP_05 : bit_vector (255 downto 0) :=
X"0000000000000000000000000000000000000000000000000000000000000000";
INITP_06 : bit_vector (255 downto 0) :=
X"0000000000000000000000000000000000000000000000000000000000000000";
INITP_07 : bit_vector (255 downto 0) :=
X"0000000000000000000000000000000000000000000000000000000000000000";

-- Regular bits initial content
INIT_00 : bit_vector (255 downto 0) :=
X"00000000000000000000000000000000000000000000000000000000000000000FEDCBA9876543210";
INIT_01 : bit_vector (255 downto 0) :=
X"0000000000000000000000000000000000000000000000000000000000000000";
INIT_02 : bit_vector (255 downto 0) :=
X"0000000000000000000000000000000000000000000000000000000000000000";
...

... (cut)

-- pragma translate_on
port (
   DI : in std_logic_vector (31 downto 0);
   DIP : in std_logic_vector (3 downto 0);
   ADDR : in std_logic_vector (8 downto 0);
   EN  : in STD_LOGIC;
   WE  : in STD_LOGIC;
   SSR : in STD_LOGIC;
   CLK : in STD_LOGIC;
   DO  : out std_logic_vector (31 downto 0);
   DOP : out std_logic_vector (3 downto 0))
);
end component;

-- Attribute Declarations:
attribute WRITE_MODE : string;
attribute INIT: string;
attribute SRVAL: string;

attribute INITP_00: string;
attribute INITP_01: string;
attribute INITP_02: string;
attribute INITP_03: string;
attribute INITP_04: string;
attribute INITP_05: string;
attribute INITP_06: string;
attribute INITP_07: string;
attribute INIT_00: string;
attribute INIT_01: string;
attribute INIT_02: string;
... (cut)
attribute INIT_3E: string;
attribute INIT_3F: string;
--
-- Attribute "Read during Write mode" = WRITE_FIRST(default)/
READ_FIRST/ NO_CHANGE
attribute WRITE_MODE of U_RAMB16_S36: label is "READ_FIRST";
attribute INIT of U_RAMB16_S36: label is "000000000";
attribute SRVAL of U_RAMB16_S36: label is "012345678";
--
-- RAMB16 memory initialization for Alliance
-- Default value is "0" / Partial initialization strings are padded
-- with zeros to the left
attribute INITP_00 of U_RAMB16_S36: label is
"000000000000000000000000000000000000000000FEDCBA9876543210";
attribute INITP_01 of U_RAMB16_S36: label is
"0000000000000000000000000000000000000000000000000000000000000000";
attribute INITP_02 of U_RAMB16_S36: label is
"0000000000000000000000000000000000000000000000000000000000000000";
attribute INITP_03 of U_RAMB16_S36: label is
"0000000000000000000000000000000000000000000000000000000000000000";
attribute INITP_04 of U_RAMB16_S36: label is
"0000000000000000000000000000000000000000000000000000000000000000";
attribute INITP_05 of U_RAMB16_S36: label is
"0000000000000000000000000000000000000000000000000000000000000000";
attribute INITP_06 of U_RAMB16_S36: label is
"0000000000000000000000000000000000000000000000000000000000000000";
attribute INITP_07 of U_RAMB16_S36: label is
"0000000000000000000000000000000000000000000000000000000000000000";
--
attribute INIT_00 of U_RAMB16_S36: label is
"000000000000000000000000000000000000000000FEDCBA9876543210";
attribute INIT_01 of U_RAMB16_S36: label is
"0000000000000000000000000000000000000000000000000000000000000000";
attribute INIT_02 of U_RAMB16_S36: label is
"0000000000000000000000000000000000000000000000000000000000000000";
... (cut)
attribute INIT_3E of U_RAMB16_S36: label is
"0000000000000000000000000000000000000000000000000000000000000000";
attribute INIT_3F of U_RAMB16_S36: label is
"0000000000000000000000000000000000000000000000000000000000000000";
--
-- Signal Declarations:
--
-- signal VCC : std_logic;
-- signal GND : std_logic;
signal CLK_BUFG: std_logic;
signal INV_SET_RESET : std_logic;
--
begin
-- VCC <= '1';
-- GND <= '0';
--
-- Instantiate the clock Buffer
U_BUFG: BUFG
  port map (I => CLK,
O => CLK_BUFG
-- Use of the free inverter on SSR pin
INV_SET_RESET <= NOT SET_RESET;

-- Block SelectRAM Instantiation
U_RAMB16_S36: RAMB16_S36
  port map (  
    DI     => DATA_IN (31 downto 0), -- insert 32 bits data-in bus  
    (<31 downto 0>)
    DIP    => DATA_IN (35 downto 32), -- insert 4 bits parity data-in bus (or <35 downto 32>)
    ADDR   => ADDRESS (8 downto 0), -- insert 9 bits address bus  
    EN     => ENABLE, -- insert enable signal  
    WE     => WRITE_EN, -- insert write enable signal  
    SSR    => INV_SET_RESET, -- insert set/reset signal  
    CLK    => CLK_BUFG, -- insert clock signal  
    DO     => DATA_OUT (31 downto 0), -- insert 32 bits data-out bus  
    (<31 downto 0>)
    DOP    => DATA_OUT (35 downto 32) -- insert 4 bits parity data-out bus (or <35 downto 32>)
  );
--
end XC2V_RAMB_1_PORT_arch;

Verilog Template
// Module: XC2V_RAMB_1_PORT  
// Description: 18Kb Block SelectRAM-II example  
// Single Port 512 x 36 bits  
// Use template "SelectRAM_A36.v"  
//  
// Device: Virtex-II Pro Family  
//---------------------------------------------------------------

module XC2V_RAMB_1_PORT (CLK, SET_RESET, ENABLE, WRITE_EN, ADDRESS,  
  DATA_IN, DATA_OUT);

input CLK, SET_RESET, ENABLE, WRITE_EN;
input [35:0] DATA_IN;
input [8:0] ADDRESS;
output [35:0] DATA_OUT;
wire CLK_BUFG, INV_SET_RESET;
//Use of the free inverter on SSR pin
assign INV_SET_RESET = ~SET_RESET;

// initialize block ram for simulation  
// synopsys translate_off  
defparam  
  //"Read during Write" attribute for functional simulation  
  U_RAMB16_S36.WRITE_MODE = "READ_FIRST",  //WRITE_FIRST(default)/  
  READ_FIRST/ NO_CHANGE  
//Output value after configuration  
  U_RAMB16_S36.INIT = 36'h000000000,  
  //Output value if SSR active  
  U_RAMB16_S36.SRVAL = 36'h012345678,
R

Block SelectRAM™ Memory

//Plus bits initial content
U_RAMB16_S36.INITP_00 =
256'h0123456789ABCDEF000000000000000000000000000000000000000000000000,
U_RAMB16_S36.INITP_01 =
256'h0000000000000000000000000000000000000000000000000000000000000000,
U_RAMB16_S36.INITP_02 =
256'h0000000000000000000000000000000000000000000000000000000000000000,
U_RAMB16_S36.INITP_03 =
256'h0000000000000000000000000000000000000000000000000000000000000000,
U_RAMB16_S36.INITP_04 =
256'h0000000000000000000000000000000000000000000000000000000000000000,
U_RAMB16_S36.INITP_05 =
256'h0000000000000000000000000000000000000000000000000000000000000000,
U_RAMB16_S36.INITP_06 =
256'h0000000000000000000000000000000000000000000000000000000000000000,
U_RAMB16_S36.INITP_07 =
256'h0000000000000000000000000000000000000000000000000000000000000000,
//Regular bits initial content
U_RAMB16_S36.INIT_00 =
256'h0123456789ABCDEF000000000000000000000000000000000000000000000000,
U_RAMB16_S36.INIT_01 =
256'h0000000000000000000000000000000000000000000000000000000000000000,
U_RAMB16_S36.INIT_02 =
256'h0000000000000000000000000000000000000000000000000000000000000000,
...<cut>
U_RAMB16_S36.INIT_3E =
256'h0000000000000000000000000000000000000000000000000000000000000000,
U_RAMB16_S36.INIT_3F =
256'h0000000000000000000000000000000000000000000000000000000000000000;
// synopsys translate_on

2
3

A

//Block SelectRAM Instantiation
RAMB16_S36 U_RAMB16_S36 (
.DI(DATA_IN[31:0]),
.DIP(DATA_IN-PARITY[35:32]),
.ADDR(ADDRESS),
.EN(ENABLE),
.WE(WRITE_EN),
.SSR(INV_SET_RESET),
.CLK(CLK_BUFG),
.DO(DATA_OUT[31:0]),
.DOP(DATA_OUT-PARITY[35:32]));

B
GL

// synthesis attribute declarations
/* synopsys attribute
WRITE_MODE "READ_FIRST"
INIT "000000000"
SRVAL "012345678"
INITP_00
"0123456789ABCDEF000000000000000000000000000000000000000000000000"
INITP_01
"0000000000000000000000000000000000000000000000000000000000000000"
INITP_02
"0000000000000000000000000000000000000000000000000000000000000000"
INITP_03
"0000000000000000000000000000000000000000000000000000000000000000"

www.xilinx.com
1-800-255-7778

1

4

//Instantiate the clock Buffer
BUFG U_BUFG ( .I(CLK), .O(CLK_BUFG));

UG012 (v2.0) October 14, 2002
Virtex-II Pro™ Platform FPGA Handbook

DS

217


Distributed SelectRAM Memory

Introduction

In addition to 18Kb SelectRAM blocks, Virtex-II Pro devices feature distributed SelectRAM modules. Each function generator or LUT of a CLB resource can implement a 16 x 1-bit synchronous RAM resource. Distributed SelectRAM memory writes synchronously and reads asynchronously. However, a synchronous read can be implemented using the register that is available in the same slice. This 16 x 1-bit RAM is cascadable for a deeper and/or wider memory implementation, with a minimal timing penalty incurred through specialized logic resources.

Distributed SelectRAM modules up to a size of 128 x 1 are available as primitives. Two 16 x 1 RAM resources can be combined to form a dual-port 16 x 1 RAM with one dedicated read/write port and a second read-only port. One port writes into both 16 x1 RAMs simultaneously, but the second port reads independently.

This section provides generic VHDL and Verilog reference code examples implementing n-bit-wide single-port and dual-port distributed SelectRAM memory.

Distributed SelectRAM memory enables many high-speed applications that require relatively small embedded RAM blocks, such as FIFOs, which are close to the logic that uses them.

Virtex-II Pro Distributed SelectRAM memories can be generated using the CORE Generator Distributed Memory module (V2.0 or later). The user can also generate Distributed RAM-based Asynchronous and Synchronous FIFOs using the CORE Generator.

Single-Port and Dual-Port RAM

Data Flow

Distributed SelectRAM memory supports the following:

- Single-port RAM with synchronous write and asynchronous read
- Dual-port RAM with one synchronous write and two asynchronous read ports
As illustrated in the Figure 2-49, the dual port has one read/write port and an independent read port.

![Figure 2-49: Single-Port and Dual-Port Distributed SelectRAM](image)

Any read/write operation can occur simultaneously with and independently of a read operation on the other port.

**Write Operations**

The write operation is a single clock-edge operation, with a write enable that is active High by default. When the write enable is Low, no data is written into the RAM. When the write enable is High, the clock edge latches the write address and writes the data on D into the RAM.

**Read Operation**

The read operation is a combinatorial operation. The address port (single or dual port) is asynchronous with an access time equivalent to the logic delay.

**Read During Write**

When new data is synchronously written, the output reflects the data in the memory cell addressed (transparent mode). The timing diagram in Figure 2-50 illustrates a write operation, with the previous data read on the output port, before the clock edge and then the new data.

![Figure 2-50: Write Timing Diagram](image)
Characteristics

- A write operation requires only one clock edge.
- A read operation requires only the logic access time.
- Outputs are asynchronous and dependent only on the logic delay.
- Data and address inputs are latched with the write clock and have a setup-to-clock timing specification. There is no hold time requirement.
- For dual-port RAM, one address is the write and read address, the other address is an independent read address.

Library Primitives

Seven library primitives from 16 x 1-bit to 128 x 1-bit are available. Four primitives are single-port RAM and three primitives are True Dual-Port RAM, as shown in Table 2-15.

<table>
<thead>
<tr>
<th>Primitive</th>
<th>RAM Size</th>
<th>Type</th>
<th>Address Inputs</th>
</tr>
</thead>
<tbody>
<tr>
<td>RAM16X1S</td>
<td>16 bits</td>
<td>single-port</td>
<td>A3, A2, A1, A0</td>
</tr>
<tr>
<td>RAM32X1S</td>
<td>32 bits</td>
<td>single-port</td>
<td>A4, A3, A2, A1, A0</td>
</tr>
<tr>
<td>RAM64X1S</td>
<td>64 bits</td>
<td>single-port</td>
<td>A5, A4, A3, A2, A1, A0</td>
</tr>
<tr>
<td>RAM128X1S</td>
<td>128 bits</td>
<td>single-port</td>
<td>A6, A5, A4, A3, A2, A1, A0</td>
</tr>
<tr>
<td>RAM16X1D</td>
<td>16 bits</td>
<td>dual-port</td>
<td>A3, A2, A1, A0</td>
</tr>
<tr>
<td>RAM32X1D</td>
<td>32 bits</td>
<td>dual-port</td>
<td>A4, A3, A2, A1, A0</td>
</tr>
<tr>
<td>RAM64X1D</td>
<td>64 bits</td>
<td>dual-port</td>
<td>A5, A4, A3, A2, A1, A0</td>
</tr>
</tbody>
</table>

The input and output data are 1-bit wide. However, several distributed SelectRAM memories can be used to implement wide memory blocks.

Figure 2-51 shows generic single-port and dual-port distributed SelectRAM primitives. The A and DPRA signals are address buses.

![Figure 2-51: Single-Port and Dual-Port Distributed SelectRAM Primitive](image_url)
As shown in Table 2-16, wider library primitives are available for 2-bit, 4-bit, and 8-bit RAM.

**Table 2-16: Wider Library Primitives**

<table>
<thead>
<tr>
<th>Primitive</th>
<th>RAM Size</th>
<th>Data Inputs</th>
<th>Address Inputs</th>
<th>Data Outputs</th>
</tr>
</thead>
<tbody>
<tr>
<td>RAM16x2S</td>
<td>16 x 2-bit</td>
<td>D1, D0</td>
<td>A3, A2, A1, A0</td>
<td>O1, O0</td>
</tr>
<tr>
<td>RAM32x2S</td>
<td>32 x 2-bit</td>
<td>D1, D0</td>
<td>A4, A3, A2, A1, A0</td>
<td>O1, O0</td>
</tr>
<tr>
<td>RAM64x2S</td>
<td>64 x 2-bit</td>
<td>D1, D0</td>
<td>A5, A4, A3, A2, A1, A0</td>
<td>O1, O0</td>
</tr>
<tr>
<td>RAM16x4S</td>
<td>16 x 4-bit</td>
<td>D3, D2, D1, D0</td>
<td>A3, A2, A1, A0</td>
<td>O3, O2, O1, O0</td>
</tr>
<tr>
<td>RAM32x4S</td>
<td>32 x 4-bit</td>
<td>D3, D2, D1, D0</td>
<td>A4, A3, A2, A1, A0</td>
<td>O3, O2, O1, O0</td>
</tr>
<tr>
<td>RAM16x8S</td>
<td>16 x 8-bit</td>
<td>D &lt;7:0&gt;</td>
<td>A3, A2, A1, A0</td>
<td>O &lt;7:0&gt;</td>
</tr>
<tr>
<td>RAM32x8S</td>
<td>32 x 8-bit</td>
<td>D &lt;7:0&gt;</td>
<td>A4, A3, A2, A1, A0</td>
<td>O &lt;7:0&gt;</td>
</tr>
</tbody>
</table>

**VHDL and Verilog Instantiation**

VHDL and Verilog instantiations templates are available as examples (see "VHDL and Verilog Templates" on page 225).

In VHDL, each template has a component declaration section and an architecture section. Each part of the template should be inserted within the VHDL design file. The port map of the architecture section should include the design signal names.

The SelectRAM_<x>S templates (with <x> = 16, 32, 64, or 128) are single-port modules and instantiate the corresponding RAM<x>S primitive.

SelectRAM_<x>D templates (with <x> = 16, 32, or 64) are dual-port modules and instantiate the corresponding RAM<x>D primitive.
Ports Signals

Each distributed SelectRAM port operates independently of the other while reading the same set of memory cells.

Clock - WCLK

The clock is used for the synchronous write. The data and the address input pins have setup time referenced to the WCLK pin.

Enable - WE

The enable pin affects the write functionality of the port. An inactive Write Enable prevents any writing to memory cells. An active Write Enable causes the clock edge to write the data input signal to the memory location pointed to by the address inputs.

Address - A0, A1, A2, A3 (A4, A5, A6)

The address inputs select the memory cells for read or write. The width of the port determines the required address inputs. Note that the address inputs are not a bus in VHDL or Verilog instantiations.

Data In - D

The data input provides the new data value to be written into the RAM.

Data Out - O, SPO, and DPO

The data out O (Single-Port or SPO) and DPO (Dual-Port) reflects the contents of the memory cells referenced by the address inputs. Following an active write clock edge, the data out (O or SPO) reflects the newly written data.

Inverting Control Pins

The two control pins (WCLK and WE) each have an individual inversion option. Any control signal, including the clock, can be active at 0 (negative edge for the clock) or at 1 (positive edge for the clock) without requiring other logic resources.

GSR

The global set/reset (GSR) signal does not affect distributed SelectRAM modules.

Attributes

Content Initialization - INIT

With the INIT attributes, users can define the initial memory contents after configuration. By default distributed SelectRAM memory is initialized with all zeros during the device configuration sequence. The initialization attribute INIT represents the specified memory contents. Each INIT is a hex-encoded bit vector. Table 2-17 shows the length of the INIT attribute for each primitive.

<table>
<thead>
<tr>
<th>Primitive</th>
<th>Template</th>
<th>INIT Attribute Length</th>
</tr>
</thead>
<tbody>
<tr>
<td>RAM16X1S</td>
<td>SelectRAM_16S</td>
<td>4 digits</td>
</tr>
<tr>
<td>RAM32X1S</td>
<td>SelectRAM_32S</td>
<td>8 digits</td>
</tr>
<tr>
<td>RAM64X1S</td>
<td>SelectRAM_64S</td>
<td>16 digits</td>
</tr>
<tr>
<td>RAM128X1S</td>
<td>SelectRAM_128S</td>
<td>32 digits</td>
</tr>
<tr>
<td>RAM16X1D</td>
<td>SelectRAM_16S</td>
<td>4 digits</td>
</tr>
<tr>
<td>RAM32X1D</td>
<td>SelectRAM_32S</td>
<td>8 digits</td>
</tr>
<tr>
<td>RAM64X1D</td>
<td>SelectRAM_64S</td>
<td>16 digits</td>
</tr>
</tbody>
</table>
Initialization in VHDL or Verilog Codes

Distributed SelectRAM memory structures can be initialized in VHDL or Verilog code for both synthesis and simulation. For synthesis, the attributes are attached to the distributed SelectRAM instantiation and are copied in the EDIF output file to be compiled by Xilinx Alliance Series™ tools. The VHDL code simulation uses a generic parameter to pass the attributes. The Verilog code simulation uses a defparam parameter to pass the attributes.

The distributed SelectRAM instantiation templates (in VHDL and Verilog) illustrate these techniques (see "VHDL and Verilog Templates" on page 225).

Location Constraints

The CLB has four slices S0, S1, S2 and S3. As an example, in the bottom left CLB, the slices have the coordinates shown below:

<table>
<thead>
<tr>
<th>Slice S3</th>
<th>Slice S2</th>
<th>Slice S1</th>
<th>Slice S0</th>
</tr>
</thead>
<tbody>
<tr>
<td>X1Y1</td>
<td>X1Y0</td>
<td>X0Y1</td>
<td>X0Y0</td>
</tr>
</tbody>
</table>

Distributed SelectRAM instances can have LOC properties attached to them to constrain placement. The RAM16X1S primitive fits in any LUT of slices S0 or S1.

For example, the instance U_RAM16 is placed in slice X0Y0 with the following LOC properties:

INST "U_RAM16" LOC = "SLICE_X0Y0";

The RAM16X1D primitive occupies half of two slices, as shown in Figure 2-52. The first slice (output SPO) implements the read/write port with the same address A[3:0] for read and write. The second slice implements the second read port with the address DPRA[3:0] and is written simultaneously with the first slice to the address A[3:0].

In the same CLB module, the dual-port RAM16X1D either occupies half of slices S0 (X0Y0) and S2 (X1Y0), or half of slices S1 (X0Y1) and S3 (X1Y1).
If a dual-port 16 x 2-bit module is built, the two RAM16X1D primitives occupy two slices, as long as they share the same clock and write enable, as illustrated in Figure 2-53.

![Figure 2-53: Two RAM16X1D Placement](image1)

A RAM32X1S primitive fits in one slice, as shown in Figure 2-54.

![Figure 2-54: RAM32X1S Placement](image2)

Following the same rules, a RAM32X1D primitive fits in two slices, with one slice implementing the read/write port and the second slice implementing the second read port.

The RAM64X1S primitive occupies two slices and the RAM64X1D primitive occupies four slices (one CLB element), with two slices implementing the read/write port and two other slices implementing the second read port. The RAM64X1S read path is built on the MUXF5 and MUXF6 multiplexers.

The RAM128X1S primitive occupies four slices, equivalent to one CLB element. Distributed SelectRAM placement locations use the slice location naming convention, allowing LOC properties to transfer easily from array to array.
Applications

Creating Larger RAM Structures

The memory compiler program generates wider and/or deeper memory structures using distributed SelectRAM instances. Along with an EDIF file for inclusion in a design, this program produces VHDL and Verilog instantiation templates and simulation models.

*Table 2-18* shows the generic VHDL and Verilog distributed SelectRAM examples provided to implement \( n \)-bit-wide memories.

**Table 2-18: VHDL and Verilog Submodules**

<table>
<thead>
<tr>
<th>Submodules</th>
<th>Primitive</th>
<th>Size</th>
<th>Type</th>
</tr>
</thead>
<tbody>
<tr>
<td>XC2V_RAM16XN_S_SUBM</td>
<td>RAM16X1S</td>
<td>16 words x ( n )-bit</td>
<td>single-port</td>
</tr>
<tr>
<td>XC2V_RAM32XN_S_SUBM</td>
<td>RAM32X1S</td>
<td>32 words x ( n )-bit</td>
<td>single-port</td>
</tr>
<tr>
<td>XC2V_RAM64XN_S_SUBM</td>
<td>RAM64X1S</td>
<td>64 words x ( n )-bit</td>
<td>single-port</td>
</tr>
<tr>
<td>XC2V_RAM128XN_S_SUBM</td>
<td>RAM128X1S</td>
<td>128 words x ( n )-bit</td>
<td>single-port</td>
</tr>
<tr>
<td>XC2V_RAM16XN_D_SUBM</td>
<td>RAM16X1D</td>
<td>16 words x ( n )-bit</td>
<td>dual-port</td>
</tr>
<tr>
<td>XC2V_RAM32XN_D_SUBM</td>
<td>RAM32X1D</td>
<td>32 words x ( n )-bit</td>
<td>dual-port</td>
</tr>
<tr>
<td>XC2V_RAM64XN_D_SUBM</td>
<td>RAM64X1D</td>
<td>64 words x ( n )-bit</td>
<td>dual-port</td>
</tr>
</tbody>
</table>

By using the read/write port for the write address and the second read port for the read address, a FIFO that can read and write simultaneously is easily generated. Simultaneous access doubles the effective throughput of the memory.

VHDL and Verilog Templates

VHDL and Verilog templates are available for all single-port and dual-port primitives. The number in each template indicates the number of bits (for example, SelectRAM_16S is the template for the 16 x 1-bit RAM); S indicates single-port, and D indicates dual-port.

In VHDL, each template has a component declaration section and an architecture section. Each part of the template should be inserted within the VHDL design file. The port map of the architecture section should include the design signal names.

The following are single-port templates:
- SelectRAM_16S
- SelectRAM_32S
- SelectRAM_64S
- SelectRAM_128S

The following are dual-port templates:
- SelectRAM_16D
- SelectRAM_32D
- SelectRAM_64D

Templates for the SelectRAM_16S module are provided in VHDL and Verilog code as examples.
VHDL Template

--
-- Module: SelectRAM_16S
--
-- Description: VHDL instantiation template
-- Distributed SelectRAM
-- Single Port 16 x 1
-- can be used also for RAM16X1S_1
--
-- Device: Virtex-II Pro Family
--
---------------------------------------------------------------------
-- Components Declarations:
--
component RAM16X1S
-- pragma translate_off
generic ( 
-- RAM initialization ("0" by default) for functional simulation:
  INIT : bit_vector := X"0000"
);
-- pragma translate_on
port ( 
  D    : in std_logic;
  WE   : in std_logic;
  WCLK : in std_logic;
  A0   : in std_logic;
  A1   : in std_logic;
  A2   : in std_logic;
  A3   : in std_logic;
  O    : out std_logic
);
end component;
--
---------------------------------------------------------------------
-- Architecture section:
--
-- Attributes for RAM initialization ("0" by default):
attribute INIT: string;
--
attribute INIT of U_RAM16X1S: label is "0000";
--
-- Distributed SelectRAM Instantiation
U_RAM16X1S: RAM16X1S
port map ( 
  D      => , -- insert input signal
  WE     => , -- insert Write Enable signal
  WCLK   => , -- insert Write Clock signal
  A0     => , -- insert Address 0 signal
  A1     => , -- insert Address 1 signal
  A2     => , -- insert Address 2 signal
  A3     => , -- insert Address 3 signal
  O      =>   -- insert output signal
);
--
---------------------------------------------------------------------
Verilog Template

//
// Module: SelectRAM_16S
//
// Description: Verilog instantiation template
//   Distributed SelectRAM
//   Single Port 16 x 1
//   can be used also for RAM16X1S_1
//
// Device: Virtex-II Pro Family
//
// Syntax for Synopsys FPGA Express
// synopsys translate_off

defparam

    // RAM initialization ("0" by default) for functional simulation:
    U_RAM16X1S.INIT = 16'h0000;
    // synopsys translate_on

// Distributed SelectRAM Instantiation
RAM16X1S U_RAM16X1S (  .D(),      // insert input signal
    .WE(),     // insert Write Enable signal
    .WCLK(),   // insert Write Clock signal
    .A0(),     // insert Address 0 signal
    .A1(),     // insert Address 1 signal
    .A2(),     // insert Address 2 signal
    .A3(),     // insert Address 3 signal
    .O()       // insert output signal
);

// synthesis attribute declarations
/* synopsys attribute
    INIT "0000"
*/

---

Look-Up Tables as Shift Registers (SRLs)

Introduction

Virtex-II Pro can configure any look-up table (LUT) as a 16-bit shift register without using the flip-flops available in each slice. Shift-in operations are synchronous with the clock, and output length is dynamically selectable. A separate dedicated output allows the cascading of any number of 16-bit shift registers to create whatever size shift register is needed. Each CLB resource can be configured using the 8 LUTs as a 128-bit shift register.

This section provides generic VHDL and Verilog submodules and reference code examples for implementing from 16-bit up to 128-bit shift registers. These submodules are built from 16-bit shift-register primitives and from dedicated MUXF5, MUXF6, MUXF7, and MUXF8 multiplexers.

These shift registers enable the development of efficient designs for applications that require delay or latency compensation. Shift registers are also useful in synchronous FIFO and content-addressable memory (CAM) designs. To quickly generate a Virtex-II Pro shift
register without using flip-flops (i.e., using the SRL16 element(s)), use the CORE Generator RAM-based Shift Register module.

### Shift Register Operations

#### Data Flow

Each shift register (SRL16 primitive) supports:

- Synchronous shift-in
- Asynchronous 1-bit output when the address is changed dynamically
- Synchronous shift-out when the address is fixed

In addition, cascadable shift registers (SRLC16) support synchronous shift-out output of the last (16th) bit. This output has a dedicated connection to the input of the next SRLC16 inside the CLB resource. Two primitives are illustrated in Figure 2-55.

![Shift Register and Cascadable Shift Register](image)

**Figure 2-55:** Shift Register and Cascadable Shift Register

#### Shift Operation

The shift operation is a single clock-edge operation, with an active High clock enable feature. When enable is High, the input (D) is loaded into the first bit of the shift register, and each bit is shifted to the next highest bit position. In a cascadable shift register configuration (such as SRLC16), the last bit is shifted out on the Q15 output. The bit selected by the 4-bit address appears on the Q output.

#### Dynamic Read Operation

The Q output is determined by the 4-bit address. Each time a new address is applied to the 4-input address pins, the new bit position value is available on the Q output after the time delay to access the LUT. This operation is asynchronous and independent of the clock and clock enable signals.
Figure 2-56 illustrates the shift and dynamic read operations.

**Static Read Operation**

If the 4-bit address is fixed, the Q output always uses the same bit position. This mode implements any shift register length up to 16 bits in one LUT. Shift register length is \(N+1\) where \(N\) is the input address.

The Q output changes synchronously with each shift operation. The previous bit is shifted to the next position and appears on the Q output.

**Characteristics**

- A shift operation requires one clock edge.
- Dynamic-length read operations are asynchronous (Q output).
- Static-length read operations are synchronous (Q output).
- The data input has a setup-to-clock timing specification.
- In a cascadable configuration, the Q15 output always contains the last bit value.
- The Q15 output changes synchronously after each shift operation.

**Library Primitives and Submodules**

Eight library primitives are available that offer optional clock enable (CE), inverted clock (CLK) and cascadable output (Q15) combinations.
Table 2-19 lists all of the available primitives for synthesis and simulation.

**Table 2-19:  Shift Register Primitives**

<table>
<thead>
<tr>
<th>Primitive</th>
<th>Length</th>
<th>Control</th>
<th>Address Inputs</th>
<th>Output</th>
</tr>
</thead>
<tbody>
<tr>
<td>SRL16</td>
<td>16 bits</td>
<td>CLK</td>
<td>A3,A2,A1,A0</td>
<td>Q</td>
</tr>
<tr>
<td>SRL16E</td>
<td>16 bits</td>
<td>CLK, CE</td>
<td>A3,A2,A1,A0</td>
<td>Q</td>
</tr>
<tr>
<td>SRL16_E</td>
<td>16 bits</td>
<td>CLK</td>
<td>A3,A2,A1,A0</td>
<td>Q</td>
</tr>
<tr>
<td>SRL16E_1</td>
<td>16 bits</td>
<td>CLK, CE</td>
<td>A3,A2,A1,A0</td>
<td>Q</td>
</tr>
<tr>
<td>SRLC16</td>
<td>16 bits</td>
<td>CLK</td>
<td>A3,A2,A1,A0</td>
<td>Q, Q15</td>
</tr>
<tr>
<td>SRLC16E</td>
<td>16 bits</td>
<td>CLK, CE</td>
<td>A3,A2,A1,A0</td>
<td>Q, Q15</td>
</tr>
<tr>
<td>SRLC16_E</td>
<td>16 bits</td>
<td>CLK</td>
<td>A3,A2,A1,A0</td>
<td>Q, Q15</td>
</tr>
<tr>
<td>SRLC16E_1</td>
<td>16 bits</td>
<td>CLK, CE</td>
<td>A3,A2,A1,A0</td>
<td>Q, Q15</td>
</tr>
</tbody>
</table>

In addition to the 16-bit primitives, three submodules that implement 32-bit, 64-bit, and 128-bit cascadable shift registers are provided in VHDL and Verilog code. Table 2-20 lists available submodules.

**Table 2-20:  Shift Register Submodules**

<table>
<thead>
<tr>
<th>Submodule</th>
<th>Length</th>
<th>Control</th>
<th>Address Inputs</th>
<th>Output</th>
</tr>
</thead>
<tbody>
<tr>
<td>SRLC32E_SUBM</td>
<td>32 bits</td>
<td>CLK, CE</td>
<td>A4,A3,A2,A1,A0</td>
<td>Q, Q31</td>
</tr>
<tr>
<td>SRLC64E_SUBM</td>
<td>64 bits</td>
<td>CLK, CE</td>
<td>A5, A4, A3,A2,A1,A0</td>
<td>Q, Q63</td>
</tr>
<tr>
<td>SRLC128E_SUBM</td>
<td>128 bits</td>
<td>CLK, CE</td>
<td>A6, A5, A4, A3,A2,A1,A0</td>
<td>Q, Q127</td>
</tr>
</tbody>
</table>

The submodules are based on SRLC16E primitives, which are associated with dedicated multiplexers (MUXF5, MUXF6, and so forth). This implementation allows a fast static- and dynamic-length mode, even for very large shift registers.

Figure 2-57 represents the cascadable shift registers (32-bit and 64-bit) implemented by the submodules in Table 2-20.
Look-Up Tables as Shift Registers (SRLs)

A 128-bit shift register is built on the same scheme and uses MUXF7 (address input A6). All clock enable (CE) and clock (CLK) inputs are connected to one global clock enable and one clock signal per submodule. If a global static- or dynamic-length mode is not required, the SRLC16E primitive can be cascaded without multiplexers.

Figure 2-57: Shift-Register Submodules (32-bit, 64-bit)
Initialization in VHDL and Verilog Code

A shift register can be initialized in VHDL or Verilog code for both synthesis and simulation. For synthesis, the attribute is attached to the 16-bit shift register instantiation and is copied in the EDIF output file to be compiled by Xilinx Alliance Series tools. The VHDL code simulation uses a `generic` parameter to pass the attributes. The Verilog code simulation uses a `defparam` parameter to pass the attributes.

The V2_SRL16E shift register instantiation code examples (in VHDL and Verilog) illustrate these techniques (see "VHDL and Verilog Templates" on page 236). V2_SRL16E.vhd and .v files are not a part of the documentation.

Port Signals

Clock - CLK

Either the rising edge or the falling edge of the clock is used for the synchronous shift-in. The data and clock enable input pins have set-up times referenced to the chosen edge of CLK.

Data In - D

The data input provides new data (one bit) to be shifted into the shift register.

Clock Enable - CE (optional)

The clock enable pin affects shift functionality. An inactive clock enable pin does not shift data into the shift register and does not write new data. Activating the clock enable allows the data in (D) to be written to the first location and all data to be shifted by one location. When available, new data appears on output pins (Q) and the cascadable output pin (Q15).

Address - A0, A1, A2, A3

Address inputs select the bit (range 0 to 15) to be read. The nth bit is available on the output pin (Q). Address inputs have no effect on the cascadable output pin (Q15), which is always the last bit of the shift register (bit 15).

Data Out - Q

The data output Q provides the data value (1 bit) selected by the address inputs.

Data Out - Q15 (optional)

The data output Q15 provides the last bit value of the 16-bit shift register. New data becomes available after each shift-in operation.

Inverting Control Pins

The two control pins (CLK, CE) have an individual inversion option. The default is the rising clock edge and active High clock enable.

GSR

The global set/reset (GSR) signal has no impact on shift registers.

Attributes

Content Initialization - INIT

The INIT attribute defines the initial shift register contents. The INIT attribute is a hex-encoded bit vector with four digits (0000). The left-most hexadecimal digit is the most significant bit. By default the shift register is initialized with all zeros during the device configuration sequence, but any other configuration value can be specified.
Location Constraints

Each CLB resource has four slices: S0, S1, S2, and S3. As an example, in the bottom left CLB resource, each slice has the coordinates shown in Table 2-21.

Table 2-21:  Slice Coordinates in the Bottom-Left CLB Resource

<table>
<thead>
<tr>
<th>Slice</th>
<th>X1Y1</th>
<th>X1Y0</th>
<th>X0Y1</th>
<th>X0Y0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Slice S3</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Slice S2</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Slice S1</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Slice S0</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

To constrain placement, shift register instances can have LOC properties attached to them. Each 16-bit shift register fits in one LUT.

A 32-bit shift register in static or dynamic address mode fits in one slice (two LUTs and one MUXF5). This shift register can be placed in any slice.

A 64-bit shift register in static or dynamic address mode fits in two slices. These slices are either S0 and S1, or S2 and S3. Figure 2-58 illustrates the position of the four slices in a CLB resource.

The dedicated CLB shift chain runs from the top slice to the bottom slice. The data input pin must either be in slice S1 or in S3. The address selected as the output pin (Q) is the MUXF6 output.

A 128-bit shift register in static or dynamic address mode fits in a four-slice CLB resource. The data input pin has to be in slice S3. The address selected as the output pin (Q) is the MUXF7 output.
Fully Synchronous Shift Registers

All shift-register primitives and submodules do not use the register(s) available in the same slice(s). To implement a fully synchronous read and write shift register, output pin Q must be connected to a flip-flop. Both the shift register and the flip-flop share the same clock, as shown in Figure 2-59.

Figure 2-58: Shift Register Placement
Look-Up Tables as Shift Registers (SRLs)

This configuration provides a better timing solution and simplifies the design. Because the flip-flop must be considered to be the last register in the shift-register chain, the static or dynamic address should point to the desired length minus one. If needed, the cascadable output can also be registered in a flip-flop.

Static-Length Shift Registers

The cascadable 16-bit shift register implements any static length mode shift register without the dedicated multiplexers (MUXF5, MUXF6,...). Figure 2-60 illustrates a 40-bit shift register. Only the last SRLC16E primitive needs to have its address inputs tied to “0111”. Alternatively, shift register length can be limited to 39 bits (address tied to “0110”) and a flip-flop can be used as the last register. (In an SRLC16E primitive, the shift register length is the address input + 1.)
VHDL and Verilog Instantiation

VHDL and Verilog instantiation templates are available for all primitives and submodules. In VHDL, each template has a component declaration section and an architecture section. Each part of the template should be inserted within the VHDL design file. The port map of the architecture section should include the design signal names.

The ShiftRegister_C_x (with x = 16, 32, 64, 128, or 256) templates are cascadable modules and instantiate the corresponding SRLCxE primitive (16) or submodule (32, 64, 128, or 256).

The ShiftRegister_16 template can be used to instantiate an SRL16 primitive.

VHDL and Verilog Templates

In template names, the number indicates the number of bits (for example, SHIFT_REGISTER_16 is the template for the 16-bit shift register) and the “C” extension means the template is cascadable.

The following are templates for primitives:

- SHIFT_REGISTER_16
- SHIFT_REGISTER_16_C

The following are templates for submodules:

- SHIFT_REGISTER_32_C (submodule: SRLC32E_SUBM)
- SHIFT_REGISTER_64_C (submodule: SRLC64E_SUBM)
- SHIFT_REGISTER_128_C (submodule: SRLC128E_SUBM)

The corresponding submodules have to be synthesized with the design.

Templates for the SHIFT_REGISTER_16_C module are provided in VHDL and Verilog code as an example.

VHDL Template:

```vhdl
-- Module: SHIFT_REGISTER_C_16
-- Description: VHDL instantiation template
-- CASCADABLE 16-bit shift register with enable (SRLC16E)
-- Device: Virtex-II Pro Family
---------------------------------------------------------------------
-- Components Declarations:
--
cOMPONENT SRLC16E
-- pragma translate_off
-- generic (general)
-- Shift Register initialization ("0" by default) for functional simulation:
-- INIT : bit_vector := X"0000"
);
-- pragma translate_on
port (\n   D : in std_logic;
   CE : in std_logic;
   CLK : in std_logic;
   A0 : in std_logic;
   A1 : in std_logic;
   A2 : in std_logic;
   A3 : in std_logic;
   Q : out std_logic;
   Q15 : out std_logic
);
end component;
-- Architecture Section:
```
-- Attributes for Shift Register initialization ("0" by default):
attribute INIT: string;
--
attribute INIT of U_SRLC16E: label is "0000";
--
-- ShiftRegister Instantiation
U_SRLC16E: SRLC16E
  port map (
    D => , -- insert input signal
    CE => , -- insert Clock Enable signal (optional)
    CLK => , -- insert Clock signal
    A0 => , -- insert Address 0 signal
    A1 => , -- insert Address 1 signal
    A2 => , -- insert Address 2 signal
    A3 => , -- insert Address 3 signal
    Q => , -- insert Address 0 signal
    Q15 => -- insert cascadable output signal
  );

Verilog Template:

// Module: SHIFT_REGISTE_16
// Description: Verilog instantiation template
// Cascadable 16-bit Shift Register with Clock Enable (SRLC16E)
// Device: Virtex-II Pro Family
//-------------------------------------------------------------------
// Syntax for Synopsys FPGA Express
// synopsys translate_off
defparam

// Shift Register initialization ("0" by default) for functional simulation:
U_SRLC16E.INIT = 16'h0000;
// synopsys translate_on

// SelectShiftRegister-II Instantiation
SRLC16E U_SRLC16E ( .D(),
    , .A0(),
    , .A1(),
    , .A2(),
    , .A3(),
    , .CLK(),
    , .CE(),
    , .Q(),
    , .Q15()
);

// synthesis attribute declarations
/* synopsys attribute
INIT "0000"
*/

Large Multiplexers

Introduction

Virtex-II Pro slices contain dedicated two-input multiplexers (one MUXF5 and one
MUXFX per slice). These multiplexers combine the 4-input LUT outputs or the outputs of
other multiplexers. Using the multiplexers MUXF5, MUXF6, MUXF7 and MUXF8 allows to combine 2, 4, 8 and 16 LUTs. Specific routing resources are associated with these 2-input multiplexers to guarantee a fast implementation of any combinatorial function built upon LUTs and MUXFX.

The combination of the LUTs and the MUXFX offers an unique solution to the design of wide-input functions. This section illustrates the implementation of large multiplexers up to 32:1. Any Virtex-II Pro slice can implement a 4:1 multiplexer, any CLB can implement a 16:1 multiplexer, and 2 CLBs can implement a 32:1 multiplexer. Such multiplexers are just one example of wide-input combinatorial function taking advantage of the MUXFX feature. Many other logic functions can be mapped in the LUT and MUXFX features.

This section provides generic VHDL and Verilog reference code implementing multiplexers. These submodules are built from LUTs and the dedicated MUXF5, MUXF6, MUXF7, and MUXF8 multiplexers. To automatically generate large multiplexers using these dedicated elements, use the CORE Generator Bit Multiplexer and Bus Multiplexer modules.

For applications like comparators, encoder-decoders or “case” statement in VHDL or Verilog, these resources offer an optimal solution.

**Virtex-II Pro CLB Resources**

**Slice Multiplexers**

Each Virtex-II Pro slice has a MUXF5 to combine the outputs of the 2 LUTs and an extra MUXFX. Figure 2-61 illustrates a combinatorial function with up to 9 inputs in one slice.

![Figure 2-61: LUTs and MUXF5 in a Slice](image)

Each Virtex-II Pro CLB contains 4 slices. The second MUXFX implements a MUXF6, MUXF7 or MUXF8 according to the position of the slice in the CLB. These MUXFX are designed to allow LUTs combination up to 16 LUTs in two adjacent CLBs.
Figure 2-62 shows the relative position of the slices in the CLB.

Figure 2-62: Slice Positions in a CLB

Slices S0 and S2 have a MUXF6, designed to combine the outputs of two MUXF5 resources. Figure 2-63 illustrates a combinatorial function up to 18 inputs in the slices S0 and S1, or in the slices S2 and S3.

Figure 2-63: LUTs and (MUXF5 and MUXF6) in Two Slices
The slice S1 has a MUXF7, designed to combine the outputs of two MUXF6. Figure 2-64 illustrates a combinatorial function up to 35 inputs in a Virtex-II Pro CLB.

Figure 2-64: LUTs and (MUXF5, MUXF6, and MUXF7) in One CLB
The slice S3 of each CLB has a MUXF8. Combinatorial functions of up to 68 inputs fit in two CLBs as shown in Figure 2-65. The outputs of two MUXF7 are combined through dedicated routing resources between two adjacent CLBs in a column.

**Figure 2-65:** MUXF8 Combining Two Adjacent CLBs
Wide-Input Multiplexers

Each LUT can implement a 2:1 multiplexer. In each slice, the MUXF5 and two LUTs can implement a 4:1 multiplexer. As shown in Figure 2-66, the MUXF6 and two slices can implement a 8:1 multiplexer. The MUXF7 and the four slices of any CLB can implement a 16:1 and the MUXF8 and two CLBs can implement a 32:1 multiplexer.

**Characteristics**

- Implementation in one level of logic (LUT) and dedicated MUXFX
- Full combinatorial path

*Figure 2-66: 8:1 and 16:1 Multiplexers*
Library Primitives and Submodules

Four library primitives are available that offer access to the dedicated MUXFX in each slice. In the example shown in Table 2-22, MUXF7 is available only in slice S1.

Table 2-22: MUXFX Resources

<table>
<thead>
<tr>
<th>Primitive</th>
<th>Slice</th>
<th>Control</th>
<th>Input</th>
<th>Output</th>
</tr>
</thead>
<tbody>
<tr>
<td>MUXF5</td>
<td>S0, S1, S2, S3</td>
<td>S</td>
<td>I0, I1</td>
<td>O</td>
</tr>
<tr>
<td>MUXF6</td>
<td>S0, S2</td>
<td>S</td>
<td>I0, I1</td>
<td>O</td>
</tr>
<tr>
<td>MUXF7</td>
<td>S1</td>
<td>S</td>
<td>I0, I1</td>
<td>O</td>
</tr>
<tr>
<td>MUXF8</td>
<td>S3</td>
<td>S</td>
<td>I0, I1</td>
<td>O</td>
</tr>
</tbody>
</table>

In addition to the primitives, five submodules that implement multiplexers from 2:1 to 32:1 are provided in VHDL and Verilog code. Synthesis tools can automatically infer the above primitives (MUXF5, MUXF6, MUXF7, and MUXF8); however, the submodules described in this section used instantiation of the new MUXFX to guarantee an optimized result. Table 2-23 lists available submodules:

Table 2-23: Available Submodules

<table>
<thead>
<tr>
<th>Submodule</th>
<th>Multiplexer</th>
<th>Control</th>
<th>Input</th>
<th>Output</th>
</tr>
</thead>
<tbody>
<tr>
<td>MUX_2_1_SUBM</td>
<td>2:1</td>
<td>SELECT_I</td>
<td>DATA_I[1:0]</td>
<td>DATA_O</td>
</tr>
<tr>
<td>MUX_4_1_SUBM</td>
<td>4:1</td>
<td>SELECT_I[1:0]</td>
<td>DATA_I[3:0]</td>
<td>DATA_O</td>
</tr>
<tr>
<td>MUX_8_1_SUBM</td>
<td>8:1</td>
<td>SELECT_I[2:0]</td>
<td>DATA_I[8:0]</td>
<td>DATA_O</td>
</tr>
<tr>
<td>MUX_16_1_SUBM</td>
<td>16:1</td>
<td>SELECT_I[3:0]</td>
<td>DATA_I[15:0]</td>
<td>DATA_O</td>
</tr>
<tr>
<td>MUX_32_1_SUBM</td>
<td>32:1</td>
<td>SELECT_I[4:0]</td>
<td>DATA_I[31:0]</td>
<td>DATA_O</td>
</tr>
</tbody>
</table>

Port Signals

Data In - DATA_I

The data input provides the data to be selected by the SELECT_I signal(s).

Control In - SELECT_I

The select input signal or bus determines the DATA_I signal to be connected to the output DATA_O. For example, the MUX_4_1_SUBM multiplexer has a 2-bit SELECT_I bus and a 4-bit DATA_I bus. Table 2-24 shows the DATA_I selected for each SELECT_I value.

Table 2-24: Selected Inputs

<table>
<thead>
<tr>
<th>SELECT_I[1:0]</th>
<th>DATA_O</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 0</td>
<td>DATA_I[0]</td>
</tr>
<tr>
<td>0 1</td>
<td>DATA_I[1]</td>
</tr>
<tr>
<td>1 0</td>
<td>DATA_I[2]</td>
</tr>
<tr>
<td>1 1</td>
<td>DATA_I[3]</td>
</tr>
</tbody>
</table>

Data Out - DATA_O

The data output O provides the data value (1 bit) selected by the control inputs.
Applications

Multiplexers are used in various applications. These are often inferred by synthesis tools when a “case” statement is used (see the example below). Comparators, encoder-decoders and wide-input combinatorial functions are optimized when they are based on one level of LUTs and dedicated MUXFX resources of the Virtex-II Pro CLBs.

VHDL and Verilog Instantiation

The primitives (MUXF5, MUXF6, and so forth) can be instantiated in VHDL or Verilog code, to design wide-input functions.

The submodules (MUX_2_1_SUBM, MUX_4_1_SUBM, and so forth) can be instantiated in VHDL or Verilog code to implement multiplexers. However the corresponding submodule must be added to the design directory as hierarchical submodule. For example, if a module is using the MUX_16_1_SUBM, the MUX_16_1_SUBM.vhd file (VHDL code) or MUX_16_1_SUBM.v file (Verilog code) must be compiled with the design source code. The submodule code can also be “cut and pasted” into the designer source code.

VHDL and Verilog Submodules

VHDL and Verilog submodules are available to implement multiplexers up to 32:1. They illustrate how to design with the MUXFX resources. When synthesis infers the corresponding MUXFX resource(s), the VHDL or Verilog code is behavioral code (“case” statement). Otherwise, the equivalent “case” statement is provided in comments and the correct MUXFX are instantiated. However, most synthesis tools support the inference of all of the MUXFX. The following examples can be used as guidelines for designing other wide-input functions.

The following submodules are available:

- MUX_2_1_SUBM (behavioral code)
- MUX_4_1_SUBM
- MUX_8_1_SUBM
- MUX_16_1_SUBM
- MUX_32_1_SUBM

The corresponding submodules have to be synthesized with the design.

The submodule MUX_16_1_SUBM in VHDL and Verilog are provided as example.

VHDL Template

```vhdl
-- Module: MUX_16_1_SUBM
-- Description: Multiplexer 16:1
--
-- Device: Virtex-II Pro Family
---------------------------------
library IEEE;
use IEEE.std_logic_1164.all;

-- Syntax for Synopsys FPGA Express
pragma translate_off
library UNISIM;
use UNISIM.VCOMPONENTS.ALL;
pragma translate_on

entity MUX_16_1_SUBM is
  port (
    DATA_I: in std_logic_vector (15 downto 0);
    SELECT_I: in std_logic_vector (3 downto 0);
    DATA_O: out std_logic
  );
end MUX_16_1_SUBM;
```
Large Multiplexers

architecture MUX_16_1_SUBM_arch of MUX_16_1_SUBM is
-- Component Declarations:
component MUXF7
    port (
        I0: in std_logic;
        I1: in std_logic;
        S: in std_logic;
        O: out std_logic
    );
end component;
-- Signal Declarations:
signal DATA_MSB : std_logic;
signal DATA_LSB : std_logic;
-- begin
-- If synthesis tools support MUXF7 :
--SELECT_PROCESS: process (SELECT_I, DATA_I)
--begin
--case SELECT_I is
-- when "0000" => DATA_O <= DATA_I (0);
-- when "0001" => DATA_O <= DATA_I (1);
-- when "0010" => DATA_O <= DATA_I (2);
-- when "0011" => DATA_O <= DATA_I (3);
-- when "0100" => DATA_O <= DATA_I (4);
-- when "0101" => DATA_O <= DATA_I (5);
-- when "0110" => DATA_O <= DATA_I (6);
-- when "0111" => DATA_O <= DATA_I (7);
-- when "1000" => DATA_O <= DATA_I (8);
-- when "1001" => DATA_O <= DATA_I (9);
-- when "1010" => DATA_O <= DATA_I (10);
-- when "1011" => DATA_O <= DATA_I (11);
-- when "1100" => DATA_O <= DATA_I (12);
-- when "1101" => DATA_O <= DATA_I (13);
-- when "1110" => DATA_O <= DATA_I (14);
-- when "1111" => DATA_O <= DATA_I (15);
-- when others => DATA_O <= 'X';
end case;
--end process SELECT_PROCESS;
--
-- If synthesis tools DO NOT support MUXF7 :
SELECT_PROCESS_LSB: process (SELECT_I, DATA_I)
begin
    case SELECT_I (2 downto 0) is
        when "000" => DATA_LSB <= DATA_I (0);
        when "001" => DATA_LSB <= DATA_I (1);
        when "010" => DATA_LSB <= DATA_I (2);
        when "011" => DATA_LSB <= DATA_I (3);
        when "100" => DATA_LSB <= DATA_I (4);
        when "101" => DATA_LSB <= DATA_I (5);
        when "110" => DATA_LSB <= DATA_I (6);
        when "111" => DATA_LSB <= DATA_I (7);
        when others => DATA_LSB <= 'X';
    end case;
end process SELECT_PROCESS_LSB;
--
SELECT_PROCESS_MSB: process (SELECT_I, DATA_I)
begin
    case SELECT_I (2 downto 0) is
        when "000" => DATA_MSB <= DATA_I (0);
        when "001" => DATA_MSB <= DATA_I (1);
        when "010" => DATA_MSB <= DATA_I (2);
        when "011" => DATA_MSB <= DATA_I (3);
        when "100" => DATA_MSB <= DATA_I (4);
        when "101" => DATA_MSB <= DATA_I (5);
        when "110" => DATA_MSB <= DATA_I (6);
        when "111" => DATA_MSB <= DATA_I (7);
        when others => DATA_MSB <= 'X';
    end case;
end process SELECT_PROCESS_MSB;
--
when "000" => DATA_MSB <= DATA_I (8);
when "001" => DATA_MSB <= DATA_I (9);
when "010" => DATA_MSB <= DATA_I (10);
when "011" => DATA_MSB <= DATA_I (11);
when "100" => DATA_MSB <= DATA_I (12);
when "101" => DATA_MSB <= DATA_I (13);
when "110" => DATA_MSB <= DATA_I (14);
when "111" => DATA_MSB <= DATA_I (15);
when others => DATA_MSB <= 'X';
end case;
end process SELECT_PROCESS_MSB;
--
-- MUXF7 instantiation
U_MUXF7: MUXF7
  port map (
    I0 => DATA_LSB,
    I1 => DATA_MSB,
    S  => SELECT_I (3),
    O  => DATA_O
  );
--
end MUX_16_1_SUBM_arch;
--

Verilog Template

// Module: MUX_16_1_SUBM
//
// Description: Multiplexer 16:1
// Device: Virtex-II Pro Family
//--------------------------------------------------------------------
//
module MUX_16_1_SUBM (DATA_I, SELECT_I, DATA_O);

input [15:0]DATA_I;
input [3:0]SELECT_I;
output DATA_O;
wire [2:0]SELECT;
reg DATA_LSB;
reg DATA_MSB;

assign SELECT[2:0] = SELECT_I[2:0];

/*
// If synthesis tools supports MUXF7 :
always @ (DATA_I or SELECT_I)
  case (SELECT_I)
    4'b0000 : DATA_O <= DATA_I[0];
    4'b0001 : DATA_O <= DATA_I[1];
    4'b0010 : DATA_O <= DATA_I[2];
    4'b0011 : DATA_O <= DATA_I[3];
    4'b0100 : DATA_O <= DATA_I[4];
    4'b0101 : DATA_O <= DATA_I[5];
    4'b0110 : DATA_O <= DATA_I[6];
    4'b0111 : DATA_O <= DATA_I[7];
    4'b1000 : DATA_O <= DATA_I[8];
    4'b1001 : DATA_O <= DATA_I[9];
    4'b1010 : DATA_O <= DATA_I[10];
    4'b1011 : DATA_O <= DATA_I[11];
  endcase;
end process SELECT_PROCESS_MSB;
### Sum of Products (SOP) Logic

#### Introduction

Virtex-II Pro slices contain a dedicated two-input multiplexer (MUXCY) and a two-input OR gate (ORCY) to perform operations involving wide AND and OR gates. These combine the four-input LUT outputs. These gates can be cascaded in a chain to provide the wide AND functionality across slices. The output from the cascaded AND gates can then be combined with the dedicated ORCY to produce the Sum of Products (SOP).
Virtex-II Pro CLB Resources

Each Virtex-II Pro slice has a MUXCY, which uses the output from the LUTs as a SELECT signal. Depending on the width of data desired, several slices can be used to provide the SOP output. Figure 2-67 illustrates the logic involved in designing a 16-input AND gate. It utilizes the 4-input LUT to provide the necessary SELECT signal for the MUXCY. Only when all of the input signals are High, can the $V_{CC}$ at the bottom reach the output. This use of carry logic helps to perform AND functions at high speed and saves logic resources.

![Figure 2-67: Implementing a 16-bit Wide AND Gate Using MUXCY & ORCY](image)

The output from the chain of AND gates is passed as one of the inputs of the dedicated OR gate, ORCY. To calculate the SOP, these AND chains can be cascaded vertically across several CLBs, depending on the width of the input data. Figure 2-68 illustrates how the AND outputs are then passed in through the ORCY gates in a horizontal cascade, the sum of which is the Sum of Products.
VHDL Parameters

**AND_WIDTH Parameter**

The width of each AND gate used in the cascade.

**PROD_TERM Parameter**

The number of AND gates used along each vertical cascade.

**AND_IN Parameter**

Data input to the AND gates. The total width of data is calculated from the product of AND_WIDTH and PROD_TERM.

**SOP_OUT Parameter**

The Sum of Products (SOP) output data from the cascade chain.

Applications

These logic gates can be used in various applications involving very wide AND gates and Sum of Products (SOP) functions.
### VHDL and Verilog Instantiation

To implement wide-input AND functions, MUXCY and ORCY primitives can be instantiated in VHDL or Verilog code. The submodule code provided can be used to implement wide-input AND gates for any width of input data.

#### VHDL and Verilog Submodules

VHDL and Verilog submodules are available to implement the cascade chain of wide-input AND gates and OR gates to calculate the Sum of Products (SOP). The VHDL module provided uses a generic case, where the width of data and the product terms can be specified in the case. The Verilog module provides a 64-bit input example, using four wide AND chains, each of which handle 16 bits of data.

#### VHDL Templates

```vhdl
-- Module : AND_CHAIN
-- Description : 16 input AND gate
--
-- Device : Virtex-II Pro Family
---------------------------------------------------------------------
library IEEE;
use IEEE.std_logic_1164.all;
--library UNISIM;
--use UNISIM.VCOMPONENTS.ALL;

entity AND_CHAIN is
    generic ( 
        input_width : integer); --must be a 4x value
    port ( 
        data_in : in std_logic_vector( input_width-1 downto 0);
        carry_in : in std_logic;
        out_andor_chain : out std_logic);
end AND_CHAIN;

architecture AND_CHAIN_arch of AND_CHAIN is

component ORCY
    port( i : std_logic;
        ci : in std_logic;
        o : out std_logic);
end component;

component AND_LOGIC
    port( sel_data : in std_logic_vector(3 downto 0);
        data_cin : in std_logic;
        data_out : out std_logic);
end component;

signal VCC, GND : std_logic;
signal cout : std_logic_vector(input_width/4 downto 0);
signal out_and_chain : std_logic;

begin

    VCC <= '1';
    GND <= '0';

    --initialization of first input for MUXCY
    cout(0) <= VCC;

    and_chain_x : for i in (input_width/4) - 1 downto 0 generate
```
AND_LOGIC_inst : AND_LOGIC
  port map (  
    sel_data => data_in((4 * i + 3) downto (4 * i)),
    data_cin => cout(i),
    data_out => cout(i + 1));
end generate;

out_and_chain <= cout(input_width/4);

orcy_inst : ORCY
  port map(  
    i => out_and_chain,
    ci => carry_in,
    o => out_andor_chain);
end AND_CHAIN_arch;

-- Module AND_LOGIC
-- Description : 4-input AND gate
-- Device : Virtex-II Pro Family
---------------------------------------------------------------------
library IEEE;
use IEEE.std_logic_1164.all;
--library UNISIM;
--use UNISIM.VCOMPONENTS.ALL;

entity AND_LOGIC is  
  port(  
    sel_data : in std_logic_vector(3 downto 0); -- data for select  
    signal for MUXCY from LUT  
    data_cin : in std_logic;  -- result from previous stage  
    data_out : out std_logic);
end AND_LOGIC;

architecture AND_LOGIC_arch of AND_LOGIC is

component MUXCY
  port(
    DI : in std_logic;
    CI : in std_logic;
    s : in std_logic;
    o : out std_logic);
end component;

signal GND : std_logic;
signal sel:std_logic;

begin

GND <= '0';
  sel <= sel_data(0) and sel_data(1) and sel_data(2) and sel_data(3);

--Wide AND gate using MUXCY
MUX : MUXCY
  port map (  
    DI => GND,
    CI => data_cin,
    s => sel,
    o => data_out);
end AND_LOGIC_arch;
-- Module : SOP_SUBM
-- Description : Implementing SOP using MUXCY and ORCY
--
-- Device : Virtex-II Pro Family
---------------------------------------------------------------------
library ieee;
use ieee.std_logic_1164.all;
--library UNISIM;
--use UNISIM.VCOMPONENTS.ALL;

entity SOP_SUBM is
  generic(
    and_width : integer :=16 ;
    prod_term : integer := 4 );
  port(
    and_in : in std_logic_vector(and_width * prod_term - 1 downto 0);
    sop_out : out std_logic);
end SOP_SUBM;

architecture SOP_SUBM_arch of SOP_SUBM is

  component AND_CHAIN
  generic ( 
    input_width : integer); --must be a 4x value 
  port ( 
    data_in : in std_logic_vector( input_width-1 downto 0);
    carry_in : in std_logic;
    out_andor_chain : out std_logic);
  end component;

  signal VCC, GND : std_logic;
  signal carry : std_logic_vector(prod_term downto 0);

  begin

    VCC <= '1';
    GND <= '0';

    carry(0) <= GND;

    andor_inst : for i in 0 to (prod_term - 1) generate
      and_chainx : AND_CHAIN
      generic map( 
        input_width => and_width)
      port map( 
        data_in => and_in((and_width * i + (and_width -1)) downto (and_width * i)),
        carry_in => carry(i),
        out_andor_chain => carry(i + 1));
    end generate;

    sop_out <= carry(prod_term);
  end SOP_SUBM_arch;
Verilog Templates

// Module : AND_CHAIN
// Description : 16 input AND gate
//
// Device : Virtex-II Family
//---------------------------------------------------------------
module AND_CHAIN(data_in, carry_in, out_andor_chain);
input [15:0] data_in;
input carry_in;
output out_andor_chain;
wire VCC = 1'b1;
wire out_and_chain;
wire dat_out1, dat_out2, dat_out3;
AND_LOGIC_OR u4(.sel_data(data_in[15:12]), .data_cin(data_out3),
    .carry_in(carry_in), .data_out(out_andor_chain));

AND_LOGIC u3(.sel_data(data_in[11:8]), .data_cin(data_out2),
    .data_out(data_out3));
AND_LOGIC u2(.sel_data(data_in[7:4]), .data_cin(data_out1),
    .data_out(data_out2));
AND_LOGIC u1(.sel_data(data_in[3:0]), .data_cin(VCC),
    .data_out(data_out1));
endmodule

//---------------------------------------------------------------
// Module AND_LOGIC
// Description : 4-input AND gate
//
// Device : Virtex-II Family
//---------------------------------------------------------------
// Module : init_and
//
module AND_LOGIC(sel_data, data_cin, data_out);
input[3:0] sel_data;
input data_cin;
output data_out;
wire GND = 1'b0;
wire VCC = 1'b1;
wire and_out;
MUXCY muxcy_inst (.DI(GND), .CI(data_cin), .S(and_out), .O(data_out));
endmodule

// Module AND_LOGIC + ORCY
module AND_LOGIC_OR(sel_data, data_cin, carry_in, data_out);
input[3:0] sel_data;
input data_cin;
input carry_in;
output data_out;
wire data_mux_out;
wire GND = 1'b0;
wire VCC = 1'b1;
wire and_out;
MUXCY muxcy_inst (.DI(GND), .CI(data_cin), .S(and_out), .O(data_out));
ORCY u5(.I(carry_in), .CI(data_mux_out), .O(data_out)) */ synthesis
RLOC="x0y0" */;
endmodule
Embedded Multipliers

Introduction

Virtex-II Pro devices feature a large number of embedded 18-bit X 18-bit two’s-complement embedded multipliers. The embedded multipliers offer fast, efficient means to create 18-bit signed by 18-bit signed multiplication products. The multiplier blocks share routing resources with the Block SelectRAM memory, allowing for increased efficiency for many applications. Cascading of multipliers can be implemented with additional logic resources in local Virtex-II Pro slices.

Applications such as signed-signed, signed-unsigned, and unsigned-unsigned multiplication, logical, arithmetic, and barrel shifters, two’s-complement and magnitude return are easily implemented.

Using the CORE Generator, the designer can quickly generate multipliers that make use of the embedded 18-bit x 18-bit two’s-complement multipliers (V2.0 or later) of the Multiplier core for Virtex-II Pro devices.

Two’s-Complement Signed Multiplier

Data Flow

Each embedded multiplier block (MULT18X18 primitive) supports two independent dynamic data input ports: 18-bit signed or 17-bit unsigned. The MULT18X18 primitive is illustrated in Figure 2-69.
In addition, efficient cascading of multipliers up to 35-bit X 35-bit signed can be accomplished by using 4 embedded multipliers, one 36-bit adder, and one 53-bit adder. See Figure 2-70.

![Embedded Multiplier](UG002_C2_005_082100)

**Figure 2-69**: Embedded Multiplier

**Library Primitives and Submodules**

One library primitive (MULT18X18) is available. **Table 2-25** lists the attributes of this primitive.

**Table 2-25**: Embedded Multiplier Primitive

<table>
<thead>
<tr>
<th>Primitive</th>
<th>A width</th>
<th>B width</th>
<th>P width</th>
<th>Signed/Unsigned</th>
</tr>
</thead>
<tbody>
<tr>
<td>MULT18X18</td>
<td>18</td>
<td>18</td>
<td>36</td>
<td>Signed (2’s complement)</td>
</tr>
</tbody>
</table>
In addition to the primitive, 15 submodules that implement various widths of signed and unsigned multipliers and two's-complement return functions are provided in VHDL and Verilog code. Multipliers using cascaded MULT18X18 primitives are included with registers between stages causing three cycles of latency. Multipliers that make use of the embedded Virtex-II Pro 18-bit by 18-bit two's complement multipliers can be easily generated using V2.0 of the CORE Generator Multiplier module. Table 2-26 lists cascaded multiplier submodules.

Table 2-26: Embedded Multiplier Submodules - Cascaded MULT18X18

<table>
<thead>
<tr>
<th>Submodule</th>
<th>A Width</th>
<th>B Width</th>
<th>P Width</th>
<th>Signed/Unsigned</th>
</tr>
</thead>
<tbody>
<tr>
<td>MULT35X35_S</td>
<td>35</td>
<td>35</td>
<td>70</td>
<td>Signed</td>
</tr>
<tr>
<td>MULT34X34_U</td>
<td>34</td>
<td>34</td>
<td>68</td>
<td>Unsigned</td>
</tr>
</tbody>
</table>

Figure 2-70 represents the cascaded scheme used to implement a 35-bit by 35-bit signed multiplier utilizing four embedded multipliers and two adders.

Figure 2-70: MULT35X35_S Submodule

The fixed adder is 53 bits wide (17 LSBs are always 0 on one input).
The 34-bit by 34-bit unsigned submodule is constructed in a similar manner with the most significant bit on each operand being tied to logic low.

Table 2-26 lists multipliers and two's-complement return functions that utilize one MULT18X18 primitive and are not registered.
Embedded Multipliers

### Table 2-27: Embedded Multiplier Submodules - Single MULT18X18

<table>
<thead>
<tr>
<th>Submodule</th>
<th>A width</th>
<th>B width</th>
<th>P width</th>
<th>Signed/Unsigned</th>
</tr>
</thead>
<tbody>
<tr>
<td>MULT17X17_U</td>
<td>17</td>
<td>17</td>
<td>34</td>
<td>Unsigned</td>
</tr>
<tr>
<td>MULT8X8_S</td>
<td>8</td>
<td>8</td>
<td>16</td>
<td>Signed</td>
</tr>
<tr>
<td>MULT8X8_U</td>
<td>8</td>
<td>8</td>
<td>16</td>
<td>Unsigned</td>
</tr>
<tr>
<td>MULT4X4_S</td>
<td>4</td>
<td>4</td>
<td>8</td>
<td>Signed</td>
</tr>
<tr>
<td>MULT4X4_U</td>
<td>4</td>
<td>4</td>
<td>8</td>
<td>Unsigned</td>
</tr>
<tr>
<td>MULT_6X6S_5X5U</td>
<td>6 5</td>
<td>6 5</td>
<td>12 10</td>
<td>Signed/Unsigned</td>
</tr>
<tr>
<td>MULT_5X5S_6X6U</td>
<td>6 5</td>
<td>6 6</td>
<td>10 12</td>
<td>Signed/Unsigned</td>
</tr>
<tr>
<td>MULT_5X5U_5X5U</td>
<td>5 5</td>
<td>5 5</td>
<td>10 10</td>
<td>Unsigned</td>
</tr>
<tr>
<td>MULT_4X4S_7X7U</td>
<td>4 7</td>
<td>4 7</td>
<td>8 14</td>
<td>Signed/Unsigned</td>
</tr>
<tr>
<td>MULT_4X4S_3X3S</td>
<td>4 3</td>
<td>4 3</td>
<td>8 6</td>
<td>Signed/Signed</td>
</tr>
<tr>
<td>TWOS_CMP18</td>
<td>18</td>
<td>-</td>
<td>18</td>
<td>-</td>
</tr>
<tr>
<td>TWOS_CMP9</td>
<td>9</td>
<td>-</td>
<td>9</td>
<td>-</td>
</tr>
<tr>
<td>MAGNTO_18</td>
<td>18</td>
<td>-</td>
<td>17</td>
<td>-</td>
</tr>
</tbody>
</table>

Multipliers of form MULT_aXaS_bXbU use one embedded multiplier to implement two multipliers with separate outputs. The submodules listed above use optimized pin assignments to achieve shortest possible through-delay.

Figure 2-71 and Figure 2-72 represent 4-bit by 4-bit signed multiplier and 4-bit by 4-bit unsigned multiplier implementations, respectively.

![Figure 2-71: MULT4X4_S Submodule](UG002_C2_002_03001)
Submodule MAGNTD_18 performs a magnitude return (i.e., absolute value) of a two’s-complement number. An incoming negative number returns with a positive number, while an incoming positive number remains unchanged. Submodules TWOS_CMP18 and TWOS_CMP perform a two’s-complement return function. The incoming number in two’s-complement form (either signed or unsigned) is complemented when the DO_COMP pin is asserted High. Additional slice logic can be used with these submodules to efficiently convert sign-magnitude to two’s-complement or vice-versa. Figure 2-73 shows the connections to a MULT18X18 to create the submodule TWOS_CMP9.

Two Multipliers in a Single Primitive

Two multipliers can be implemented in a single primitive. For simplified illustration purposes, an assumption of two squares being implemented in the same MULT18X18 primitive is used. The following equation shows the form of the multiplication.

**Two Multipliers per Primitive:**

\[(X \times 2^n + Y)(X \times 2^n + Y) = (X^2 \times 2^{2n}) + (Y^2) + (XY \times 2^{n+1})\]

\((X \times 2^n)\) is the input \(X\) appearing on the MSBs while \(Y\) appears on the LSBS to form the value \((X \times 2^n + Y)\). Two multipliers can coexist in one MULT18X18 primitive, if the conditions in the following inequalities are met when neither \(X\) nor \(Y\) are 0.
Inequality Conditions for Two Multipliers per Primitive:

\[(X^2 \cdot 2^{2n})_{\text{min}} > (XY \cdot 2^{n+1})_{\text{max}}, (XY \cdot 2^{n+1})_{\text{min}} > (Y^2)_{\text{max}}\]

For values 0 on X or Y, the equation becomes:

\[X^2 \cdot 2^{2n} \quad |Y=0|\]

\[Y^2 \quad |X=0|\]

\[0 \quad |X=0, Y=0|\]

Figure 2-74 represents the MULT_6X6S_5X5U submodule.

![Figure 2-74](image_url)

Table 2-28 shows values for X and Y where these conditions are met.

**Table 2-28: Two Multipliers per MULT18X18 Allowable Sizes**

<table>
<thead>
<tr>
<th>X * X</th>
<th>Y * Y</th>
</tr>
</thead>
<tbody>
<tr>
<td>Signed Size</td>
<td>Unsigned Size</td>
</tr>
<tr>
<td>7 X 7</td>
<td>6 X 6</td>
</tr>
<tr>
<td>6 X 6</td>
<td>5 X 5</td>
</tr>
<tr>
<td>5 X 5</td>
<td>4 X 4</td>
</tr>
<tr>
<td>4 X 4</td>
<td>3 X 3</td>
</tr>
<tr>
<td>3 X 3</td>
<td>2 X 2</td>
</tr>
</tbody>
</table>

**VHDL and Verilog Instantiation**

VHDL and Verilog instantiation templates are available as examples of primitives and submodules (see VHDL and Verilog Templates, page 260).

In VHDL, each template has a component declaration section and an architecture section. Each part of the template should be inserted within the VHDL design file. The port map of the architecture section should include the design signals names.

**Port Signals**

**Data In - A**

The data input provides new data (up to 18 bits) to be used as one of the multiplication operands.

**Data In - B**

The data input provides new data (up to 18 bits) to be used as one of the multiplication operands.
Data Out - P

The data output bus P provides the data value (up to 36 bits) of two’s-complement multiplication for operands A and B.

Location Constraints

Each embedded multiplier has location coordinates of the form XrowYcolumn. To constrain placement, multiplier instances can have LOC properties attached to
MULT18X18 embedded multiplier instances can have LOC properties attached to them to constrain placement. MULT18X18 placement locations differ from the convention used for naming CLB locations, allowing LOC properties to transfer easily from array to array.
The LOC properties use the following form:

LOC = MULT18X18_X#Y#

For example, MULT18X18_X0Y0 is the bottom-left MULT18X18 location on the device.

VHDL and Verilog Templates

VHDL and Verilog templates are available for the primitive and submodules.
The following is a template for the primitive:

• SIGNED_MULT_18X18 (primitive: MULT18X18)
The following are templates for submodules:

• SIGNED_MULT_35X35 (submodule: MULT35X35_S)
• UNSIGNED_MULT_34X34 (submodule: MULT34X34_U)
• UNSIGNED_MULT_17X17 (submodule: MULT17X17_U)
• SIGNED_MULT_8X8 (submodule: MULT8X8_S)
• UNSIGNED_MULT_8X8 (submodule: MULT8X8_U)
• SIGNED_MULT_4X4 (submodule: MULT4X4_S)
• UNSIGNED_MULT_4X4 (submodule: MULT4X4_U)
• DUAL_MULT_6X6S_5X5U (submodule: MULT_6x6S_5x5U)
• DUAL_MULT_5X5S_6X6U (submodule: MULT_5x5S_6x6U)
• DUAL_MULT_5X5U_5X5U (submodule: MULT_5x5U_5x5U)
• DUAL_MULT_4X4S_7X7U (submodule: MULT_4x4S_7x7U)
• DUAL_MULT_4X4S_3X3S (submodule: MULT_4x4S_3x3S)
• TWOS_COMPLEMENTER_18BIT (submodule: TWOS_CMP18)
• TWOS_COMPLEMENTER_9BIT (submodule: TWOS_CMP9)
• MAGNITUDE_18BIT (submodule: MAGNTD_18)
The corresponding submodules have to be synthesized with the design.
Templates for the SIGNED_MULT_18X18 module are provided in VHDL and Verilog code as an example.
VHDL Template:

-- Module: SIGNED_MULT_18X18
-- Description: VHDL instantiation template
-- 18-bit X 18-bit embedded signed multiplier (asynchronous)
--
-- Device: Virtex-II Pro Family
---------------------------------------------------------------------
-- Components Declarations
component MULT18X18
  port(
      A : in std_logic_vector (17 downto 0);
      B : in std_logic_vector (17 downto 0);
      P : out std_logic_vector (35 downto 0)
  );
end component;
--
-- Architecture Section
--
U_MULT18X18 : MULT18X18
  port map (A => , -- insert input signal #1
            B => , -- insert input signal #2
            P =>   -- insert output signal
        );

Verilog Template:

// Module: SIGNED_MULT_18X18
// Description: Verilog instantiation template
// 18-bit X 18-bit embedded signed multiplier (asynchronous)
//
// Device: Virtex-II Pro Family
//-------------------------------------------------------------------
// Instantiation Section
//
MULT18X18 U_MULT18X18
  (.
    .A () , // insert input signal #1
    .B () , // insert input signal #2
    .P ()   // insert output signal
  );

Single-Ended SelectIO™-Ultra Resources

Summary

The Virtex-II Pro FPGA Series includes a highly configurable, high-performance single-ended SelectIO-Ultra resource that supports a wide variety of I/O standards. The SelectIO-Ultra resource includes a robust set of features, including programmable control of output drive strength, slew rate, and input delay and hold time. Taking advantage of the flexibility of SelectIO-Ultra features and the design considerations described in this document can improve and simplify system-level design.

Introduction

As FPGAs continue to grow in size and capacity, the larger and more complex systems designed for them demand an increased variety of I/O standards. Furthermore, as system clock speeds continue to increase, the need for high-performance I/O becomes more
important. Chip-to-chip delays have an increasingly substantial impact on overall system speed. The task of achieving the desired system performance is becoming more difficult with the proliferation of low-voltage I/O standards. SelectIO-Ultra resolves this potential problem by providing a highly configurable, high-performance alternative to I/O resources used in more conventional programmable devices.

Virtex-II Pro SelectIO-Ultra blocks can support up to 19 single-ended I/O standards. Supporting such a variety of I/O standards allows support for a wide variety of applications.

Each Input/Output Block (IOB) includes six registers, two each from the input, output, and 3-state signals within the IOB. These registers are optionally configured as either a D-type flip-flop or as a level-sensitive latch. The purpose of having six registers is to allow designers to design double-data-rate (DDR) logic in the I/O blocks. Each pair of the flip-flop (FF) has different clocks so that the flip-flops can be driven by two clocks with a 180-degree phase shift to achieve DDR. All I/O flip-flops still share the same reset/preset line.

The input buffer has an optional delay element used to guarantee a zero hold time requirement for input signals registered within the IOB.

Virtex-II Pro SelectIO-Ultra features also provide dedicated resources for input reference voltage ($V_{\text{REF}}$) and input output source voltage ($V_{\text{CCO}}$), along with a convenient banking system that simplifies board design. Virtex-II Pro inputs and outputs are powered from $V_{\text{CCO}}$. Differential amplifier inputs, such as GTL and SSTL, are powered from $V_{\text{REF}}$.

Fundamentals

Modern bus applications, pioneered by the largest and most influential components in the digital electronics industry, are commonly introduced with a new I/O standard tailored specifically to the needs of that application. The bus I/O standards provide specifications to other vendors who create products designed to interface with these applications. Each standard often has its own specifications for current, voltage, I/O buffering, and termination techniques.

The ability to provide the flexibility and time-to-market advantages of programmable logic is increasingly dependent on the capability of the programmable logic device to support an ever increasing variety of I/O standards.

SelectIO-Ultra resources feature highly configurable input and output buffers that provide support for a wide variety of I/O standards. An input buffer can be configured as either a simple buffer or as a differential amplifier input. An output buffer can be configured as either a Push-Pull output or as an Open Drain output. Table 2-29 illustrates all of the supported single-ended I/O standards in Virtex-II Pro devices. Each buffer type can support a variety of current and voltage requirements.

Table 2-29: Supported Single-Ended I/O Standards

<table>
<thead>
<tr>
<th>I/O Standard</th>
<th>Output Source Voltage ($V_{\text{CCO}}$)</th>
<th>Input Source Voltage ($V_{\text{CCO}}$)</th>
<th>Input Reference Voltage ($V_{\text{REF}}$)</th>
<th>Board Termination Voltage ($V_{\text{TT}}$)</th>
</tr>
</thead>
<tbody>
<tr>
<td>LVCMOS15</td>
<td>1.5</td>
<td>1.5</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>LVCMOS18</td>
<td>1.8</td>
<td>1.8</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>LVCMOS25</td>
<td>2.5</td>
<td>2.5</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>PCI33_3</td>
<td>3.3</td>
<td>3.3</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>PCI66_3</td>
<td>3.3</td>
<td>3.3</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>GTL</td>
<td>Note (1)</td>
<td>N/A</td>
<td>0.80</td>
<td>1.2</td>
</tr>
<tr>
<td>GTLP</td>
<td>Note (1)</td>
<td>N/A</td>
<td>1.0</td>
<td>1.5</td>
</tr>
<tr>
<td>HSTL_I</td>
<td>1.5</td>
<td>N/A</td>
<td>0.75</td>
<td>0.75</td>
</tr>
<tr>
<td>HSTL_II</td>
<td>1.5</td>
<td>N/A</td>
<td>0.75</td>
<td>0.75</td>
</tr>
</tbody>
</table>
Overview of Supported I/O Standards

This section provides a brief overview of I/O standards supported by all Virtex-II Pro devices.

While most I/O standards specify a range of allowed voltages, this document records typical voltage values only. Detailed information on each specification can be found on the Electronic Industry Alliance JEDEC website at:

http://www.jedec.org

LVCMOS25 - 2.5-Volt Low-Voltage CMOS

This standard is an extension of the LVCMOS standard (JESD 8.-5). It is used in general purpose 2.5 volts or lower applications. This standard requires a 2.5V input/output source voltage (VCCO), but does not require the use of a reference voltage (VREF) or a board termination voltage (VTT).

LVCMOS18 - 1.8-Volt Low-Voltage CMOS

This standard is an extension of the LVCMOS standard. It is used in general purpose 1.8V applications. The use of a reference voltage (VREF) or board termination voltage (VTT) is not required.

LVCMOS15 - 1.5-Volt Low-Voltage CMOS

This standard is an extension of the LVCMOS standard. It is used in general purpose 1.5V applications. The use of a reference voltage (VREF) or a board termination voltage (VTT) is not required.

PCI - Peripheral Component Interface

The PCI standard specifies support for 33 MHz and 66 MHz PCI bus applications. It uses a LVCMOS input buffer and a Push-Pull output buffer. This standard does not require the use of a reference voltage (VREF) or a board termination voltage (VTT). However, it does require 3.3V input/output source voltage (VCCO).
GTL - Gunning Transceiver Logic Terminated

The GTL standard is a high-speed bus standard (JESD8.3) invented by Xerox. Xilinx has implemented the terminated variation for this standard. This standard requires a differential amplifier input buffer and a open Drain output buffer.

GTLP - Gunning Transceiver Logic Plus

The Gunning Transceiver Logic Plus, or GTLP standard is a high-speed bus standard (JESD8.3) first used by the Pentium Pro Processor.

HSTL - High-speed Transceiver Logic

The high-speed Transceiver Logic, or HSTL standard is a general purpose high-speed, 1.5V bus standard sponsored by IBM (EIA/JESD8-6). This standard has four variations or classes. Virtex-II Pro SelectIO-Ultra supports all four Classes. This standard requires a Differential Amplifier input buffer and a Push-pull output buffer.

SSTL2 - Stub Series Terminated Logic for 2.5V

The Stub Series Terminated Logic for 2.5V, or SSTL2 standard is a general purpose 2.5V memory bus standard also sponsored by Hitachi and IBM (JESD8-8). This standard has two classes, I and II. Virtex-II Pro SelectIO-Ultra supports both classes for the SSTL2 standard. This standard requires a Differential Amplifier input buffer and a Push-Pull output buffer.

SSTL18 - Stub Series Terminated Logic for 1.8V

The Stub Series Terminated Logic for 1.8V, or SSTL18 is a general purpose 1.8V memory bus standard. Similar to SSTL2, it has two classes, I and II. (Only Class II is supported by JESD8-15.) Virtex-II Pro SelectIO-Ultra supports both classes for the SSTL18 standard. This standard requires a Differential Amplifier input buffer and a Push-Pull output buffer.

3.3V I/O Support

LVTTL and LVCMOS Support

Using the Xilinx Digitally-Controlled Impedance (DCI) feature, Virtex-II Pro I/Os can interface nominally with LVTTL and LVCMOS I/Os, as long as requirements 1 through 3 below are complied with. In addition, such I/Os must meet all applicable LVDCI requirements as described in Digitally Controlled Impedance (DCI), page 294. For more details on designing 3.3V I/Os, refer to XAPP659.

1. Use only designated 3.3V I/O banks. See Table 4-1, page 410, for the location of these banks. I/Os in these banks operating at 3.3V have the same reliability as other regular I/Os.

2. Use the Low-Voltage Digitally Controlled Impedance (LVDCI_33) standard. The LVDCI_33 feature can ensure perfect impedance matching at the output pins. This will eliminate over- and undershoot that could exceed the absolute maximum specifications of the I/Os.

3. LVDCI_33 does not have input termination. It is necessary to add source resistors near the external LVTTL or LVCMOS drivers that are feeding LVDCI inputs. The combined
impedance of resistor \( R_0 \) and the driver must match the impedance of board traces. Figure 2-75 illustrates the requirement.

\[
\begin{align*}
\text{LVTTL / LVCMOS driver} & \quad Z_0 \\
\text{External Device} & \\
R_0 + R_{\text{driver}} &= Z_0 = 50 \Omega \text{ (typical)} \\
V_{\text{CCO}} &= 3.3V
\end{align*}
\]

**Figure 2-75: Source Resistor for LVDCI_33 Input**

LVDCI_33 inputs work exactly the same as LVCMOS33 inputs. No VRN/VRP is required if the bank is used for LVDCI input only. If LVDCI outputs are used, the VRN/VRP must be connected to appropriate resistors that match the impedance of the transmission line. JTAG pins are 3.3V-tolerant, even though VCCAUX is 2.5V.

**PCI Support**

The supported PCI I/O standards are PCI33_3 and PCI66_3. For further information on interfacing a Virtex-II Pro device to a PCI bus, please see the following Xilinx application notes:

- **XAPP646**, Connecting Virtex-II Devices to a 3.3V/5V PCI Bus
- **XAPP653**, Virtex-II Pro 3.3V PCI Reference Design

**NOTE:** The information contained in both these application notes must be taken into account when implementing PCI33_3 or PCI66_3.

**Library Symbols**

The Xilinx library includes an extensive list of symbols designed to provide support for the variety of SelectIO-Ultra features. Most of these symbols represent variations of the five generic SelectIO-Ultra symbols.

- IBUF (input buffer)
- IBUFG (clock input buffer)
- OBUF (output buffer)
- OBUFT (3-state output buffer)
- IOBUF (input/output buffer)

**IBUF**

Signals used as inputs to a Virtex-II Pro device must source an input buffer (IBUF) via an external input port. The generic Virtex-II Pro IBUF symbol is shown in Figure 2-76. The extension to the base name defines which I/O standard the IBUF uses. The assumed standard is LVCMOS when the generic IBUF has no specified extension.

\[
\begin{align*}
\text{IBUF} \\
\text{I} & \quad \text{O}
\end{align*}
\]

**Figure 2-76: Input Buffer (IBUF) Symbols**
Table 2-30 details variations of the IBUF symbol for single-ended Virtex-II Pro I/O standards:

**Table 2-30: Variations of the IBUF Symbol**

<table>
<thead>
<tr>
<th>IBUF</th>
<th>IBUF_HSTL_II</th>
</tr>
</thead>
<tbody>
<tr>
<td>IBUF_LVCMOS15</td>
<td>IBUF_HSTL_III</td>
</tr>
<tr>
<td>IBUF_LVCMOS18</td>
<td>IBUF_HSTL_IV</td>
</tr>
<tr>
<td>IBUF_LVCMOS25</td>
<td>IBUF_SSTL2_I</td>
</tr>
<tr>
<td>IBUF_GTL</td>
<td>IBUF_SSTL2_II</td>
</tr>
<tr>
<td>IBUF_GTLP</td>
<td>IBUF_PCI33_3</td>
</tr>
<tr>
<td>IBUF_HSTL_I</td>
<td>IBUF_PCI66_3</td>
</tr>
</tbody>
</table>

When the IBUF symbol supports an I/O standard that requires a differential amplifier input, the IBUF is automatically configured as a differential amplifier input buffer. The low-voltage I/O standards with a differential amplifier input require an external reference voltage input $V_{\text{REF}}$.

The voltage reference signal is “banked” within the Virtex-II Pro device on a half-edge basis, such that for all packages there are eight independent $V_{\text{REF}}$ banks internally. For a representation of the Virtex-II Pro I/O banks, see Figure 2-78. Within each bank, approximately one of every six I/O pins is automatically configured as a $V_{\text{REF}}$ input. After placing a differential amplifier input signal within a given $V_{\text{REF}}$ bank, the same external source must drive all I/O pins configured as a $V_{\text{REF}}$ input.

IBUF placement restrictions require that any differential amplifier input signals within a bank be of the same standard. How to specify a specific location for the IBUF via the LOC property is described below. Table 2-31 summarizes compatibility requirements of Virtex-II Pro input standards.

An optional delay element in the input data path is associated with each IBUF. When the IBUF drives a flip-flop within the IOB, the delay element is activated by default to ensure a zero hold-time requirement at the device input pin. The IOBDELAY = NONE property overrides this default, reducing the input set-up time, but risking a hold-time requirement. When the IBUF does not drive a flip-flop within the IOB, the delay element is deactivated by default to provide a shorter input set-up time. To delay the input signal, activate the delay element with the IOBDELAY = BOTH property.
Each bank has its own VCCO and VREF voltage. Details on compatible input standards for each VCCO / VREF voltage combination are available in the Virtex-II Pro Data Sheet.

**OBUF**

An OBUF must drive outputs through an external output port. Figure 2-79 shows the generic output buffer (OBUF) symbol.

The extension to the base name defines which I/O standard the OBUF uses. With no extension specified for the generic OBUF symbol, the assumed standard is slew rate limited LVCMOS25 with 12mA drive strength.

The LVCMOS OBUFs can additionally support one of two slew rate modes to minimize bus transients. By default, the slew rate for each output buffer is reduced to minimize power bus transients, when switching non-critical signals.

LVCMOS output buffers have selectable drive strengths. The format for these OBUF symbol names is as follows:

```
OBUF_<slew_rate>_ <drive_strength>
```

<slew_rate> is either F (fast) or S (slow) and <drive_strength> is specified in milliamperes. For LVCMOS25, the supported drive strengths are 2, 4, 6, 8, 12, 16, and 24. For LVCMOS15 and LVCMOS18, the supported drive strengths are 2, 4, 6, 8, 12, and 16.
Table 2-32 details variations of the OBUF symbol.

**Table 2-32: Variations of the OBUF Symbol**

<table>
<thead>
<tr>
<th>OBUF</th>
<th>OBUF_LVC莫斯15_F_4</th>
<th>OBUF_LVC莫斯25_S_12</th>
</tr>
</thead>
<tbody>
<tr>
<td>OBUF_S_2</td>
<td>OBUF_LVC莫斯15_F_6</td>
<td>OBUF_LVC莫斯25_S_16</td>
</tr>
<tr>
<td>OBUF_S_4</td>
<td>OBUF_LVCamos15_F_8</td>
<td>OBUF_LVCamos25_S_24</td>
</tr>
<tr>
<td>OBUF_S_6</td>
<td>OBUF_LVCamos15_F_12</td>
<td>OBUF_LVCamos25_F_2</td>
</tr>
<tr>
<td>OBUF_S_8</td>
<td>OBUF_LVCamos15_F_16</td>
<td>OBUF_LVCamos25_F_4</td>
</tr>
<tr>
<td>OBUF_S_12</td>
<td>OBUF_LVCamos18</td>
<td>OBUF_LVCamos25_F_6</td>
</tr>
<tr>
<td>OBUF_S_16</td>
<td>OBUF_LVCamos18_S_2</td>
<td>OBUF_LVCamos25_F_8</td>
</tr>
<tr>
<td>OBUF_S_24</td>
<td>OBUF_LVCamos18_S_4</td>
<td>OBUF_LVCamos25_F_12</td>
</tr>
<tr>
<td>OBUF_F_2</td>
<td>OBUF_LVCamos18_S_6</td>
<td>OBUF_LVCamos25_F_16</td>
</tr>
<tr>
<td>OBUF_F_4</td>
<td>OBUF_LVCamos18_S_8</td>
<td>OBUF_LVCamos25_F_24</td>
</tr>
<tr>
<td>OBUF_F_6</td>
<td>OBUF_LVCamos18_S_12</td>
<td>OBUF_PCI33_3</td>
</tr>
<tr>
<td>OBUF_F_8</td>
<td>OBUF_LVCamos18_S_16</td>
<td>OBUF_PCI66-3</td>
</tr>
<tr>
<td>OBUF_F_12</td>
<td>OBUF_LVCamos18_F_2</td>
<td>OBUF_GTL</td>
</tr>
<tr>
<td>OBUF_F_16</td>
<td>OBUF_LVCamos18_F_4</td>
<td>OBUF_GTLP</td>
</tr>
<tr>
<td>OBUF_F_24</td>
<td>OBUF_LVCamos18_F_6</td>
<td>OBUF_HSTL_I</td>
</tr>
<tr>
<td>OBUF_LVCamos15</td>
<td>OBUF_LVCamos18_F_8</td>
<td>OBUF_HSTL_II</td>
</tr>
<tr>
<td>OBUF_LVCamos15_S_2</td>
<td>OBUF_LVCamos18_F_12</td>
<td>OBUF_HSTL_III</td>
</tr>
<tr>
<td>OBUF_LVCamos15_S_4</td>
<td>OBUF_LVCamos18_F_16</td>
<td>OBUF_HSTL_IV</td>
</tr>
<tr>
<td>OBUF_LVCamos15_S_6</td>
<td>OBUF_LVCamos25</td>
<td>OBUF_SSTL18_1</td>
</tr>
<tr>
<td>OBUF_LVCamos15_S_8</td>
<td>OBUF_LVCamos25_S_2</td>
<td>OBUF_SSTL18_2</td>
</tr>
<tr>
<td>OBUF_LVCamos15_S_12</td>
<td>OBUF_LVCamos25_S_4</td>
<td>OBUF_SSTL2_I</td>
</tr>
<tr>
<td>OBUF_LVCamos15_S_16</td>
<td>OBUF_LVCamos25_S_6</td>
<td>OBUF_SSTL2_II</td>
</tr>
<tr>
<td>OBUF_LVCamos15_F_2</td>
<td>OBUF_LVCamos25_S_8</td>
<td></td>
</tr>
</tbody>
</table>

OBUF placement restrictions require that within a given V_CCO bank each OBUF share the same output source drive voltage. Input buffers with the same V_CCO and output buffers that do not require V_CCO can be placed within any V_CCO bank. Table 2-33 summarizes Virtex-II Pro output compatibility requirements. The LOC property can specify a location for the OBUF.

**Table 2-33: Output Standards Compatibility Requirements**

<table>
<thead>
<tr>
<th>Rule</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Rule 1</td>
<td>Only outputs with standards which share compatible V_CCO can be used within the same bank.</td>
</tr>
<tr>
<td>Rule 2</td>
<td>There are no placement restrictions for outputs with standards that do not require a V_CCO</td>
</tr>
</tbody>
</table>

Each bank has its own V_CCO voltage. Details on compatible output standards for each V_CCO voltage combination are available in the [Virtex-II Pro Data Sheet](https://www.xilinx.com).
OBUFT

The generic 3-state output buffer OBUFT, shown in Figure 2-80, typically implements 3-state outputs or bidirectional I/O.

The extension to the base name defines which I/O standard OBUFT uses. With no extension specified for the generic OBUFT symbol, the assumed standard is slew rate limited LVCMOS with 12mA drive strength.

The LVCMOS OBUFT additionally can support one of two slew rate modes to minimize bus transients. By default, the slew rate for each output buffer is reduced to minimize power bus transients, when switching non-critical signals.

LVCMOS 3-state buffers have selectable drive strengths. The format for these OBUFT symbol names is as follows:

\[
\text{OBUFT}_{<\text{slew\_rate}>}_{<\text{drive\_strength}>}
\]

\(<\text{slew\_rate}>> is either F(fast) or S(slow) and <drive_strength> is specified in milliamperes. For LVCMOS25, the supported drive strengths are 2, 4, 6, 8, 12, 16, and 24. For LVCMOS15 and LVCMOS18, the supported drive strengths are 2, 4, 6, 8, 12, and 16.

Table 2-34 details variations of the OBUFT symbol.

<table>
<thead>
<tr>
<th>OBUFT</th>
<th>OBUFT_LVCMOS15_F_2</th>
<th>OBUFT_LVCMOS25_S_6</th>
</tr>
</thead>
<tbody>
<tr>
<td>OBUFT_S_2</td>
<td>OBUFT_LVCMOS15_F_4</td>
<td>OBUFT_LVCMOS25_S_8</td>
</tr>
<tr>
<td>OBUFT_S_4</td>
<td>OBUFT_LVCMOS15_F_6</td>
<td>OBUFT_LVCMOS25_S_12</td>
</tr>
<tr>
<td>OBUFT_S_6</td>
<td>OBUFT_LVCMOS15_F_8</td>
<td>OBUFT_LVCMOS25_S_16</td>
</tr>
<tr>
<td>OBUFT_S_8</td>
<td>OBUFT_LVCMOS15_F_12</td>
<td>OBUFT_LVCMOS25_S_24</td>
</tr>
<tr>
<td>OBUFT_S_12</td>
<td>OBUFT_LVCMOS15_F_16</td>
<td>OBUFT_LVCMOS25_F_2</td>
</tr>
<tr>
<td>OBUFT_S_16</td>
<td>OBUFT_LVCMOS18</td>
<td>OBUFT_LVCMOS25_F_4</td>
</tr>
<tr>
<td>OBUFT_S_24</td>
<td>OBUFT_LVCMOS18_S_2</td>
<td>OBUFT_LVCMOS25_F_6</td>
</tr>
<tr>
<td>OBUFT_F_2</td>
<td>OBUFT_LVCMOS18_S_4</td>
<td>OBUFT_LVCMOS25_F_8</td>
</tr>
<tr>
<td>OBUFT_F_4</td>
<td>OBUFT_LVCMOS18_S_6</td>
<td>OBUFT_LVCMOS25_F_12</td>
</tr>
<tr>
<td>OBUFT_F_6</td>
<td>OBUFT_LVCMOS18_S_8</td>
<td>OBUFT_LVCMOS25_F_16</td>
</tr>
<tr>
<td>OBUFT_F_8</td>
<td>OBUFT_LVCMOS18_S_12</td>
<td>OBUFT_LVCMOS25_F_24</td>
</tr>
<tr>
<td>OBUFT_F_12</td>
<td>OBUFT_LVCMOS18_S_16</td>
<td>OBUFT_PCI33_3</td>
</tr>
<tr>
<td>OBUFT_F_16</td>
<td>OBUFT_LVCMOS18_F_2</td>
<td>OBUFT_PCI66-3</td>
</tr>
<tr>
<td>OBUFT_F_24</td>
<td>OBUFT_LVCMOS18_F_4</td>
<td>OBUFT_GTL</td>
</tr>
<tr>
<td>OBUFT_LVCMOS15</td>
<td>OBUFT_LVCMOS18_F_6</td>
<td>OBUFT_GTLP</td>
</tr>
<tr>
<td>OBUFT_LVCMOS15_S_2</td>
<td>OBUFT_LVCMOS18_F_8</td>
<td>OBUFT_HSTL_I</td>
</tr>
<tr>
<td>OBUFT_LVCMOS15_S_4</td>
<td>OBUFT_LVCMOS18F_12</td>
<td>OBUFT_HSTL_II</td>
</tr>
</tbody>
</table>

Figure 2-80: 3-State Output Buffer Symbol (OBUFT)
OBUFT placement restrictions require that within a given $V_{CCO}$ bank each OBUFT share the same output source drive voltage. Input buffers with the same $V_{CCO}$ and output buffers that do not require $V_{CCO}$ can be placed within any $V_{CCO}$ bank. The LOC property can specify a location for the OBUFT.

3-state output buffers and bidirectional buffers can have either a weak pull-up resistor, a weak pull-down resistor, or a weak “keeper” circuit. Control this feature by adding the appropriate symbol to the output net of the OBUFT (PULLUP, PULLDOWN, or KEEPER).

The weak “keeper” circuit requires the input buffer within the IOB to sample the I/O signal. Thus, OBUFTs programmed for an I/O standard that requires a $V_{REF}$ have automatic placement of a $V_{REF}$ in the bank with an OBUFT configured with a weak “keeper” typically implement a bidirectional I/O. In this case, the IBUF (and the corresponding $V_{REF}$) are placed explicitly.

### IOBUF

Use the IOBUF symbol for bidirectional signals that require both an input buffer and a 3-state output buffer with an active High 3-state pin. Figure 2-81 shows the generic input/output IOBUF buffer.

![Figure 2-81: Input/Output Buffer Symbol (IOBUF)](x133_06_111699)

The extension to the base name defines which I/O standard the IOBUF uses. With no extension specified for the generic IOBUF symbol, the assumed standard is LVCMOS input buffer and slew rate limited LVCMOS with 12mA drive strength for the output buffer.

The LVCMOS IOBUF can additionally support one of two slew rate modes to minimize bus transients. By default, the slew rate for each output buffer is reduced to minimize power bus transients, when switching non-critical signals.

LVCMOS output buffers have selectable drive strengths. The format for these IOBUF symbol names is as follows:

```
IOBUF_<slew_rate>_<drive_strength>
```

<slew_rate> is either F (fast) or S (slow) and <drive_strength> is specified in milliamperes. For LVCMOS25, the supported drive strengths are 2, 4, 6, 8, 12, 16, and 24. For LVCMOS15
and LVCMOS18, the supported drive strengths are 2, 4, 6, 8, 12, and 16. Table 2-35 details variations of the IOBUF symbol.

Table 2-35: Variations of the IOBUF Symbol

<table>
<thead>
<tr>
<th>IOBUF</th>
<th>IOBUF_LVCMOS15_F_4</th>
<th>IOBUF_LVCMOS25_S_12</th>
</tr>
</thead>
<tbody>
<tr>
<td>IOBUF_S_2</td>
<td>IOBUF_LVCMOS15_F_6</td>
<td>IOBUF_LVCMOS25_S_16</td>
</tr>
<tr>
<td>IOBUF_S_4</td>
<td>IOBUF_LVCMOS15_F_8</td>
<td>IOBUF_LVCMOS25_S_24</td>
</tr>
<tr>
<td>IOBUF_S_6</td>
<td>IOBUF_LVCMOS15_F_12</td>
<td>IOBUF_LVCMOS25_F_2</td>
</tr>
<tr>
<td>IOBUF_S_8</td>
<td>IOBUF_LVCMOS15_F_16</td>
<td>IOBUF_LVCMOS25_F_4</td>
</tr>
<tr>
<td>IOBUF_S_12</td>
<td>IOBUF_LVCMOS18</td>
<td>IOBUF_LVCMOS25_F_6</td>
</tr>
<tr>
<td>IOBUF_S_16</td>
<td>IOBUF_LVCMOS18_S_2</td>
<td>IOBUF_LVCMOS25_F_8</td>
</tr>
<tr>
<td>IOBUF_S_24</td>
<td>IOBUF_LVCMOS18_S_4</td>
<td>IOBUF_LVCMOS25_F_12</td>
</tr>
<tr>
<td>IOBUF_F_2</td>
<td>IOBUF_LVCMOS18_S_6</td>
<td>IOBUF_LVCMOS25_F_16</td>
</tr>
<tr>
<td>IOBUF_F_4</td>
<td>IOBUF_LVCMOS18_S_8</td>
<td>IOBUF_LVCMOS25_F_24</td>
</tr>
<tr>
<td>IOBUF_F_6</td>
<td>IOBUF_LVCMOS18_S_12</td>
<td>IOBUF_PCI33_3</td>
</tr>
<tr>
<td>IOBUF_F_8</td>
<td>IOBUF_LVCMOS18_S_16</td>
<td>IOBUF_PCI66-3</td>
</tr>
<tr>
<td>IOBUF_F_12</td>
<td>IOBUF_LVCMOS18_F_2</td>
<td>IOBUF_GTL</td>
</tr>
<tr>
<td>IOBUF_F_16</td>
<td>IOBUF_LVCMOS18_F_4</td>
<td>IOBUF_GTLP</td>
</tr>
<tr>
<td>IOBUF_F_24</td>
<td>IOBUF_LVCMOS18_F_6</td>
<td>IOBUF_HSTL_I</td>
</tr>
<tr>
<td>IOBUF_LVCMOS15</td>
<td>IOBUF_LVCMOS18_F_8</td>
<td>IOBUF_HSTL_II</td>
</tr>
<tr>
<td>IOBUF_LVCMOS15_F_2</td>
<td>IOBUF_LVCMOS18F_12</td>
<td>IOBUF_HSTL_III</td>
</tr>
<tr>
<td>IOBUF_LVCMOS15_S_2</td>
<td>IOBUF_LVCMOS18_F_16</td>
<td>IOBUF_HSTL_IV</td>
</tr>
<tr>
<td>IOBUF_LVCMOS15_S_4</td>
<td>IOBUF_LVCMOS25</td>
<td>IOBUF_SSTL18_I</td>
</tr>
<tr>
<td>IOBUF_LVCMOS15_S_6</td>
<td>IOBUF_LVCMOS25</td>
<td>IOBUF_SSTL18_II</td>
</tr>
<tr>
<td>IOBUF_LVCMOS15_S_8</td>
<td>IOBUF_LVCMOS25_S_2</td>
<td>IOBUF_SSTL18_II</td>
</tr>
<tr>
<td>IOBUF_LVCMOS15_S_12</td>
<td>IOBUF_LVCMOS25_S_4</td>
<td>IOBUF_SSTL2_1</td>
</tr>
<tr>
<td>IOBUF_LVCMOS15_S_16</td>
<td>IOBUF_LVCMOS25_S_6</td>
<td>IOBUF_SSTL2_II</td>
</tr>
<tr>
<td>IOBUF_LVCMOS15_F_2</td>
<td>IOBUF_LVCMOS25_S_8</td>
<td></td>
</tr>
</tbody>
</table>

When the IOBUF symbol supports an I/O standard that requires a differential amplifier input, IOBUF is automatically configured as a differential amplifier input buffer. Low-voltage I/O standards with a differential amplifier input require an external reference voltage input $V_{REF}$.

The voltage reference signal is “banked” within the Virtex-II Pro device on a half-edge basis, such that for all packages there are eight independent $V_{REF}$ banks internally. For a representation of the Virtex-II Pro I/O banks, see Figure 2-78. Within each bank approximately one of every twelve I/O pins is automatically configured as a $V_{REF}$ input. After placing a differential amplifier input signal within a given $V_{REF}$ bank, the same external source must drive all I/O pins configured as a $V_{REF}$ input.

IOBUF placement restrictions require any differential amplifier input signals within a bank be of the same standard.

Additional restrictions on Virtex-II Pro SelectIO-Ultra IOBUF placement require that within a given $V_{CCO}$ bank each IOBUF share the same output source drive voltage. Input buffers with the same $V_{CCO}$ and output buffers that do not require $V_{CCO}$ can be placed within any $V_{CCO}$ bank. The LOC property can specify a location for the IOBUF.
An optional delay element is associated with the input path in each IOBUF. When the IOBUF drives an input flip-flop within the IOB, the delay element is activated by default to ensure the zero hold-time requirement. Override this default with the IOBDELAY = NONE property.

In the case when the IOBUF does not drive an input flip-flop within the IOB, the delay element is deactivated by default to provide higher performance. To delay the input signal, activate the delay element with the IOBDELAY = BOTH property.

3-state output buffers and bidirectional buffers can have a weak pull-up resistor, a weak pull-down resistor, or a weak “keeper” circuit. Control this feature by adding the appropriate symbol to the output net of the IOBUF (PULLUP, PULLDOWN, or KEEPER).

SelectIO-Ultra Properties

Access to some SelectIO-Ultra features (for example, location constraints, input delay, output drive strength, and slew rate) is available through properties associated with these features.

Input Delay Properties

An optional delay element is associated with the input path in each IBUF. When the IBUF drives an input flip-flop within the IOB, the delay element activates by default to ensure the zero hold-time requirement. Override this default with the IOBDELAY = NONE property.

In the case when the IBUF does not drive an input flip-flop within the IOB, the delay element is deactivated by default to provide higher performance. To delay the input signal, activate the delay element with the IOBDELAY = BOTH property.

IOB Flip-Flop/Latch Properties

The Virtex-II Pro Series I/O block (IOB) includes two optional registers on the input path, two optional registers on the output path, and two optional registers on the 3-state control pin. The design implementation software automatically takes advantage of these registers when the following option for the MAP program is specified.

Map -pr b <filename>

Alternatively, the IOB = TRUE property can be placed on a register to force the mapper to place the register in an IOB.

The two registers for each path makes designing double-data-rate (DDR) logic much simpler. Each pair of the registers has separate clock inputs, which can be driven by either the positive edge or the negative edge of the clock. Users can use both edges of the clocks to clock data in and out from the IOB. For details on DDR, see Double-Data-Rate (DDR) I/O, page 310.

Location Constraints

Specify the location of each SelectIO-Ultra symbol with the location constraint LOC attached to the SelectIO-Ultra symbol. The external port identifier indicates the value of the location constrain. The format of the port identifier depends on the package chosen for the specified design.

The LOC properties use the following form:

- LOC=A42;
- LOC=P37;

Output Slew Rate Property

As mentioned above, a variety of symbol names provide the option of choosing the desired slew rate for the output buffers. In the case of the LVCMOS output buffers (OBUF, OBUFT, and IOBUF), slew rate control can be alternatively programmed with the
SLEW = property. By the default, the slew rate for each output buffer is reduced to minimize power bus transients when switching non-critical signals. The SLEW = property has one of the two following values:

- SLEW = SLOW
- SLEW = FAST

Output Drive Strength Property

The desired output drive strength can be additionally specified by choosing the appropriate library symbol. The Xilinx library also provides an alternative method for specifying this feature. For the LVCMOS output buffers (OBUF, OBUFT, and IOBUF), the desired drive strength can be specified with the DRIVE = property. This property could have one of the following values:

- DRIVE = 2
- DRIVE = 4
- DRIVE = 6
- DRIVE = 8
- DRIVE = 12
- DRIVE = 16
- DRIVE = 24

Design Considerations

Reference Voltage (VREF) Pins

Low-voltage I/O standards with a differential amplifier input buffer require an input reference voltage (VREF). Provide the VREF as an external signal to the device.

The voltage reference signal is “banked” within the Virtex-II Pro device on a half-edge basis such that for all packages there are eight independent VREF banks internally. See Figure 2-78 for a representation of the Virtex-II Pro I/O banks. Within each bank approximately one of every twelve I/O pins is automatically configured as a VREF input. After placing a differential amplifier input signal within a given VREF bank, the same external source must drive all I/O pins configured as a VREF input.

Within each VREF bank, any input buffers that require a VREF signal must be of the same type. Output buffers that have the same VCCO values as the input buffers can be placed within the same VREF bank.

Output Drive Source Voltage (VCCO) Pins

Many of the low-voltage I/O standards supported by SelectIO-Ultra devices require a different output drive source voltage (VCCO). As a result each device can often have to support multiple output drive source voltages.

Output buffers within a given VCCO bank must share the same output drive source voltage. Input buffers for LVCMOS15, LVCMOS18, LVCMOS25, PCI33_3, and PCI66_3 use the VCCO voltage for input VCCO voltage.

Transmission Line Effects

The delay of an electrical signal along a wire is dominated by the rise and fall times when the signal travels a short distance. Transmission line delays vary with inductance and capacitance. But a well-designed board can experience delays of approximately 180ps per inch. Transmission line effects, or reflections, typically start at 1.5” for fast (1.5ns) rise and fall times. Poor (or non-existent) termination or changes in the transmission line impedance cause these reflections and can cause additional delay in longer traces. As a
system speeds continue to increase, the effect of I/O delays can become a limiting factor and therefore transmission line termination becomes increasingly more important.

Termination Techniques

A variety of termination techniques reduce the impact of transmission line effects. The following are output termination techniques:

- None
- Series
- Parallel (Shunt)
- Series and Parallel (Series-Shunt)

The following are input termination techniques:

- None
- Parallel (Shunt)

These termination techniques can be applied in any combination. A generic example of each combination of termination methods appears in Figure 2-82.

Simultaneous Switching Guidelines

Ground bounce can occur with high-speed digital ICs when multiple outputs change states simultaneously, causing undesired transient behavior on an output or in the internal logic. This is also referred to as the Simultaneous Switching Output (SSO) problem.

Ground bounce is primarily due to current changes in the combined inductance of ground pins, bond wires, and group metallization. The IC internal ground level deviates from the external system ground level for a short duration (a few nanoseconds) after multiple outputs change state simultaneously.

Ground bounce affects stable low outputs and all inputs because they interpret the incoming signal by comparing it to the internal ground. If the ground bounce amplitude exceeds the actual instantaneous noise margin, then a non-changing input can be interpreted as changing. Table 2-36 provides the guidelines for the maximum number of simultaneously switching outputs allowed per output power/ground pair to avoid the effects of ground bounce. (See Note 1 at the end of the table for qualifications.) Refer to
Note on LVDCI Drivers

Table 2-36 shows LVDCI guidelines only for 50Ω impedance. For higher reference resistor (RR) values, less drive strength is needed, and the SSO limit increases linearly. To calculate the SSO limit for an LVDCI driver with different reference resistors, the following formula is used:

\[
\text{New SSO Limit} = \frac{\text{New RR Value}}{50\Omega} \times \text{SSO Limit for 50Ω}
\]

**Example:**

If using the LVDCI_18 driver with 65Ω reference resistors, the LVDCI_18 SSO limit for 50Ω impedance is first taken from the table. The SSO limit for LVDCI_18 at 50Ω is 11 per power/ground pin pair. Therefore, the SSO limit for LVDCI_18 at 65Ω is \((65\Omega / 50\Omega) \times 11 = 14\) per power/ground pin pair.

**Table 2-36:** Guidelines for Maximum Number of Simultaneously Switching Outputs per Power/Ground Pair (1)

<table>
<thead>
<tr>
<th>Standard</th>
<th>Package: FG, FF</th>
</tr>
</thead>
<tbody>
<tr>
<td>LVDCI_15 (50Ω impedance)</td>
<td>10</td>
</tr>
<tr>
<td>LVDCI_DV2_15 (25Ω impedance)</td>
<td>5</td>
</tr>
<tr>
<td>LVCMOS15_2_slow</td>
<td>51</td>
</tr>
<tr>
<td>LVCMOS15_4_slow</td>
<td>31</td>
</tr>
<tr>
<td>LVCMOS15_6_slow</td>
<td>22</td>
</tr>
<tr>
<td>LVCMOS15_8_slow</td>
<td>17</td>
</tr>
<tr>
<td>LVCMOS15_12_slow</td>
<td>11</td>
</tr>
<tr>
<td>LVCMOS15_16_slow</td>
<td>8</td>
</tr>
<tr>
<td>LVCMOS15_2_fast</td>
<td>30</td>
</tr>
<tr>
<td>LVCMOS15_4_fast</td>
<td>18</td>
</tr>
<tr>
<td>LVCMOS15_6_fast</td>
<td>13</td>
</tr>
<tr>
<td>LVCMOS15_8_fast</td>
<td>10</td>
</tr>
<tr>
<td>LVCMOS15_12_fast</td>
<td>8</td>
</tr>
<tr>
<td>LVCMOS15_16_fast</td>
<td>6</td>
</tr>
<tr>
<td>LVDCI_18 (50Ω impedance)</td>
<td>11</td>
</tr>
<tr>
<td>LVDCI_DV2_18 (25Ω impedance)</td>
<td>5</td>
</tr>
<tr>
<td>LVCMOS18_2_slow</td>
<td>58</td>
</tr>
<tr>
<td>LVCMOS18_4_slow</td>
<td>35</td>
</tr>
<tr>
<td>LVCMOS18_6_slow</td>
<td>25</td>
</tr>
<tr>
<td>LVCMOS18_8_slow</td>
<td>19</td>
</tr>
<tr>
<td>LVCMOS18_12_slow</td>
<td>13</td>
</tr>
<tr>
<td>LVCMOS18_16_slow</td>
<td>10</td>
</tr>
</tbody>
</table>
### Table 2-36: Guidelines for Maximum Number of Simultaneously Switching Outputs per Power/Ground Pair (1) (Continued)

<table>
<thead>
<tr>
<th>Standard</th>
<th>Package: FG, FF</th>
</tr>
</thead>
<tbody>
<tr>
<td>LVCMOS18_2_fast</td>
<td>34</td>
</tr>
<tr>
<td>LVCMOS18_4_fast</td>
<td>20</td>
</tr>
<tr>
<td>LVCMOS18_6_fast</td>
<td>15</td>
</tr>
<tr>
<td>LVCMOS18_8_fast</td>
<td>11</td>
</tr>
<tr>
<td>LVCMOS18_12_fast</td>
<td>9</td>
</tr>
<tr>
<td>LVCMOS18_16_fast</td>
<td>7</td>
</tr>
<tr>
<td>LVDCl_25 50Ω impedance</td>
<td>13</td>
</tr>
<tr>
<td>LVDCl_DV2_25 25Ω impedance</td>
<td>6</td>
</tr>
<tr>
<td>LVCMOS25_2_slow</td>
<td>68</td>
</tr>
<tr>
<td>LVCMOS25_4_slow</td>
<td>41</td>
</tr>
<tr>
<td>LVCMOS25_6_slow</td>
<td>29</td>
</tr>
<tr>
<td>LVCMOS25_8_slow</td>
<td>22</td>
</tr>
<tr>
<td>LVCMOS25_12_slow</td>
<td>15</td>
</tr>
<tr>
<td>LVCMOS25_16_slow</td>
<td>11</td>
</tr>
<tr>
<td>LVCMOS25_24_slow</td>
<td>7</td>
</tr>
<tr>
<td>LVCMOS25_2_fast</td>
<td>40</td>
</tr>
<tr>
<td>LVCMOS25_4_fast</td>
<td>24</td>
</tr>
<tr>
<td>LVCMOS25_6_fast</td>
<td>17</td>
</tr>
<tr>
<td>LVCMOS25_8_fast</td>
<td>13</td>
</tr>
<tr>
<td>LVCMOS25_12_fast</td>
<td>10</td>
</tr>
<tr>
<td>LVCMOS25_16_fast</td>
<td>8</td>
</tr>
<tr>
<td>LVCMOS25_24_fast</td>
<td>5</td>
</tr>
<tr>
<td>LVDCl_33 (50Ω impedance)</td>
<td>13</td>
</tr>
<tr>
<td>LVDCl_DV2_33 (25Ω impedance)</td>
<td>6</td>
</tr>
<tr>
<td>PCI33/66/X</td>
<td>8</td>
</tr>
<tr>
<td>GTL</td>
<td>4</td>
</tr>
<tr>
<td>GTL_DCI</td>
<td>3</td>
</tr>
<tr>
<td>GTLP</td>
<td>4</td>
</tr>
<tr>
<td>GTLP_DCI</td>
<td>3</td>
</tr>
<tr>
<td>HSTLI</td>
<td>20</td>
</tr>
<tr>
<td>HSTLI_DCI</td>
<td>20</td>
</tr>
<tr>
<td>HSTLII</td>
<td>10</td>
</tr>
<tr>
<td>HSTLII_DCI</td>
<td>7</td>
</tr>
</tbody>
</table>
Since some of the ground pins are shared inside the package, the effective power/ground pairs per bank may be fewer than the physical power/ground pair pins. The following tables show the number of equivalent power/ground pairs.

Table 2-37 shows the number of pairs in banks 0, 1, 4, and 5 (top and bottom edges of the die), while Table 2-38 shows the numbers in banks 2, 3, 6, and 7. This is because MGTs reside on the top and bottom edge only.

Table 2-36: Guidelines for Maximum Number of Simultaneously Switching Outputs per Power/Ground Pair (Continued)

<table>
<thead>
<tr>
<th>Standard</th>
<th>Package: FG, FF</th>
</tr>
</thead>
<tbody>
<tr>
<td>HSTLIII</td>
<td>8</td>
</tr>
<tr>
<td>HSTLIII_DCI</td>
<td>8</td>
</tr>
<tr>
<td>HSTLIV</td>
<td>4</td>
</tr>
<tr>
<td>HSTLIV_DCI</td>
<td>4</td>
</tr>
<tr>
<td>SSTL18_I</td>
<td>20</td>
</tr>
<tr>
<td>SSTL18_I_DCI</td>
<td>20</td>
</tr>
<tr>
<td>SSTL18_II</td>
<td>10</td>
</tr>
<tr>
<td>SSTL18_II_DCI</td>
<td>6</td>
</tr>
<tr>
<td>SSTL2_1</td>
<td>15</td>
</tr>
<tr>
<td>SSTL2_1_DCI</td>
<td>15</td>
</tr>
<tr>
<td>SSTL2_II</td>
<td>10</td>
</tr>
<tr>
<td>SSTL2_II_DCI</td>
<td>5</td>
</tr>
</tbody>
</table>

Notes:
1. The maximum number of simultaneously switching outputs per power/ground pair may be less than the number given in this table if the external bypass capacitor solution has a high series inductance. This table presumes the use of ultra-low inductance bypass capacitors. Refer to VCC Decoupling, page 500.

Table 2-37: Virtex-II Pro Equivalent Power/Ground Pairs per Bank, Top/Bottom

<table>
<thead>
<tr>
<th>Package</th>
<th>For Banks 0, 1, 4, and 5 (Top/Bottom Sides):</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>2VP2</td>
</tr>
<tr>
<td>FG256</td>
<td>2</td>
</tr>
<tr>
<td>FG456</td>
<td>3</td>
</tr>
<tr>
<td>FG672</td>
<td>4</td>
</tr>
<tr>
<td>FF896</td>
<td>6</td>
</tr>
<tr>
<td>FF1152</td>
<td>9</td>
</tr>
<tr>
<td>FF1148</td>
<td></td>
</tr>
<tr>
<td>FF1517</td>
<td></td>
</tr>
<tr>
<td>FF1704</td>
<td></td>
</tr>
<tr>
<td>FF1696</td>
<td></td>
</tr>
</tbody>
</table>
Application Example

Creating a design with the SelectIO-Ultra feature requires either assignment of the IOSTANDARD attribute in the constraint file or instantiation of the desired library symbol within the design code.

To enter the IOSTANDARD attribute in the constraint file (UCF file), the following syntax can be used:

\[
\text{NET } \langle \text{pad net name} \rangle \text{ IOSTANDARD}=\langle \text{the name of the standard} \rangle
\]

For example, to enter LVCMOS25 standard, use

\[
\text{NET } \langle \text{pad net name} \rangle \text{ IOSTANDARD}=\text{LVCMOS25};
\]

To instantiate a library symbol in the HDL code, use the proper input or output buffer name, and follow the standard syntax of instantiation.

For example, to instantiate a GTL input buffer in VHDL, the following syntax can be used:

\[
\text{GTL_buffer : IBUF_GTL port map (I=>data_in, O=>data_gtl_in);}\]

At the board level, designers need to know the termination techniques required for each I/O standard.

This section describes some common application examples illustrating the termination techniques recommended by each of the single-ended standard supported by the SelectIO-Ultra features.

Termination Example

Circuit examples involving typical termination techniques for each of the SelectIO-Ultra standards follow. For a full range of accepted values for the DC voltage specifications for each standard, refer to the table associated with each figure.

The resistors used in each termination technique example and the transmission lines depicted represent board level components and are not meant to represent components on the device.
GTL

A sample circuit illustrating a valid termination technique for GTL is shown in Figure 2-83.

Table 2-39 lists DC voltage specifications.

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
</tr>
</thead>
<tbody>
<tr>
<td>( V_{CCO} )</td>
<td>-</td>
<td>N/A</td>
<td>-</td>
</tr>
<tr>
<td>( V_{REF} = N \times V_{TT} )</td>
<td>0.74</td>
<td>0.8</td>
<td>0.86</td>
</tr>
<tr>
<td>( V_{TT} )</td>
<td>1.14</td>
<td>1.2</td>
<td>1.26</td>
</tr>
<tr>
<td>( V_{IH} \geq V_{REF} + 0.05 )</td>
<td>0.79</td>
<td>0.85</td>
<td>-</td>
</tr>
<tr>
<td>( V_{IL} \leq V_{REF} - 0.05 )</td>
<td>-</td>
<td>0.75</td>
<td>0.81</td>
</tr>
<tr>
<td>( V_{OH} )</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>( V_{OL} )</td>
<td>-</td>
<td>0.2</td>
<td>0.4</td>
</tr>
<tr>
<td>( I_{OH} ) at ( V_{OH} ) (mA)</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>( I_{OL} ) at ( V_{OL} ) (mA) at 0.4V</td>
<td>32</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>( I_{OL} ) at ( V_{OL} ) (mA) at 0.2V</td>
<td>-</td>
<td>-</td>
<td>40</td>
</tr>
</tbody>
</table>

Notes:
1. \( N \) must be greater than or equal to 0.653 and less than or equal to 0.68.
GTL +

Figure 2-84 shows a sample circuit illustrating a valid termination technique for GTLP.

Table 2-40 lists DC voltage specifications.

### Table 2-40: GTLP Voltage Specifications

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
</tr>
</thead>
<tbody>
<tr>
<td>$V_{CCO}$</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>$V_{REF} = N \times V_T (i)$</td>
<td>0.88</td>
<td>1.0</td>
<td>1.12</td>
</tr>
<tr>
<td>$V_T$</td>
<td>1.35</td>
<td>1.5</td>
<td>1.65</td>
</tr>
<tr>
<td>$V_{IH} \geq V_{REF} + 0.1$</td>
<td>0.98</td>
<td>1.1</td>
<td>-</td>
</tr>
<tr>
<td>$V_{IL} \leq V_{REF} - 0.1$</td>
<td>-</td>
<td>0.9</td>
<td>1.02</td>
</tr>
<tr>
<td>$V_{OH}$</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>$V_{OL}$</td>
<td>0.3</td>
<td>0.45</td>
<td>0.6</td>
</tr>
<tr>
<td>$I_{OH} \text{ at } V_{OH}$ (mA)</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>$I_{OL} \text{ at } V_{OL}$ (mA) at 0.6V</td>
<td>36</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>$I_{OL} \text{ at } V_{OL}$ (mA) at 0.3V</td>
<td>-</td>
<td>-</td>
<td>48</td>
</tr>
</tbody>
</table>

**Notes:**
1. N must be greater than or equal to 0.653 and less than or equal to 0.68.
HSTL Class I

Figure 2-85 shows a sample circuit illustrating a valid termination technique for HSTL_I.

![Terminated HSTL Class I](image)

Table 2-41 lists DC voltage specifications.

<table>
<thead>
<tr>
<th>Parameter</th>
<th>MIN</th>
<th>TYP</th>
<th>MAX</th>
</tr>
</thead>
<tbody>
<tr>
<td>V_{CCO}</td>
<td>1.40</td>
<td>1.50</td>
<td>1.60</td>
</tr>
<tr>
<td>V_{REF}</td>
<td>0.68</td>
<td>0.75</td>
<td>0.90</td>
</tr>
<tr>
<td>V_{TT}</td>
<td>-</td>
<td>V_{CCO} \times 0.5</td>
<td>-</td>
</tr>
<tr>
<td>V_{IH}</td>
<td>V_{REF} + 0.1</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>V_{IL}</td>
<td>-</td>
<td>-</td>
<td>V_{REF} – 0.1</td>
</tr>
<tr>
<td>V_{OH}</td>
<td>V_{CCO} – 0.4</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>V_{OL}</td>
<td>-</td>
<td>-</td>
<td>0.4</td>
</tr>
<tr>
<td>I_{OH} at V_{OH} (mA)</td>
<td>-8</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>I_{OL} at V_{OL} (mA)</td>
<td>8</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>
HSTL Class II

Figure 2-86 shows a sample circuit illustrating a valid termination technique for HSTL_II.

![Terminated HSTL Class II](image)

Table 2-42 lists DC voltage specifications.

<table>
<thead>
<tr>
<th>Parameter</th>
<th>MIN</th>
<th>TYP</th>
<th>MAX</th>
</tr>
</thead>
<tbody>
<tr>
<td>VCCO</td>
<td>1.40</td>
<td>1.50</td>
<td>1.60</td>
</tr>
<tr>
<td>VREF (1)</td>
<td>-</td>
<td>0.75</td>
<td>-</td>
</tr>
<tr>
<td>VTT</td>
<td>-</td>
<td>CCO \times 0.5</td>
<td>-</td>
</tr>
<tr>
<td>VIH</td>
<td>VREF + 0.1</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>VIL</td>
<td>VREF - 0.1</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>VOH</td>
<td>CCO - 0.4</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>VOL</td>
<td>-</td>
<td>-</td>
<td>0.4</td>
</tr>
<tr>
<td>IOH at VOH (mA)</td>
<td>-16</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>IOL at VOL (mA)</td>
<td>16</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

Notes:
1. Per EIA/JESD8-6, “The value of VREF is to be selected by the user to provide optimum noise margin in the use conditions specified by the user.”
HSTL Class III

Figure 2-87 shows a sample circuit illustrating a valid termination technique for HSTL_III.

![Circuit Diagram]

Figure 2-87: Terminated HSTL Class III

Table 2-43 lists DC voltage specifications.

Table 2-43: HSTL Class III Voltage Specification

<table>
<thead>
<tr>
<th>Parameter</th>
<th>MIN</th>
<th>TYP</th>
<th>MAX</th>
</tr>
</thead>
<tbody>
<tr>
<td>$V_{CCO}$</td>
<td>1.40</td>
<td>1.50</td>
<td>1.60</td>
</tr>
<tr>
<td>$V_{REF}$ (1)</td>
<td>-</td>
<td>0.90</td>
<td>-</td>
</tr>
<tr>
<td>$V_{TT}$</td>
<td>-</td>
<td>$V_{CCO}$</td>
<td>-</td>
</tr>
<tr>
<td>$V_{IH}$</td>
<td>$V_{REF} + 0.1$</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>$V_{IL}$</td>
<td>-</td>
<td>-</td>
<td>$V_{REF} - 0.1$</td>
</tr>
<tr>
<td>$V_{OH}$</td>
<td>$V_{CCO} - 0.4$</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>$V_{OL}$</td>
<td>-</td>
<td>-</td>
<td>0.4</td>
</tr>
<tr>
<td>$I_{OH}$ at $V_{OH}$ (mA)</td>
<td>-8</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>$I_{OL}$ at $V_{OL}$ (mA)</td>
<td>24</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

Notes:
1. Per EIA/JESD8-6, “The value of $V_{REF}$ is to be selected by the user to provide optimum noise margin in the use conditions specified by the user.”
HSTL Class IV

Figure 2-88 shows a sample circuit illustrating a valid termination technique for HSTL_IV.

![Figure 2-88: Terminated HSTL Class IV](image)

Table 2-44 lists DC voltage specifications.

**Table 2-44: HSTL Class IV Voltage Specification**

<table>
<thead>
<tr>
<th>Parameter</th>
<th>MIN</th>
<th>TYP</th>
<th>MAX</th>
</tr>
</thead>
<tbody>
<tr>
<td>V_{CCO}</td>
<td>1.40</td>
<td>1.50</td>
<td>1.60</td>
</tr>
<tr>
<td>V_{REF}</td>
<td>-</td>
<td>0.90</td>
<td>-</td>
</tr>
<tr>
<td>V_{TT}</td>
<td>-</td>
<td>V_{CCO}</td>
<td>-</td>
</tr>
<tr>
<td>V_{IH}</td>
<td>V_{REF} + 0.1</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>V_{IL}</td>
<td>-</td>
<td>-</td>
<td>V_{REF} - 0.1</td>
</tr>
<tr>
<td>V_{OH}</td>
<td>V_{CCO} - 0.4</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>V_{OL}</td>
<td>-</td>
<td>-</td>
<td>0.4</td>
</tr>
<tr>
<td>I_{OH} at V_{OH} (mA)</td>
<td>-8</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>I_{OL} at V_{OL} (mA)</td>
<td>48</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

**Notes:**

1. Per EIA/JESD8-6, “The value of V_{REF} is to be selected by the user to provide optimum noise margin in the use conditions specified by the user.”
HSTL Class I (1.8V)

Figure 2-89 shows a sample circuit illustrating a valid termination technique for HSTL_I.

![Terminated HSTL Class I (1.8V) Circuit](image)

Table 2-45 lists DC voltage specifications.

Table 2-45: HSTL Class I (1.8V) Voltage Specification

<table>
<thead>
<tr>
<th>Parameter</th>
<th>MIN</th>
<th>TYP</th>
<th>MAX</th>
</tr>
</thead>
<tbody>
<tr>
<td>V_CCO</td>
<td>1.7</td>
<td>1.8</td>
<td>1.9</td>
</tr>
<tr>
<td>V_REF</td>
<td>0.8</td>
<td>0.9</td>
<td>1.1</td>
</tr>
<tr>
<td>V_TT</td>
<td>-</td>
<td>V_CCO x 0.5</td>
<td>-</td>
</tr>
<tr>
<td>V_IH</td>
<td>V_REF + 0.1</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>V_IL</td>
<td>-</td>
<td>-</td>
<td>V_REF - 0.1</td>
</tr>
<tr>
<td>V_OH</td>
<td>V_CCO - 0.4</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>V_OL</td>
<td>-</td>
<td>-</td>
<td>0.4</td>
</tr>
<tr>
<td>I_OH at V_OH (mA)</td>
<td>-8</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>I_OL at V_OH (mA)</td>
<td>8</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>
HSTL Class II (1.8V)

Figure 2-90 shows a sample circuit illustrating a valid termination technique for HSTL_II.

![Terminated HSTL Class II (1.8V)](image)

Table 2-46 lists DC voltage specifications.

**Table 2-46: HSTL Class II (1.8V) Voltage Specification**

<table>
<thead>
<tr>
<th>Parameter</th>
<th>MIN</th>
<th>TYP</th>
<th>MAX</th>
</tr>
</thead>
<tbody>
<tr>
<td>$V_{CCO}$</td>
<td>1.7</td>
<td>1.8</td>
<td>1.9</td>
</tr>
<tr>
<td>$V_{REF}^{(1)}$</td>
<td>-</td>
<td>0.9</td>
<td>-</td>
</tr>
<tr>
<td>$V_{TT}$</td>
<td>-</td>
<td>$V_{CCO} \times 0.5$</td>
<td>-</td>
</tr>
<tr>
<td>$V_{IH}$</td>
<td>$V_{REF} + 0.1$</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>$V_{IL}$</td>
<td>-</td>
<td>-</td>
<td>$V_{REF} - 0.1$</td>
</tr>
<tr>
<td>$V_{OH}$</td>
<td>$V_{CCO} - 0.4$</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>$V_{OL}$</td>
<td>-</td>
<td>-</td>
<td>0.4</td>
</tr>
<tr>
<td>$I_{OH}$ at $V_{OH}$ (mA)</td>
<td>-16</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>$I_{OL}$ at $V_{OL}$ (mA)</td>
<td>16</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

**Notes:**

1. Per EIA/JESD8-6, “The value of $V_{REF}$ is to be selected by the user to provide optimum noise margin in the use conditions specified by the user.”
HSTL Class III (1.8V)

Figure 2-91 shows a sample circuit illustrating a valid termination technique for HSTL_III.

![Figure 2-91: Terminated HSTL Class III (1.8V)](image)

Table 2-47 lists DC voltage specifications.

<table>
<thead>
<tr>
<th>Parameter</th>
<th>MIN</th>
<th>TYP</th>
<th>MAX</th>
</tr>
</thead>
<tbody>
<tr>
<td>$V_{CCO}$</td>
<td>1.7</td>
<td>1.8</td>
<td>1.9</td>
</tr>
<tr>
<td>$V_{REF}^{(1)}$</td>
<td>-</td>
<td>1.1</td>
<td>-</td>
</tr>
<tr>
<td>$V_{TT}$</td>
<td>-</td>
<td>$V_{CCO}$</td>
<td>-</td>
</tr>
<tr>
<td>$V_{IH}$</td>
<td>$V_{REF} + 0.1$</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>$V_{IL}$</td>
<td>-</td>
<td>-</td>
<td>$V_{REF} - 0.1$</td>
</tr>
<tr>
<td>$V_{OH}$</td>
<td>$V_{CCO} - 0.4$</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>$V_{OL}$</td>
<td>-</td>
<td>-</td>
<td>0.4</td>
</tr>
<tr>
<td>$I_{OH}$ at $V_{OH}$ (mA)</td>
<td>-8</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>$I_{OL}$ at $V_{OL}$ (mA)</td>
<td>24</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

Notes:
1. Per EIA/JESD8-6, “The value of $V_{REF}$ is to be selected by the user to provide optimum noise margin in the use conditions specified by the user.”
HSTL Class IV (1.8V)

Figure 2-92 shows a sample circuit illustrating a valid termination technique for HSTL_IV.

![Terminated HSTL Class IV (1.8V)](image)

Table 2-48 lists DC voltage specifications.

**Table 2-48: HSTL Class IV (1.8V) Voltage Specification**

<table>
<thead>
<tr>
<th>Parameter</th>
<th>MIN</th>
<th>TYP</th>
<th>MAX</th>
</tr>
</thead>
<tbody>
<tr>
<td>Vcco</td>
<td>1.7</td>
<td>1.8</td>
<td>1.9</td>
</tr>
<tr>
<td>VREF</td>
<td>-</td>
<td>1.1</td>
<td>-</td>
</tr>
<tr>
<td>VTT</td>
<td>-</td>
<td>Vcco</td>
<td>-</td>
</tr>
<tr>
<td>VIH</td>
<td>VREF + 0.1</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>VIL</td>
<td>-</td>
<td>-</td>
<td>VREF - 0.1</td>
</tr>
<tr>
<td>VOH</td>
<td>Vcco - 0.4</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>VOL</td>
<td>-</td>
<td>-</td>
<td>0.4</td>
</tr>
<tr>
<td>IOH at VOH (mA)</td>
<td>-8</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>IOL at VOL (mA)</td>
<td>48</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

**Notes:**
1. Per EIA/JESD8-6, “The value of VREF is to be selected by the user to provide optimum noise margin in the use conditions specified by the user.”
SSTL2_I

Figure 2-93 shows a sample circuit illustrating a valid termination technique for SSTL2_I.

![Terminated SSTL2_I schematic]

Figure 2-93: Terminated SSTL2_I

Table 2-49 lists DC voltage specifications.

**Table 2-49: SSTL2_I Voltage Specifications**

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
</tr>
</thead>
<tbody>
<tr>
<td>(V_{CCO})</td>
<td>2.3</td>
<td>2.5</td>
<td>2.7</td>
</tr>
<tr>
<td>(V_{REF} = 0.5 \times V_{CCO})</td>
<td>1.13</td>
<td>1.25</td>
<td>1.38</td>
</tr>
<tr>
<td>(V_{TT} = V_{REF} + N^{(1)})</td>
<td>1.11</td>
<td>1.25</td>
<td>1.39</td>
</tr>
<tr>
<td>(V_{IH} \geq V_{REF} + 0.18)</td>
<td>1.3</td>
<td>1.43</td>
<td>3.0^{(2)}</td>
</tr>
<tr>
<td>(V_{IL} \leq V_{REF} - 0.18)</td>
<td>−0.3^{(3)}</td>
<td>1.07</td>
<td>1.2</td>
</tr>
<tr>
<td>(V_{OH} \geq V_{REF} + 0.61^{(4)})</td>
<td>1.74</td>
<td>1.84</td>
<td>1.99</td>
</tr>
<tr>
<td>(V_{OL} \leq V_{REF} - 0.61^{(4)})</td>
<td>0.52</td>
<td>0.66</td>
<td>0.77</td>
</tr>
<tr>
<td>(I_{OH} \text{ at } V_{OH} (mA))</td>
<td>−8.1</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>(I_{OL} \text{ at } V_{OL} (mA))</td>
<td>8.1</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

**Notes:**
1. \(N\) must be greater than or equal to -0.04 and less than or equal to 0.04.
2. \(V_{IH}\) maximum is \(V_{CCO} + 0.3\).
3. \(V_{IL}\) minimum does not conform to the formula.
4. \(V_{OH}\) and \(V_{OL}\) will be different for SSTL2_I_DCI, because it uses a controlled-impedance driver.
SSTL2_II

Figure 2-94 shows a sample circuit illustrating a valid termination technique for SSTL2_II.

Figure 2-94: Terminated SSTL2_II

Table 2-50 lists DC voltage specifications.

Table 2-50: SSTL2_II Voltage Specifications

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
</tr>
</thead>
<tbody>
<tr>
<td>$V_{CCO}$</td>
<td>2.3</td>
<td>2.5</td>
<td>2.7</td>
</tr>
<tr>
<td>$V_{REF} = 0.5 \times V_{CCO}$</td>
<td>1.13</td>
<td>1.25</td>
<td>1.38</td>
</tr>
<tr>
<td>$V_{TT} = V_{REF} + N^{(1)}$</td>
<td>1.11</td>
<td>1.25</td>
<td>1.42</td>
</tr>
<tr>
<td>$V_{IH} \geq V_{REF} + 0.15$</td>
<td>1.30</td>
<td>1.43</td>
<td>3.0$^{(2)}$</td>
</tr>
<tr>
<td>$V_{IL} \leq V_{REF} - 0.15$</td>
<td>$-0.3^{(3)}$</td>
<td>1.07</td>
<td>1.2</td>
</tr>
<tr>
<td>$V_{OH} \geq V_{REF} + 0.8^{(4)}$</td>
<td>1.93</td>
<td>2.06</td>
<td>-</td>
</tr>
<tr>
<td>$V_{OL} \leq V_{REF} - 0.8^{(4)}$</td>
<td>-</td>
<td>0.44</td>
<td>0.55</td>
</tr>
<tr>
<td>$I_{OH}$ at $V_{OH}$ (mA)</td>
<td>$-16.2$</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>$I_{OL}$ at $V_{OL}$ (mA)</td>
<td>16.2</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

Notes:
1. $N$ must be greater than or equal to $-0.04$ and less than or equal to 0.04.
2. $V_{IH}$ maximum is $V_{CCO} + 0.3$.
3. $V_{IL}$ minimum does not conform to the formula.
4. $V_{OH}$ and $V_{OL}$ will be different for SSTL2_II DCI, because it uses a controlled-impedance driver.
SSTL18-II

Figure 2-95 shows a sample circuit illustrating a valid termination technique for SSTL18-II.

![Terminated SSTL18-II](image)

Table 2-51 lists DC voltage specifications.

**Table 2-51: SSTL18-II Voltage Specifications (JESD8-15)**

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
</tr>
</thead>
<tbody>
<tr>
<td>V_CCO</td>
<td>1.7</td>
<td>1.8</td>
<td>1.9</td>
</tr>
<tr>
<td>V_REF = 0.5 × V_CCO</td>
<td>0.833</td>
<td>0.9</td>
<td>0.969</td>
</tr>
<tr>
<td>V_TT = V_REF + N⁽¹⁾</td>
<td>0.793</td>
<td>0.9</td>
<td>1.009</td>
</tr>
<tr>
<td>V_H ≥ V_REF + 0.15</td>
<td>0.958</td>
<td></td>
<td>2.2</td>
</tr>
<tr>
<td>V_L ≤ V_REF − 0.15</td>
<td>-0.3</td>
<td></td>
<td>0.844</td>
</tr>
<tr>
<td>V_OH ≥ V_REF + 0.8⁽⁴⁾</td>
<td>1.396</td>
<td></td>
<td></td>
</tr>
<tr>
<td>V_OH ≤ V_REF − 0.8⁽⁴⁾</td>
<td></td>
<td></td>
<td>0.406</td>
</tr>
<tr>
<td>I_OH at V_OH (mA)</td>
<td>-13.4</td>
<td></td>
<td></td>
</tr>
<tr>
<td>I_OL at V_OH (mA)</td>
<td>13.4</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
PCI33_3 and PCI66_3

Table 2-52 lists DC voltage specifications.

Table 2-52: PCI33_3 and PCI66_3 Voltage Specifications

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
</tr>
</thead>
<tbody>
<tr>
<td>V_{CCO}</td>
<td>3.0</td>
<td>3.3</td>
<td>3.5</td>
</tr>
<tr>
<td>V_{REF}</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>V_{TT}</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>V_{IH} = 0.5 \times V_{CCO}</td>
<td>1.5</td>
<td>1.65</td>
<td>V_{CCO} + 0.5</td>
</tr>
<tr>
<td>V_{IL} = 0.3 \times V_{CCO}</td>
<td>-0.5</td>
<td>0.99</td>
<td>1.08</td>
</tr>
<tr>
<td>V_{OH} = 0.9 \times V_{CCO}</td>
<td>2.7</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>V_{OL} = 0.1 \times V_{CCO}</td>
<td>-</td>
<td>-</td>
<td>0.36</td>
</tr>
<tr>
<td>I_{OH} at V_{OH} (mA)</td>
<td>(Note 1)</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>I_{OL} at V_{OL} (mA)</td>
<td>(Note 1)</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

Notes:
1. Tested according to the relevant specification.

LVCMOS15

Table 2-53 lists DC voltage specifications.

Table 2-53: LVCMOS15 Voltage Specifications

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
</tr>
</thead>
<tbody>
<tr>
<td>V_{CCO}</td>
<td>-</td>
<td>1.5</td>
<td>-</td>
</tr>
<tr>
<td>V_{REF}</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>V_{TT}</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>V_{IH} = 0.7 \times V_{CCO}</td>
<td>1.05</td>
<td>-</td>
<td>1.65</td>
</tr>
<tr>
<td>V_{IL} = 0.2 \times V_{CCO}</td>
<td>-0.5</td>
<td>-</td>
<td>0.3</td>
</tr>
<tr>
<td>V_{OH} = V_{CCO} - 0.45</td>
<td>-</td>
<td>1.05</td>
<td>-</td>
</tr>
<tr>
<td>V_{OL}</td>
<td>-</td>
<td>-</td>
<td>0.4</td>
</tr>
<tr>
<td>I_{OH} at V_{OH} (mA)</td>
<td>-16</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>I_{OL} at V_{OL} (mA)</td>
<td>16</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>
LVCMOS18

Table 2-54 lists DC voltage specifications.

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
</tr>
</thead>
<tbody>
<tr>
<td>( V_{CCO} )</td>
<td>1.7</td>
<td>1.8</td>
<td>1.9</td>
</tr>
<tr>
<td>( V_{REF} )</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>( V_{TT} )</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>( V_{IH} = 0.7 \times V_{CCO} )</td>
<td>1.19</td>
<td>-</td>
<td>1.95</td>
</tr>
<tr>
<td>( V_{IL} = 0.2 \times V_{CCO} )</td>
<td>-0.5</td>
<td>-</td>
<td>0.4</td>
</tr>
<tr>
<td>( V_{OH} = V_{CCO} - 0.4 )</td>
<td>1.3</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>( V_{OL} )</td>
<td>-</td>
<td>-</td>
<td>0.4</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
</tr>
</thead>
<tbody>
<tr>
<td>( I_{OH} ) at ( V_{OH} ) (mA)</td>
<td>-16</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>( I_{OL} ) at ( V_{OL} ) (mA)</td>
<td>16</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

LVCMOS25

Table 2-55 lists DC voltage specifications.

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
</tr>
</thead>
<tbody>
<tr>
<td>( V_{CCO} )</td>
<td>2.3</td>
<td>2.5</td>
<td>2.7</td>
</tr>
<tr>
<td>( V_{REF} )</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>( V_{TT} )</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>( V_{IH} )</td>
<td>1.7</td>
<td>-</td>
<td>2.7</td>
</tr>
<tr>
<td>( V_{IL} )</td>
<td>-0.5</td>
<td>-</td>
<td>0.7</td>
</tr>
<tr>
<td>( V_{OH} )</td>
<td>1.9</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>( V_{OL} )</td>
<td>-</td>
<td>-</td>
<td>0.4</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
</tr>
</thead>
<tbody>
<tr>
<td>( I_{OH} ) at ( V_{OH} ) (mA)</td>
<td>-24</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>( I_{OL} ) at ( V_{OL} ) (mA)</td>
<td>24</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>
Digitally Controlled Impedance (DCI)

Introduction

As FPGAs get bigger and system clock speeds get faster, PC board design and manufacturing becomes more difficult. With ever faster edge rates, maintaining signal integrity becomes a critical issue. Designers must make sure that most PC board traces are terminated properly to avoid reflections or ringing.

To terminate a trace, resistors are traditionally added to make the output and/or input match the impedance of the receiver or driver to the impedance of the trace. However, due to the increase in device I/O counts, adding resistors close to the device pins increases the board area and component count, and in some cases might even be physically impossible. To address these issues and to achieve better signal integrity, Xilinx developed a new I/O technology for the Virtex-II and Virtex-II Pro device families, Digitally Controlled Impedance (DCI).

DCI adjusts the output impedance or input termination to accurately match the characteristic impedance of the transmission line. DCI actively adjusts the impedance of the I/O to equal an external reference resistance. This compensates for changes in I/O impedance due to process variation. It also continuously adjusts the impedance of the I/O to compensate for variations of temperature and supply voltage fluctuations.

In the case of controlled impedance drivers, DCI controls the driver impedance to match two reference resistors, or optionally, to match half the value of these reference resistors. DCI eliminates the need for external series termination resistors.

DCI provides the parallel or series termination for transmitters or receivers. This eliminates the need for termination resistors on the board, reduces board routing difficulties and component count, and improves signal integrity by eliminating stub reflection. Stub reflection occurs when termination resistors are located too far from the end of the transmission line. With DCI, the termination resistors are as close as possible to the output driver or the input buffer, thus, eliminating stub reflections.

Xilinx DCI

DCI uses two multi-purpose reference pins in each bank to control the impedance of the driver or the parallel termination value for all of the I/Os of that bank. The N reference pin (VRN) must be pulled up to VCCO by a reference resistor, and the P reference pin (VRP) must be pulled down to ground by another reference resistor. The value of each reference resistor should be equal to the characteristic impedance of the PC board traces, or should be twice that value (configuration option).

When a DCI I/O standard is used on a particular bank, the two multi-purpose reference pins cannot be used as regular I/Os. However, if DCI I/O standards are not used in the bank, these pins are available as regular I/O pins. Check the Virtex-II Pro pinout for detailed pin descriptions.

DCI adjusts the impedance of the I/O by selectively turning transistors in the I/Os on or off. The impedance is adjusted to match the external reference resistors. The impedance adjustment process has two phases. The first phase, which compensates for process variations, is done during the device startup sequence. The second phase, which maintains the impedance in response to temperature and supply voltage changes, begins immediately after the first phase and continues indefinitely, even while the part is operating. By default, the DONE pin does not go High until the first phase of the impedance adjustment process has completed.

If users do not wish to have the second phase enabled, they should use the FreezeDCI option in BitGen. If FreezeDCI is used, Phase One is the only impedance adjustment.
For controlled impedance output drivers, the impedance can be adjusted either to match the reference resistors or half the resistance of the reference resistors. For on-chip termination, the termination is always adjusted to match the reference resistors.

DCI can configure output drivers to be the following types:
1. Controlled Impedance Driver (Source Termination)
2. Controlled Impedance Driver with Half Impedance (Source Termination)

It can also configure inputs to have the following types of on-chip terminations:
1. Input termination to $V_{CCO}$ (Single Termination)
2. Input termination to $V_{CCO}/2$ (Split Termination, Thevenin equivalent)

For bidirectional operation, both ends of the line can be DCI-terminated permanently:
1. Driver with termination to $V_{CCO}$ (Single Termination)
2. Driver with termination to $V_{CCO}/2$ (Split Termination, Thevenin equivalent)

Alternatively, bidirectional point-to-point lines can use controlled-impedance drivers (with 3-state buffers) on both ends.

### Controlled Impedance Driver (Source Termination)

Some I/O standards, such as LVCMOS, must have a drive impedance that matches the characteristic impedance of the driven line. DCI can provide controlled impedance output drivers that eliminate reflections without an external source termination. The impedance is set by the external reference resistors, whose resistance should be equal to the trace impedance.

The DCI I/O standards that support Controlled Impedance Driver are: LVDCI_15, LVDCI_18, LVDCI_25, and LVDCI_33. Figure 2-96 illustrates a controlled impedance driver inside Virtex-II Pro device.

![Controlled Impedance Driver](UG012_C2_047_121101)

**Figure 2-96:** Controlled Impedance Driver

### Controlled Impedance Driver with Half Impedance (Source Termination)

DCI can also provide drivers with one half of the impedance of the reference resistors. The DCI I/O standards that support controlled impedance driver with half-impedance are LVDCI_DV2_15, LVDCI_DV2_18, and LVDCI_DV2_25.

Figure 2-97 illustrates a controlled driver with half impedance inside a Virtex-II Pro device. Note that reference resistors $R$ must be $2 \cdot Z_0$ in order to match an impedance of $Z_0$.

![Controlled Impedance Driver with Half Impedance](UG012_C2_052_121101)

**Figure 2-97:** Controlled Impedance Driver with Half Impedance
Input Termination to $V_{CCO}$ (Single Termination)

Some I/O standards, such as HSTL Class III, IV, etc., require an input termination to $V_{CCO}$. See Figure 2-98.

DCI can provide this termination to $V_{CCO}$ using single termination. The termination resistance is set by the reference resistors. For GTL and HSTL standards, they should be controlled by 50-ohm reference resistors. The DCI I/O standards that support single termination are: GTL_DCI, GTLP_DCI, HSTL_III_DCI, HSTL_III_DCI_18, HSTL_IV_DCI, and HSTL_IV_DCI_18.

Figure 2-99 illustrates single termination inside a Virtex-II Pro device.
Digitally Controlled Impedance (DCI)

Input Termination to $V_{CCO}/2$ (Split Termination)

Some I/O standards, such as HSTL Class I and II, require an input termination voltage of $V_{CCO}/2$. See Figure 2-100.

This is equivalent to having a split termination composed of two resistors. One terminates to $V_{CCO}$, the other to ground. The resistor values are 2R. DCI provides termination to $V_{CCO}/2$ using split termination. The termination resistance is set by the external reference resistors, i.e., the resistors to $V_{CC}$ and ground are each twice the reference resistor value. If users are planning to use HSTL or SSTL standards, the reference resistors should be 50-ohms. The DCI I/O standards that support split termination are: HSTL_I_DCI, HSTL_I_DCI_18, HSTL_II_DCI, HSTL_II_DCI_18, SSTL2_I_DCI, and SSTL2_II_DCI. Figure 2-101 illustrates split termination inside a Virtex-II Pro device.

Figure 2-100: Input Termination to $V_{CCO}/2$ without DCI

Figure 2-101: Input Termination to $V_{CCO}/2$ Using DCI Split Termination
Driver with Termination to $V_{CCO}$ (Single Termination)

Some I/O standards, such as HSTL Class IV, require an output termination to $V_{CCO}$. Figure 2-102 illustrates the output termination to $V_{CCO}$.

![Driver with Termination to VCCO without DCI](image1)

**Figure 2-102:** Driver with Termination to $V_{CCO}$ without DCI

DCI can provide this termination to $V_{CCO}$ using single termination. In this case, DCI only controls the impedance of the termination, but not the driver. If users are planning to use GTL or HSTL standards, the external reference resistors should be 50-ohms. The DCI I/O standards that support a driver with single termination are: GTL_DCI, GTLP_DCI, HSTL_IV_DCI, and HSTL_IV_DCI_18.

Figure 2-103 illustrates a driver with single termination inside a Virtex-II Pro device.

![Driver with Termination to VCCO Using DCI Single Termination](image2)

**Figure 2-103:** Driver with Termination to $V_{CCO}$ Using DCI Single Termination
Digitally Controlled Impedance (DCI)

Driver with Termination to $V_{CCO}/2$ (Split Termination)

Some I/O standards, such as HSTL Class II, require an output termination to $V_{CCO}/2$. See Figure 2-104.

![Driver with Termination to $V_{CCO}/2$ without DCI](image)

Figure 2-104:  Driver with Termination to $V_{CCO}/2$ without DCI

DCI can provide this termination to $V_{CCO}/2$ using split termination. It only controls the impedance of the termination, but not the driver. For HSTL or SSTL standards, the external reference resistors should be 50-ohms. The DCI I/O standards that support a Driver with split termination are: HSTL_II_DCI, HSTL_II_DCI_18, and SSTL2_II_DCI.

Figure 2-105 illustrates a driver with split termination inside a Virtex-II Pro device.

![Driver with Termination to $V_{CCO}/2$ Using DCI Split Termination](image)

Figure 2-105:  Driver with Termination to $V_{CCO}/2$ Using DCI Split Termination
Software Support

This section lists the valid DCI I/O buffer library components and describes how to use DCI in the Xilinx software.

DCI I/O Buffer Library Components

The DCI input buffer library components, including global clock buffer, are the following:

- IBUFGDS_LVDSEXT_25_DCI
- IBUFGDS_LVDS_25_DCI
- IBUFDS_LVDSEXT_25_DCI
- IBUFDS_LVDS_25_DCI
- IBUFG_GTLP_DCI
- IBUFG_GTL_DCI
- IBUFG_HSTL_I_DCI
- IBUFG_HSTL_II_DCI
- IBUFG_HSTL_III_DCI
- IBUFG_HSTL_IV_DCI
- IBUFG_HSTL_I_DCI_18
- IBUFG_HSTL_II_DCI_18
- IBUFG_HSTL_III_DCI_18
- IBUFG_HSTL_IV_DCI_18
- IBUFG_LVDCI_15
- IBUFG_LVDCI_18
- IBUFG_LVDCI_25
- IBUFG_LVDCI_33
- IBUFG_LVDCI_DV2_15
- IBUFG_LVDCI_DV2_18
- IBUFG_LVDCI_DV2_25
- IBUF_GTLP_DCI
- IBUF_GTL_DCI
- IBUF_HSTL_I_DCI
- IBUF_HSTL_II_DCI
- IBUF_HSTL_III_DCI
- IBUF_HSTL_IV_DCI
- IBUF_LVDCI_15
- IBUF_LVDCI_18
- IBUF_LVDCI_25
- IBUF_LVDCI_33
- IBUF_LVDCI_DV2_15
- IBUF_LVDCI_DV2_18
- IBUF_LVDCI_DV2_25
- IBUF_SSTL2_I_DCI
- IBUF_SSTL2_II_DCI

The following are DCI output buffer library components:
- OBUF_GTLP_DCI
- OBUF_GTL_DCI
- OBUF_HSTL_I_DCI
- OBUF_HSTL_II_DCI
- OBUF_HSTL_III_DCI
- OBUF_HSTL_IV_DCI
- OBUF_HSTL_I_DCI_18
- OBUF_HSTL_II_DCI_18
- OBUF_HSTL_III_DCI_18
- OBUF_HSTL_IV_DCI_18
- OBUF_LVDCI_15
- OBUF_LVDCI_18
- OBUF_LVDCI_25
- OBUF_LVDCI_33
- OBUF_LVDCI_DV2_15
- OBUF_LVDCI_DV2_18
- OBUF_LVDCI_DV2_25
- OBUF_SSTL2_I_DCI
- OBUF_SSTL2_II_DCI

The following are DCI 3-state output buffer library components:
- OBUFT_GTLP_DCI
- OBUFT_GTL_DCI
- OBUFT_HSTL_I_DCI
- OBUFT_HSTL_II_DCI
- OBUFT_HSTL_III_DCI
- OBUFT_HSTL_IV_DCI
- OBUFT_HSTL_I_DCI_18
- OBUFT_HSTL_II_DCI_18
- OBUFT_HSTL_III_DCI_18
- OBUFT_HSTL_IV_DCI_18
- OBUFT_LVDCI_15
- OBUFT_LVDCI_18
- OBUFT_LVDCI_25
- OBUFT_LVDCI_33
- OBUFT_LVDCI_DV2_15
Chapter 2: Design Considerations

- OBUFT_LVDCI_DV2_18
- OBUFT_LVDCI_DV2_25
- OBUFT_SSTL2_I_DCI
- OBUFT_SSTL2_II_DCI

The following are DCI I/O buffer library components:
- IOBUF_GTLP_DCI
- IOBUF_GTL_DCI
- IOBUF_HSTL_II_DCI
- IOBUF_HSTL_IV_DCI
- IOBUF_SSTL2_II_DCI
- IOBUF_HSTL_II_DCI_18
- IOBUF_HSTL_IV_DCI_18
- IOBUF_LVDCI_15
- IOBUF_LVDCI_18
- IOBUF_LVDCI_25
- IOBUF_LVDCI_33
- IOBUF_LVDCI_DV2_15
- IOBUF_LVDCI_DV2_18
- IOBUF_LVDCI_DV2_25

How to Use DCI in the Software

There are two ways for users to use DCI for Virtex-II Pro devices:
1. Use the IOSTANDARD attribute in the constraint file.
2. Instantiate DCI input or output buffers in the HDL code.

IOSTANDARD Attribute

The IOSTANDARD attribute can be entered through the NCF or UCF file. The syntax is as follows:

```
NET <net name> IOSTANDARD = LVDCI_25;
```

Where `<net name>` is the name between the IPAD and IBUF or OPAD or OBUF. For HDL designs, this name is the same as the port name.

The following are valid DCI attributes for output drivers:
- LVDCI_15
- LVDCI_18
- LVDCI_25
- LVDCI_33
- LVDCI_DV2_15
- LVDCI_DV2_18
- LVDCI_DV2_25

The following are valid DCI attributes for terminations:
- GTL_DCI
- GTLP_DCI
Digitally Controlled Impedance (DCI)

- HSTL_I_DCI
- HSTL_II_DCI
- HSTL_III_DCI
- HSTL_IV_DCI
- HSTL_I_DCI_18
- HSTL_II_DCI_18
- HSTL_III_DCI_18
- HSTL_IV_DCI_18
- SSTL2_I_DCI
- SSTL2_II_DCI

VHDL Example

Instantiating DCI input and output buffers is the same as instantiating any other I/O buffers. Users must make sure that the correct I/O buffer names are used and follow the standard syntax of instantiation.

For example, to instantiate a HSTL Class I output DCI buffer, the following syntax can be used:

```
HSTL_DCI_buffer: OBUF_HSTL_I_DCI port map (I=>data_out, O=>data_out_DCI);
```

Below is an example VHDL code that instantiates four 2.5V LVDCI drivers and four HSTL Class I outputs.

```
-- Module: DCI_TEST
--
-- Description: VHDL example for DCI SelectIO-Ultra
-- Device: Virtex-II Pro Family
--
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;

entity dci_test is
    port (clk, reset, ce, control : in std_logic;
        A, B : in std_logic_vector (3 downto 0);
        Dout : out std_logic_vector (3 downto 0);
        muxout : out std_logic_vector (3 downto 0));
end dci_test;

architecture dci_arch of dci_test is

--DCI output buffer component declaration
component OBUF_LVDCI_25 port (I : in std_logic; O : out std_logic);
end component;
attribute syn_black_box : boolean;
attribute black_box_pad_pin : string;
attribute syn_black_box of OBUF_LVDCI_25 : component is true;
attribute black_box_pad_pin of OBUF_LVDCI_25 : component is "O";

--HSTL Class I DCI output buffer component declaration
component OBUF_HSTL_I_DCI port (I : in std_logic; O: out std_logic);
end component;
attribute syn_black_box of OBUF_HSTL_I_DCI : component is true;
attribute black_box_pad_pin of OBUF_HSTL_I_DCI : component is "O";

signal muxout_int : std_logic_vector (3 downto 0);
signal dout_int : std_logic_vector (3 downto 0);
```

---
begin

process (clk, reset)
begin
  if (reset = '1') then
    dout_int<="0000";
  elsif (clk'event and clk='1') then
    dout_int<=dout_int+1;
  end if;
end process;

process (controls, A, B, DOUT_INT)
begin
  if (control='1') then
    muxout_int<=A and B;
  else
    muxout_int<=Dout_int;
  end if;
end process;

U0 : OBUF_LVDCI_25 port map(
    I=>dout_int(0),
    O=>dout(0));

U1 : OBUF_LVDCI_25 port map(
    I=>dout_int(1),
    O=>dout(1));

U2 : OBUF_LVDCI_25 port map(
    I=>dout_int(2),
    O=>dout(2));

U3 : OBUF_LVDCI_25 port map(
    I=>dout_int(3),
    O=>dout(3));

K0 : OBUF_HSTL_I_DCI port map(
    I=>muxout_int(0),
    O=>muxout(0));

K1 : OBUF_HSTL_I_DCI port map(
    I=>muxout_int(1),
    O=>muxout(1));

K2 : OBUF_HSTL_I_DCI port map(
    I=>muxout_int(2),
    O=>muxout(2));

K3 : OBUF_HSTL_I_DCI port map(
    I=>muxout_int(3),
    O=>muxout(3));

end dci_arch;

DCI in Virtex-II Pro Hardware

DCI works with single-ended I/O standards and the 2.5V LVDS I/O standard. DCI supports the following Virtex-II Pro standards:

LVDCI, LVDCI_DV2, GTL_DCI, GTLP_DCI, HSTL_I_DCI, HSTL_II_DCI, HSTL_III_DCI, HSTL_IV_DCI, HSTL_I_DCI_18, HSTL_II_DCI_18, HSTL_III_DCI_18, HSTL_IV_DCI_18, SSTL2_I_DCI, SSTL2_II_DCI, LVDS_25, and LVDSEXT_25.

To correctly use DCI in a Virtex-II Pro device, users must follow the following rules:
1. Virtex-II Pro I/Os can support 3.3V LVTTL and LVCMOS using LVDCI. Refer to 3.3V I/O Support, page 264, for details.

2. $V_{CCO}$ pins must be connected to the appropriate $V_{CCO}$ voltage based on the IOSTANDARDs in that bank.

3. Correct DCI I/O buffers must be used in the software either by using IOSTANDARD attributes or instantiations in the HDL code.

4. External reference resistors must be connected to multipurpose pins (VRN and VRP) in the bank. These two multipurpose pins cannot be used as regular user I/Os. Refer to the Virtex-II Pro pinouts for the specific pin locations. Pin VRN must be pulled up to $V_{CCO}$ by its reference resistor. Pin VRP must be pulled down to ground by its reference resistor.

5. The value of the external reference resistors should be selected to give the desired output impedance. If using GTL_DCI, HSTL_DCI, or SSTL_DCI I/O standards, then they should be 50 ohms.

6. The values of the reference resistors must be within the supported range (20Ω – 100Ω).

7. Follow the DCI I/O banking rules.

The DCI I/O banking rules are the following:

1. $V_{REF}$ must be compatible for all of the inputs in the same bank.

2. $V_{CCO}$ must be compatible for all of the inputs and outputs in the same bank.

3. No more than one DCI I/O standard using Single Termination type is allowed per bank.

4. No more than one DCI I/O standard using Split Termination type is allowed per bank.

5. Single Termination and Split Termination, Controlled Impedance Driver, and Controlled Impedance Driver with Half Impedance can co-exist in the same bank.

The behavior of DCI 3-state outputs is as follows:

If a LVDCI or LVDCI_DV2 driver is in 3-state, the driver is 3-stated. If a Driver with Single or Split Termination is in 3-state, the driver is 3-stated but the termination resistor remains.

The following section lists any special care actions that must be taken for each DCI I/O standard.

**LVDCI_15, LVDCI_18, LVDCI_25, LVDCI_33**

Using these buffers configures the outputs as controlled impedance drivers. The number extension at the end indicates the $V_{CCO}$ voltage that should be used. For example, 15 means $V_{CCO}$=1.5V, etc. There is no slew rate control or drive strength settings for LVDCI drivers.

**LVDCI Support for 3.3V I/O Standards**

Virtex-II Pro I/Os can support 3.3V LVTTL and LVCMOS using LVDCI_33. Refer to 3.3V I/O Support, page 264, for the details.

**LVDCI_DV2_15, LVDCI_DV2_18, LVDCI_DV2_25**

Using these buffers configures the outputs as controlled drivers with half impedance. The number extension at the end indicates the $V_{CCO}$ voltage that should be used. For example, 15 means $V_{CCO}$=1.5V, etc. There is no slew rate control or drive strength settings for LVDCI_DV2 drivers.

**GTL_DCI**

GTL does not require a $V_{CCO}$ voltage. However, for GTL_DCI, $V_{CCO}$ must be connected to 1.2V. GTL_DCI provides single termination to $V_{CCO}$ for inputs or outputs.
GTLP_DCI

GTLP does not require a V_{CCO} voltage. However, for GTLP_DCI, V_{CCO} must be connected to 1.5V. GTLP_DCI provides single termination to V_{CCO} for inputs or outputs.

HSTL_ I_DCI, HSTL_ III_DCI, HSTL_ I_DCI_18, HSTL_ III_DCI_18

HSTL_ I_DCI provides split termination to V_{CCO}/2 for inputs. HSTL_ III_DCI provides single termination to V_{CCO} for inputs.

HSTL_ II_DCI, HSTL_ IV_DCI, HSTL_ II_DCI_18, HSTL_ IV_DCI_18

HSTL_ II_DCI provides split termination to V_{CCO}/2 for inputs or outputs. HSTL_ IV_DCI provides single termination to V_{CCO} for inputs or outputs.

SSTL2_ I_DCI, SSTL2_ II_DCI

SSTL2_ I_DCI and SSTL2_ II_DCI provide split termination to V_{CCO}/2 for inputs. These I/O standards provide SSTL compatibility. Note that SSTL2_ I_DCI and SSTL2_ II_DCI have V_{OH} and V_{OL} levels that are different than non-DCI SSTL2_ I and SSTL2_ II levels.

LVDS_25_DCI, LVDSEXT_25_DCI

LVDS_25_DCI and LVDSEXT_25_DCI provide split termination for the P and N inputs only. VRP and VRN should connect to 50Ω resistors.

Equivalently, it provides 100Ω differential impedance between the LVDS inputs.

DCI Usage Examples

- Figure 2-106, page 307, provides examples illustrating the use of the HSTL_ I_DCI, HSTL_ II_DCI, HSTL_ III_DCI, and HSTL_ IV_DCI I/O standards.
- Figure 2-107, page 308, provides examples illustrating the use of the SSTL2_ I_DCI and SSTL2_ II_DCI I/O standards.
- Figure 2-108, page 309, provides examples illustrating the use of the LVDS_25_DCI and LVDSEXT_25_DCI I/O standards.
### HSTL DCI Usage Examples

<table>
<thead>
<tr>
<th></th>
<th>HSTL_I</th>
<th>HSTL_II</th>
<th>HSTL_III</th>
<th>HSTL_IV</th>
</tr>
</thead>
<tbody>
<tr>
<td>Conventional Transmit</td>
<td><img src="image1" alt="Diagram" /></td>
<td><img src="image2" alt="Diagram" /></td>
<td><img src="image3" alt="Diagram" /></td>
<td><img src="image4" alt="Diagram" /></td>
</tr>
<tr>
<td>Conventional Receive</td>
<td><img src="image5" alt="Diagram" /></td>
<td><img src="image6" alt="Diagram" /></td>
<td><img src="image7" alt="Diagram" /></td>
<td><img src="image8" alt="Diagram" /></td>
</tr>
<tr>
<td>Bidirectional</td>
<td><img src="image9" alt="Diagram" /></td>
<td><img src="image10" alt="Diagram" /></td>
<td><img src="image11" alt="Diagram" /></td>
<td><img src="image12" alt="Diagram" /></td>
</tr>
<tr>
<td>Reference Resistor</td>
<td>VRN = VRP = R = Z₀</td>
<td>VRN = VRP = R = Z₀</td>
<td>VRN = VRP = R = Z₀</td>
<td>VRN = VRP = R = Z₀</td>
</tr>
<tr>
<td>Recommended Z₀</td>
<td>50Ω</td>
<td>50Ω</td>
<td>50Ω</td>
<td>50Ω</td>
</tr>
</tbody>
</table>

*Figure 2-106: HSTL DCI Usage Examples*
### Figure 2-107: SSTL DCI Usage Examples

<table>
<thead>
<tr>
<th>Schematic Description</th>
<th>SSTL2_I or SSTL18_I</th>
<th>SSTL2_II or SSTL18_II</th>
</tr>
</thead>
<tbody>
<tr>
<td>Conventional Transmit</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Conventional Transmit Conventional</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Conventional Transmit DCI Receive</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Conventional Transmit DCI Receive</td>
<td></td>
<td></td>
</tr>
<tr>
<td>DCI Transmit DCI Receive</td>
<td></td>
<td></td>
</tr>
<tr>
<td>DCI Transmit DCI Receive</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Bidirectional</td>
<td>N/A</td>
<td></td>
</tr>
<tr>
<td>Reference Resistor</td>
<td>VRN = VRP = R = Z₀</td>
<td>VRN = VRP = R = Z₀</td>
</tr>
<tr>
<td>Recommended Z₀</td>
<td>50 Ω</td>
<td>50 Ω</td>
</tr>
</tbody>
</table>
Figure 2-108: LVDS DCI Usage Examples
Double-Data-Rate (DDR) I/O

Introduction

Virtex-II Pro devices have dedicated registers in a single IOB to implement input, output, and output with 3-state control Double-Data-Rate (DDR) registers. Input and output DDR is accomplished with the use of two registers in the IOB. A single clock triggers one register on a Low to High transition and a second register on a High to Low transition. Output DDR with 3-state requires the use of four registers in the IOB clocked in a similar fashion. Since the introduction of DLLs, Xilinx devices can generate low-skew clock signals that are 180 degrees out of phase, with a 50/50 duty cycle. These clocks reach the DDR registers in the IOB via dedicated routing resources.

Data Flow

Input DDR

Input DDR is accomplished via a single input signal driving two registers in the IOB. Both registers are clocked on the rising edge of their respective clocks. With proper clock forwarding, alternating bits from the input signal are clocked in on the rising edge of the two clocks, which are 180 degrees out of phase. Figure 2-109 depicts the input DDR registers and the signals involved.

![Figure 2-109: Input DDR](image-url)
CLK0 and CLK1 are 180 degrees out of phase. Both registers share the SET/PRE and RESET/CLR lines. As shown in Figure 2-110, alternating bits on the DATA line are clocked in via Q0 and Q1 while CE is High. The clocks are shifted out of phase by the DCM (CLK0 and CLK180 outputs) or by the inverter available on the CLK1 clock input.

![Input DDR Timing Diagram](image-url)
Output DDR

Output DDR registers are used to clock output from the chip at twice the throughput of a single rising-edge clocking scheme. Clocking for output DDR is the same as input DDR. The clocks driving both registers are 180 degrees out of phase. The DDR MUX selects the register outputs. The output consists of alternating bits from DATA_1 and DATA_2. Figure 2-111 depicts the output DDR registers and the signals involved.

Figure 2-111: Output DDR
Both registers share the SET/PRE and RESET/CLR line. Both registers share the CE line which must be High for outputs to be seen on Q1 and Q2. Figure 2-112 shows the data flow for the output DDR registers.

Figure 2-112: Output DDR Timing Diagram
Output DDR With 3-State Control

The 3-state control allows the output to have one of two values, either the output from the DDR MUX or high impedance.

The Enable signal is driven by a second DDR MUX (Figure 2-113). This application requires the instantiation of two output DDR primitives.

![Diagram of Output DDR With 3-State Control](image-url)
All four registers share the SET/PRESET and RESET/CLEAR lines. Two registers are required to accomplish the DDR task and two registers are required for the 3-state control. There are two Clock Enable signals, one for output DDRs performing the DDR function and another for the output DDRs performing the 3-state control function. Two 180 degree out of phase clocks are used. CLK1 clocks one of the DDR registers and a 3-state register. CLK2 clocks the other DDR register and the other 3-state register.

The DDR registers and 3-state registers are associated by the clock that is driving them. Therefore, the DDR register that is clocked by CLK1 is associated to the 3-state register being clocked by CLK1. The remaining two registers are associated by CLK2. If both 3-state registers are driving a logic High, the output sees a high impedance. If both 3-state registers are driving a logic Low, the output sees the values from the DDR MUX (see Figure 2-114).

Characteristics

- All registers in an IOB share the same SET/PRE and RESET/CLEAR lines.
- The 3-State and Output DDR registers have common clocks (OTCLK1 & OTCLK2).
- All signals can be inverted (with no added delay) inside the IOB.
- DDR MUXing is handled automatically within the IOB. There is no manual control of the MUX-select. This control is generated from the clock.
- When several clocks are used, and when using DDR registers, the floorplan of a design should take into account that the input clock to an IOB is shared with a pair of IOBs.

Figure 2-114: Timing Diagram for Output DDR With 3-State Control

When the 3-state registers are not driving the same logic value, the 3-state register being clocked by CLK1 is called TREG1. The other 3-state register TREG2 is clocked by CLK2. Similarly, the DDR register being clocked by CLK1 is called DREG1, and the other DDR register DREG2 is clocked by CLK2. If TREG1 is driving a logic High and TREG2 is driving a logic Low, the output sees a high impedance when CLK1 is High and the value out of DREG2 when CLK2 is High. If TREG2 is driving a logic High and TREG1 is driving a logic Low, the output sees a high impedance when CLK2 is High and the value out of DREG1 when CLK1 is High.
Library Primitives

Input DDR registers are inferred, and dedicated output DDR registers have been provided as primitives for Virtex-II Pro designs. Input DDR registers consist of two inferred registers that clock in a single data line on each edge. Generating 3-state output with DDR registers is as simple as instantiating a primitive.

\[\text{Figure 2-115: FDDRRSE Symbol: DDR Flip-Flop With Clock Enable and Synchronous Reset and Set}\]

\[\text{Figure 2-116: FDDRCPE Symbol: DDR Flip-Flop With Clock Enable and Asynchronous PRESET and CLR}\]

VHDL and Verilog Instantiation

Examples are available in VHDL and Verilog Templates, page 318.

In VHDL, each template has a component declaration section and an architecture section. Each part of the template should be inserted within the VHDL design file. The port map of the architecture section should include the design signal names.

Constraints file syntax is provided where input registers need to be used. These settings force the input DDR registers into the IOB. The output registers should be instantiated and do not require any constraints file syntax to be pushed into the IOB.
Port Signals

**FDDRRSE**

Data inputs - D0 and D1

D0 and D1 are the data inputs into the DDR flip-flop. Data on the D0 input is loaded into the flip-flop when R and S are Low and CE is High during a Low-to-High C0 clock transition. Data on the D1 input is loaded into the flip-flop when R and S are Low and CE is High during a Low-to-High C1 clock transition.

Clock Enable - CE

The enable pin affects the loading of data into the DDR flip-flop. When Low, new data is not loaded into the flip-flop. CE must be High to load new data into the flip-flop.

Clocks - C0 and C1

These two clocks are phase shifted 180 degrees (via the DLL) and allow selection of two separate data inputs (D0 and D1).

Synchronous Set - S and Synchronous Reset - R

The Reset (R) input, when High, overrides all other inputs and resets the output Low during any Low-to-High clock transition (C0 or C1). Reset has precedence over Set. When the Set (S) input is High and R is Low, the flip-flop is set, output High, during a Low-to-High clock transition (C0 or C1).

Data Output - Q

When power is applied, the flip-flop is asynchronously cleared and the output is Low. During normal operation, The value of Q is either D0 or D1. The Data Inputs description above states how the value of Q is chosen.

**FDDRCPE**

Data inputs - D0 and D1

D0 and D1 are the data inputs into the DDR flip-flop. Data on the D0 input is loaded into the flip-flop when PRE and CLR are Low and CE is High during a Low-to-High C0 clock transition. Data on the D1 input is loaded into the flip-flop when PRE and CLR are Low and CE is High during a Low-to-High C1 clock transition.

Clock Enable - CE

The enable pin affects the loading of data into the DDR flip-flop. When Low, clock transitions are ignored and new data is not loaded into the flip-flop. CE must be High to load new data into the flip-flop.

Clocks - C0 and C1

These two clocks are phase shifted 180 degrees (via the DLL) and allow selection of two separate data inputs (D0 and D1).

Asynchronous Preset - PRE and Asynchronous Clear - CLR

The Preset (PRE) input, when High, sets the Q output High. When the Clear (CLR) input is High, the output is reset to Low.

Data Output - Q

When power is applied, the flip-flop is asynchronously cleared and the output is Low. During normal operation, The value of Q is either D0 or D1. The Data Inputs description above states how the value of Q is chosen.
Initialization in VHDL or Verilog

Output DDR primitives can be initialized in VHDL or Verilog code for both synthesis and simulation. For synthesis, the attributes are attached to the output DDR instantiation and are copied in the EDIF output file to be compiled by Xilinx tools. The VHDL code simulation uses a generic parameter to pass the attributes. The Verilog code simulation uses the defparam parameter to pass the attributes.

The DDR code examples (in VHDL ad Verilog) illustrate the following techniques.

Location Constraints

DDR instances can have LOC properties attached to them to constrain pin placement. The LOC constraint uses the following form.

```
NET <net_name> LOC=A8;
```

Where “A8” is a valid I/O pin location.

Applications

DDR SDRAM

The DDR SDRAM is an enhancement to the Synchronous DRAM by effectively doubling the data throughput of the memory device. Commands are registered at every positive clock edge. Input data is registered on both edges of the data strobe, and output data is referenced to both edges of the data strobe, as well as both edges of the clock.

Clock Forwarding

DDR can be used to forward a copy of the clock on the output. This can be useful for propagating a clock along with double-data-rate data that has an identical delay. It is also useful for multiple clock generation, where there is a unique clock driver for every clock load.

VHDL and Verilog Templates

VHDL and Verilog templates are available for output, output with 3-state enable, and input DDR registers.

Input DDR

To implement an Input DDR application, paste the following template in your code.

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;

entity DDR_Input is
  Port ( clk : in std_logic;
          d : in std_logic;
          rst : in std_logic;
          q1 : out std_logic;
          q2 : out std_logic );
end DDR_Input;

architecture behavioral of DDR_Input is

--Describe input DDR registers (behaviorally) to be inferred
architecture behavioral of DDR_Input is
```
begin
q1reg : process (clk, d, rst)
begin
if rst='1' then --asynchronous reset, active high
q1 <= '0';
elsif clk'event and clk='1' then  --Clock event - posedge
q1 <= d;
end if;
end process;
q2reg : process (clk, d, rst)
begin
if rst='1' then --asynchronous reset, active high
q2 <= '0';
elsif clk'event and clk='0' then  --Clock event - negedge
q2 <= d;
end if;
end process;
end behavioral;

-- NOTE: You must include the following constraints in the .ucf
-- file when running back-end tools,
-- in order to ensure that IOB DDR registers are used:
--
-- INST "q2_reg" IOB=TRUE;
-- INST "q1_reg" IOB=TRUE;
--
-- Depending on the synthesis tools you use, it may be required to
-- check the edif file for modifications to
-- original net names...in this case, Synopsys changed the
-- names: q1 and q2 to q1_reg and q2_reg

DDR_input.v

module DDR_Input (data_in, q1, q2, clk, rst);
input data_in, clk, rst;
output q1, q2;
reg q1, q2;

//Describe input DDR registers (behaviorally) to be inferred
always @ (posedge clk or posedge rst) //rising-edge DDR reg. and
asynchronous reset
begin
if (rst)
  q1 = 1'b0;
else
  q1 = data_in;
end
always @ (negedge clk or posedge rst) //falling-edge DDR reg. and
asynchronous reset
begin
  if (rst)
    q2 = 1'b0;
  else
    q2 = data_in;
end

assign data_out = q1 & q2;
endmodule

/* NOTE: You must include the following constraints in the .ucf file when running back-end tools, \in order to ensure that IOB DDR registers are used:

INST "q2_reg" IOB=TRUE;
INST "q1_reg" IOB=TRUE;

Depending on the synthesis tools you use, it may be required to check the edif file for modifications to original net names...in this case, Synopsys changed the names: q1 and q2 to q1_reg and q2_reg
*/

Output DDR

To implement an Output DDR application, paste the following template in your code.

**DDR_out.vhd**

```vhdl
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
-- pragma translate_off
LIBRARY UNISIM;
use UNISIM.VCOMPONENTS.ALL;
--pragma translate_on

entity DDR_Output is
  Port(
    clk : in std_logic; --clk and clk180 can be outputs from the DCM or clk180 can be the
    clk180 : in std_logic; --logical inverse of clk (the inverter is located in the IOB and will be inferred.
    d0 : in std_logic; --data in to fddr
    d1 : in std_logic; --data in to fddr
    ce : in std_logic; --clock enable
    rst : in std_logic; --reset
    set : in std_logic; --set
    q : out std_logic --DDR output
  );

end DDR_Output;

architecture behavioral of DDR_Output is

component FDDRRSE
  port(
    Q  : out std_logic;
    D0 : in std_logic;
```

Double-Data-Rate (DDR) I/O

D1 : in std_logic;
C0 : in std_logic;
C1 : in std_logic;
CE : in std_logic;
R  : in std_logic;
S  : in std_logic
);
end component;

begin

U0: FDDRRSE
  port map (  
    Q => q,
    D0 => d0,
    D1 => d1,
    C0 => clk,
    C1 => clk180,
    CE => ce,
    R => rst,
    S => set
  );

end behavioral;

DDR_out.v

module DDR_Output (d0 , d1, q, clk, clk180, rst, set, ce);
input d0, d1, clk, clk180, rst, set, ce;
output q;

//Synchronous Output DDR primitive instantiation
FDDRRSE U1 ( .D0(d0),
              .D1(d1),
              .C0(clk),
              .C1(clk180),
              .CE(ce),
              .R(rst),
              .S(set),
              .Q(q)
);
endmodule

Output DDR With 3-State Enable

To implement an Output DDR with 3-state Enable, paste the following template in your code:

DDR_3state.vhd

library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
--pragma translate_off
LIBRARY UNISIM;
use UNISIM.VCOMPONENTS.ALL;
--pragma translate_on

entity DDR_3state is
  Port(
clk : in std_logic; --clk and clk180 can be outputs from the DCM or
clk180 can be the
clk180 : in std_logic; --logical inverse of clk (the inverter is
located in the IOB and will be inferred.
d0 : in std_logic; --data in to fddr
d1 : in std_logic; --data in to fddr
ce : in std_logic; --clock enable
set : in std_logic; --set
rst : in std_logic; --reset
en0 : in std_logic; --enable signal
en1 : in std_logic; --enable signal
data_out : out std_logic --data seen at pad
);

end DDR_3state;

architecture behavioral of DDR_3state is

signal ddr_out, tri : std_logic;

component FDDRRSE
port (  
Q : out std_logic;
D0 : in std_logic;
D1 : in std_logic;
C0 : in std_logic;
Cl : in std_logic;
CE : in std_logic;
R  : in std_logic;
S  : in std_logic
);
end component;

begin

--Instantiate Ouput DDR registers
U0: FDDRRSE port map(Q => tri,
  D0 => en0,
  D1 => en1,
  C0 => clk,
  C1 => clk180,
  CE => ce,
  R  => rst,
  S  => set
);

--Instantiate three-state DDR registers
U1: FDDRRSE port map( Q => ddr_out,
  D0 => d0,
  D1 => d1,
  C0 => clk,
  C1 => clk180,
  CE => ce,
  R  => rst,
  S  => set
);

--inferr the 3-State buffer
process(tri, ddr_out)
begin
  if tri = '1' then


data_out <= 'Z';
elsif tri = '0' then
  data_out <= ddr_out;
end if;
end process;

end behavioral;

DDR_3state.v

module DDR_3state (d0 , d1, data_out, en_0, en_1, clk, clk180, rst, set, ce);
input d0, d1, clk, clk180, rst, set, ce, en_0, en_1;
output data_out;
reg data_out;
wire q, q_tri;

//Synchronous Output DDR primitive instantiation
FDDRRSE U1 ( .D0(d0),
  .D1(d1),
  .C0(clk),
  .C1(clk180),
  .CE(ce),
  .R(rst),
  .S(set),
  .Q(q)
);

//Synchronous 3-State DDR primitive instantiation
FDDRRSE U2 ( .D0(en_0),
  .D1(en_1),
  .C0(clk),
  .C1(clk180),
  .CE(ce),
  .R(rst),
  .S(set),
  .Q(q_tri)
);

//3-State buffer description
always @ (q_tri or q)
begin
  if (q_tri)
    data_out = 1'bz;
  else
    data_out = q;
end
endmodule
LVDS I/O

Introduction

Low Voltage Differential Signaling (LVDS) is a very popular and powerful high-speed interface in many system applications. Virtex-II Pro I/Os are designed to comply with the EIA/TIA electrical specifications for LVDS to make system and board design easier. With the addition of an LVDS current-mode driver in the IOBs, which eliminates the need for external source termination in point-to-point applications, and with the choice of an extended mode, Virtex-II Pro devices provide the most flexible solution for doing an LVDS design in an FPGA.

Table 2-56 lists all LVDS primitives that are available for Virtex-II Pro devices.

Table 2-56: Available Virtex-II Pro LVDS Primitives

<table>
<thead>
<tr>
<th>Input</th>
<th>Output</th>
<th>3-State</th>
<th>Clock</th>
<th>Bi-Directional</th>
</tr>
</thead>
<tbody>
<tr>
<td>IBUF_LVDS</td>
<td>OBUF_LVDS</td>
<td>OBUFT_LVDS</td>
<td>IBUFG_LVDS</td>
<td>IOBUF_LVDS</td>
</tr>
<tr>
<td>IBUFDS_LVDS_25</td>
<td>OBUFDS_LVDS_25</td>
<td>OBUFTDS_LVDS_25</td>
<td>IBUFGDS_LVDS_25</td>
<td></td>
</tr>
<tr>
<td>IBUFDS_LVDSEXT_25</td>
<td>OBUFDS_LVDSEXT_25</td>
<td>OBUFTDS_LVDSEXT_25</td>
<td>IBUFGDS_LVDSEXT_25</td>
<td></td>
</tr>
<tr>
<td>IBUFDS_LVDS_25_DC1</td>
<td>OBUFDS_LVDS_25_DC1</td>
<td>OBUFTDS_LVDS_25_DC1</td>
<td>IBUFGDS_LVDS_25_DC1</td>
<td></td>
</tr>
<tr>
<td>IBUFDS_LVDSEXT_25_DC1</td>
<td>OBUFDS_LVDS_25_DC1</td>
<td>OBUFTDS_LVDS_25_DC1</td>
<td>IBUFGDS_LVDS_25_DC1</td>
<td></td>
</tr>
</tbody>
</table>

The primitives in bold type are pre-existing LVDS primitives used in Virtex-E and earlier designs. They are not current-mode drivers and are still required for BLVDS (Bus LVDS) applications.

*DS_LVDS_25 = 2.5V V_{CCO} LVDS Buffer

There are no differences in the AC characteristics of any LVDS I/O. These choices now provide more flexibility for mixed-I/O banking rules: for example, an LVCMOS I/O can coexist with the 2.5V LVDS buffer in the same bank.

*DS_LVDSEXT* = Extended mode LVDS buffer

This buffer provides a higher drive capability and voltage swing (350 - 750 mV), which makes it ideal for long-distance or cable LVDS links. The output AC characteristics of this LVDS Extended Mode driver are not within the EIA/TIA specifications. This LVDS Extended Mode driver is intended for situations that require higher drive capabilities in order to produce an LVDS signal that is within EIA/TIA specification at the receiver.

Creating an LVDS Input/Clock Buffer

Figure 2-117 illustrates the LVDS input and clock buffer primitives shown in Table 2-57. The pin names used are the same as those used in the HDL library primitives.

Table 2-57: LVDS Input and Clock Buffer Primitives

<table>
<thead>
<tr>
<th>LVDS Inputs</th>
<th>LVDS Clocks</th>
</tr>
</thead>
<tbody>
<tr>
<td>IBUFDS_LVDS_25</td>
<td>IBUFGDS_LVDS_25</td>
</tr>
<tr>
<td>IBUFDS_LVDSEXT_25</td>
<td>IBUFGDS_LVDSEXT_25</td>
</tr>
<tr>
<td>IBUFDS_LVDS_25_DC1</td>
<td>IBUFGDS_LVDS_25_DC1</td>
</tr>
<tr>
<td>IBUFDS_LVDSEXT_25_DC1</td>
<td>IBUFGDS_LVDSEXT_25_DC1</td>
</tr>
</tbody>
</table>
LVDS Input HDL Examples

VHDL Instantiation

U1: IBUFDS_LVDS_25
   port map (I => data_in_P, IB => data_in_N, O => data_in);

Verilog Instantiation

IBUFDS_LVDS_25 U1 (.I(data_in_P), .IB(data_in_N), .O(data_in))

Port Signals

I = P-channel data input to the LVDS input buffer
IB = N-channel data input to the LVDS input buffer
O = Non-differential input data from LVDS input buffer

Location Constraints

NET “data_in_P” LOC= “NS”;

LVDS Receiver Termination

All LVDS receivers require standard termination. Figure 2-118 is an example of a typical termination for an LVDS receiver on a board with 50Ω transmission lines.

Figure 2-118: LVDS Receiver Termination
Creating an LVDS Output Buffer

Figure 2-119 illustrates the LVDS output buffer primitives:

- OBUFDS_LVDS_25
- OBUFDS_LVDSEXT_25

The pin names used are the same as those used in the HDL library primitives.

![LVDS Output Buffer Primitives](UG002_C2_032_100020)

**Figure 2-119: LVDS Output Buffer Primitives**

To create an LVDS output, instantiate the desired mode (2.5 or Extended) LVDS output buffer. Notice that the P and N channels are included in the primitive (O = P, OB = N). Software automatically uses the appropriate pin from an adjacent IOB for the N channel.

LVDS Output HDL Examples

**VHDL Instantiation**

```
U1: OBUFDS_LVDS_25
    port map (   
        I => data_out,  
        O => data_out_P,  
        OB => data_out_N
    );
```

**Verilog Instantiation**

```
OBUFDS_LVDS_25 U1 ( .I(data_out),  
       .O(data_out_P),  
       .OB(data_out_N)  
    );
```

Port Signals

- I = data input to the LVDS input buffer
- O = P-channel data output
- OB = N-channel data output

Location Constraints

```
NET "data_out_P" LOC= "NS";
```

LVDS Transmitter Termination

The Virtex-II Pro LVDS transmitter does not require any termination. Table 2-56 lists primitives that correspond to the Virtex-II Pro LVDS current-mode drivers. Virtex-II Pro LVDS current-mode drivers are a true current source and produce the proper (EIA/TIA...
compliant) LVDS signal. Figure 2-120 illustrates a Virtex-II Pro LVDS transmitter on a board with 50Ω transmission lines.

![LVDS Transmitter Termination](image)

**Figure 2-120: LVDS Transmitter Termination**

### Creating an LVDS Output 3-State Buffer

Figure 2-121 illustrates the LVDS 3-state buffer primitives:

- **OBUFTDS_LVDS_25**
- **OBUFTDS_LVDSEXT_25**

The pin names used are the same as those used in the HDL library primitives.

![LVDS 3-State Primitives](image)

**Figure 2-121: LVDS 3-State Primitives**

To create an LVDS 3-State output, instantiate the desired mode (2.5V, or Extended) LVDS 3-state buffer. Notice that the P and N channels are included in the primitive (O = P, OB = N). Software automatically uses the appropriate pin from an adjacent IOB for the N channel.

### LVDS 3-State HDL Example

**VHDL Instantiation**

```vhdl
U1: OBUFTDS_LVDS_25
    port map (  
        I => data_out,  
        T => tri,  
        O => data_out_P,  
        OB => data_out_N 
    );
```

**Verilog Instantiation**

```verilog
OBUFTDS_LVDS_25 U1 (  .I(data_out),  .T(tri),
```
Port Signals

- I = data input to the 3-state output buffer
- T = 3-State control signal
- O = P-channel data output
- OB = N-channel data output

Location Constraints

```
NET "data_out_P" LOC = "NS";
```

LVDS 3-State Termination

The Virtex-II Pro LVDS 3-state buffer does not require any termination. Table 2-56 lists primitives that correspond to Virtex-II Pro LVDS current-mode drivers. These drivers are a true current source, and they produce the proper (EIA/TIA compliant) LVDS signal. Figure 2-122 illustrates a simple redundant point-to-point LVDS solution with two LVDS 3-state transmitters sharing a bus with one LVDS receiver and the required termination for the circuit.

Creating a Bidirectional LVDS Buffer

Since LVDS is intended for point-to-point applications, BLVDS (Bus-LVDS) is not an EIA/TIA standard implementation and requires careful adaptation of I/O and PCB layout design rules. The primitive supplied in the software library for bi-directional LVDS does not use the Virtex-II Pro LVDS current-mode driver. Therefore, source termination is required. Refer to XAPP243 for examples of BLVDS termination.

The following are VHDL and Verilog instantiation examples of Virtex-II Pro BLVDS primitives.

VHDL Instantiation

```vhdl
blvds_io: IOBUFDS_BLVDS_2S
port map (
  I => data_out,
  O => data_in,
  T => tri,
  IO => data_IO_P,
  IOB => data_IO_N
);
```
Verilog Instantiation

```verilog
IOBUFDS_BLVDS_25 blvds_io (.I(data_out), .O(data_in), .T(tri), .IO(data_IO_P), .IOB(data_IO_N));
```

Port Signals

- I = data output: internal logic to LVDS I/O buffer
- T = 3-State control to LVDS I/O buffer
- IO = P-channel data I/O to or from BLVDS pins
- IOB = N-channel data I/O to or from BLVDS pins
- O = Data input: off-chip data to LVDS I/O buffer

Location Constraints

Only the P or N channel must be constrained. Software automatically places the corresponding channel of the pair on the appropriate pin.

LDT

Lightning Data Transport (LDT) is a high speed interface and protocol introduced by Advanced Micro Devices. LDT is a differential signaling based interface that is very similar to LVDS. Virtex-II Pro IOBs are equipped with LDT buffers. These buffers also have corresponding software primitives as follows:

```verilog
IBUFDS_LDT_25
IBUFGDS_LDT_25
OBUFDS_LDT_25
OBUFTDS_LDT_25
```

LDT Implementation

LDT implementation is the same as LVDS with DDR, so follow all of the rules and guidelines set forth earlier in this chapter for LVDS-DDR, and replace the LVDS buffer with the corresponding LDT buffer. For more information on Virtex-II Pro LDT electrical specification, refer to the Virtex-II Pro Data Sheet.
LVPECL I/O

Introduction

Low Voltage Positive Emitter-Coupled Logic (LVPECL) is a very popular and powerful high-speed interface in many system applications. Virtex-II Pro I/Os are designed to comply with the EIA/TIA electrical specifications for 2.5V LVPECL to make system and board design easier.

Table 2-58 lists all LVPECL primitives that are available for Virtex-II Pro devices.

Table 2-58: Available Virtex-II Pro LVPECL Primitives

<table>
<thead>
<tr>
<th>Input</th>
<th>Output</th>
<th>3-State</th>
<th>Clock</th>
<th>Bi-Directional</th>
</tr>
</thead>
<tbody>
<tr>
<td>IBUFDS_LVPECL_25</td>
<td>OBUFDS_LVPECL_25</td>
<td>OBUFTDS_LVPECL_25</td>
<td>IBUFGDS_LVPECL_25</td>
<td></td>
</tr>
</tbody>
</table>

Creating an LVPECL Input/Clock Buffer

Figure 2-117 illustrates the LVPECL input and clock buffer primitives shown in Table 2-57. The pin names used are the same as those used in the HDL library primitives.

Table 2-59: LVPECL Input and Clock Buffer Primitives

<table>
<thead>
<tr>
<th>LVPECL Inputs</th>
<th>LVPECL Clocks</th>
</tr>
</thead>
<tbody>
<tr>
<td>IBUFDS_LVPECL_25</td>
<td>IBUFGDS_LVPECL_25</td>
</tr>
</tbody>
</table>

LVPECL Input HDL Examples

VHDL Instantiation

U1: IBUFDS_LVPECL_25
port map (I => data_in_P,
         IB => data_in_N,
         O => data_in
       );

Verilog Instantiation

IBUFDS_LVPECL_25 U1 (.I(data_in_P),
                      .IB(data_in_N),
                      .O(data_in)
                    );
Port Signals

I = P-channel data input to the LVDS input buffer
IB = N-channel data input to the LVDS input buffer
O = Non-differential input data from LVDS input buffer

Location Constraints

NET "data_in_P" LOC= "NS";

LVPECL Receiver Termination

All LVPECL receivers require standard termination. Figure 2-124 is an example of a typical termination for an LVPECL receiver on a board with 50Ω transmission lines.

Creating an LVPECL Output Buffer

Figure 2-125 illustrates the LVDS output buffer primitives:

- OBUFDS_LVPECL_25
- OBUFTDS_LVPECL_25

The pin names used are the same as those used in the HDL library primitives.

LVPECL Output HDL Examples

VHDL Instantiation

```
U1: OBUFDS_LVPECL_25
   port map (
      I => data_out,
      O => data_out_P,
      OB => data_out_N
   );
```

Figure 2-125: LVPECL Output Buffer Primitives

To create an LVPECL output, instantiate the desired mode LVPECL output buffer. Notice that the P and N channels are included in the primitive (O = P, OB = N). Software automatically uses the appropriate pin from an adjacent IOB for the N channel.
Verilog Instantiation

```verilog
OBUFDS_LVPECL_25U1 ( .I(data_out),
    .O(data_out_P),
    .OB(data_out_N)
);
```

Port Signals
- I = data input to the LVPECL input buffer
- O = P-channel data output
- OB = N-channel data output

Location Constraints

```verilog
NET "data_out_P" LOC= "NS";
```

LVPECL Transmitter Termination

The Virtex-II Pro LVPECL transmitter does not require any termination. Table 2-58 lists primitives that correspond to the Virtex-II Pro LVPECL drivers. Figure 2-126 illustrates a Virtex-II Pro LVPECL transmitter on a board with 50Ω transmission lines.

![LVPECL Transmitter Termination](ug012_c2_66_082902)

**Figure 2-126:** LVPECL Transmitter Termination

Bitstream Encryption

Virtex-II Pro devices have an on-chip decryptor that can be enabled to make the configuration bitstream (and thus the whole logic design) secure. The user can encrypt the bitstream in the Xilinx software, and the Virtex-II Pro chip then performs the reverse operation, decrypting the incoming bitstream, and internally recreating the intended configuration.

This method provides a very high degree of design security. Without knowledge of the encryption/decryption key or keys, potential pirates cannot use the externally intercepted bitstream to analyze, or even to clone the design. System manufacturers can be sure that their Virtex-II Pro implemented designs cannot be copied and reverse engineered. Also, IP Virtex-II Pro chips that contain the correct decryption key.

The Virtex-II Pro devices store the internal decryption keys in a few hundred bits of dedicated RAM, backed up by a small externally connected battery. At <100 nA load, the endurance of the battery is only limited by its shelf life.

The method used to encrypt the data is Data Encryption Standard (DES). This is an official standard supported by the National Institute of Standards and Technology (NIST) and the
U. S. Department of Commerce. DES is a symmetric encryption standard that utilizes a 56-bit key. Because of the increased sophistication and speed of today’s computing hardware, single DES is no longer considered to be secure. However, the Triple Data Encryption Algorithm (TDEA), otherwise known as triple DES, is authorized for use by U. S. federal organizations to protect sensitive data and is used by many financial institutions to protect their transactions. Triple DES has yet to be cracked. Both DES and triple DES are available in Virtex-II Pro devices.

What DES Is

DES and triple DES are symmetric encryption algorithms. This means that the key to encrypt and the key to decrypt are the same. The security of the data is kept by keeping the key secret. This contrasts to a public key system, like RSA or PGP. One thing to note is that Virtex-II Pro devices use DES in Cipher Block Chaining mode. This means that each block is combined with the previous encrypted block for added security. DES uses a single 56-bit key to encrypt 64-bit blocks one at a time.

How Triple DES is Different

Triple DES uses three keys (known as a key bundle or key set), and the encryption algorithm is repeated for each of those keys. If $E_K(I)$ and $D_K(I)$ denote the encryption and decryption of a data block $I$ using key $K$, the Triple DES encryption algorithm is as follows (known as E-D-E):

$$\text{Output}_{\text{encrypted}} = E_{K_3}(D_{K_2}(E_{K_1}(I)))$$

And the decryption algorithm is as follows (known as D-E-D):

$$\text{Output}_{\text{decrypted}} = D_{K_1}(E_{K_2}(D_{K_3}(I)))$$

$K_1 = K_2 = K_3$ gives the same result as single DES.

For a detailed description of the DES standard, refer to:


For a popular description of the origin and the basic concept of DES and many other older and newer encryption schemes, see the recent best-seller:


Classification and Export Considerations

Virtex-II Pro FPGAs have been classified by the U. S. Department of Commerce as an FPLD (3A001.a.7), which is the same classification as current FPGAs. Only the decryptor is on-chip and can only be used to decrypt an incoming bitstream, so the classification has not changed and no new paperwork is required. The software has been classified under ECCN#:5D002 and can be exported globally under license exception ENC. No changes to current export practices are necessary.

Creating Keys

For Virtex-II Pro, DES or triple DES (TDEA) can be used. DES uses a single 56-bit key, where triple-DES always uses three such keys. All of the keys can be chosen by the BitGen program at random, or can be explicitly specified by the user.

Virtex-II Pro devices can have six separate keys programmed into the device. A particular Virtex-II Pro device can store two sets of triple-DES keys and can thus accept alternate bitstreams from two competing IP vendors, without providing access to each other’s design. However, all of the keys must be programmed at once.

An encrypted bitstream is created by the BitGen program. Keys and key options can be chosen in two ways: by command-line arguments to BitGen, or by specifying a KeyFile...
(with the --g KeyFile command-line option). The BitGen options relevant to encryption are listed in Table 2-60.

**Table 2-60: BitGen Encryption Options**

<table>
<thead>
<tr>
<th>Option</th>
<th>Description</th>
<th>Values (default first where appropriate)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Encrypt</td>
<td>Whether to encrypt the bitstream</td>
<td>No, Yes</td>
</tr>
<tr>
<td>Key0</td>
<td>DES Key 0</td>
<td>pick, (&lt;hex string&gt;)</td>
</tr>
<tr>
<td>Key1</td>
<td>DES Key 1</td>
<td>pick, (&lt;hex string&gt;)</td>
</tr>
<tr>
<td>Key2</td>
<td>DES Key 2</td>
<td>pick, (&lt;hex string&gt;)</td>
</tr>
<tr>
<td>Key3</td>
<td>DES Key 3</td>
<td>pick, (&lt;hex string&gt;)</td>
</tr>
<tr>
<td>Key4</td>
<td>DES Key 4</td>
<td>pick, (&lt;hex string&gt;)</td>
</tr>
<tr>
<td>Key5</td>
<td>DES Key 5</td>
<td>pick, (&lt;hex string&gt;)</td>
</tr>
<tr>
<td>KeyFile</td>
<td>Location of separate key definition file</td>
<td>(&lt;string&gt;)</td>
</tr>
<tr>
<td>Keyseq0</td>
<td>Set the key sequence for key 0 (S = single, F = first, M = middle, L = last)</td>
<td>S,F,M,L</td>
</tr>
<tr>
<td>Keyseq1</td>
<td>Set the key sequence for key 1</td>
<td>S,F,M,L</td>
</tr>
<tr>
<td>Keyseq2</td>
<td>Set the key sequence for key 2</td>
<td>S,F,M,L</td>
</tr>
<tr>
<td>Keyseq3</td>
<td>Set the key sequence for key 3</td>
<td>S,F,M,L</td>
</tr>
<tr>
<td>Keyseq4</td>
<td>Set the key sequence for key 4</td>
<td>S,F,M,L</td>
</tr>
<tr>
<td>Keyseq5</td>
<td>Set the key sequence for key 5</td>
<td>S,F,M,L</td>
</tr>
<tr>
<td>StartKey</td>
<td>Key number to start decryption</td>
<td>0,3</td>
</tr>
<tr>
<td>StartCBC</td>
<td>Constant Block Chaining start value</td>
<td>(&lt;string&gt;)</td>
</tr>
</tbody>
</table>

The key sequence (Keyseq) is set to S for single key encryption, F for first key in multi-key encryption, M for middle key in multi-key encryption, and L for last key in multi-key encryption. When the KeyFile option is specified, BitGen looks in that file for all other DES key options listed above. An example for the input KeyFile using triple DES is:

```plaintext
# Comment for key file
Key 0 0x9ac28ebeb2d83b;
Key 1 pick;
Key 2 string for my key;
Key 3 0x0000000000000000;
Key 4 8774eb3ebbbf84;
Keyseq 0 F;
Keyseq 1 M;
Keyseq 2 L;
Keyseq 3 F;
Keyseq 4 M;
Keyseq 5 L;
Key StartCBC 503f2f655b1b2f82;
StartKey 0;
```

Every key is given in the output key file, with unused key locations set to "0x0000000000000000." The proper key sequence prefix is added for all used keys. The prefix is preserved for unused keys, if the user specified a value. The output key file has the same base file name as the .bit file, but with a .nky file extension.

The command line equivalent of the input key file above is as follows:
Bitstream Encryption

bitgen -g Encrypt:Yes -g Key0: 0x9ac28ebeb2d83b -g Key1:pick -g Key2:"string for my key" -g Key30x00000000000000 -g Key4:8774eb3eb4f84 -g Keyseq0:F -g Keyseq1:M -g Keyseq2:L -g Keyseq3:F -g Keyseq4:M -g Keyseq5:L -g StartCBC:503f2f655b1b2f82 -g StartKey:0 myinput.ncd

If the key file is used, the command line is as follows:

Bitgen –g Encrypt:Yes –g KeyFile: mykeyfile myinput.ncd

The output key file from either of the above inputs looks something like this:

```
Device 2v40CS144;
Key 0 0x9ac28ebeb2d83b;
Key 1 0xdb1adb5f08b972;
Key 2 0x5452032773c286;
Key 3 0x00000000000000;
Key 4 0x8774eb3eb4f84;
Key 5 0x00000000000000;
Keyseq 0 F;
Keyseq 1 M;
Keyseq 2 L;
Keyseq 3 F;
Keyseq 4 M;
Keyseq 5 L;
Key StartCBC 0x503f2f655b1b2f82;
StartKey 0;
```

In the case of the string for Key2, if the keyvalue is a character string, BitGen encodes the string into a 56-bit hex string. The same character string gives the same 56-bit hex string every time. This enables passwords or phrases to be used instead of hex strings.

The above keys are all specified as 64 bits each. The first 8 bits are used by Xilinx as header information and the following 56 bits as the key. BitGen accepts 64 bit keys, but automatically overrides the header, if necessary.

Because of security issues, the –g Compress option cannot be used with bitstream encryption. Also, partial reconfiguration is not allowed.

Loading Keys

DES keys can only be loaded through JTAG. The iMPACT™ tools have the capability to take a .nky file and program the device with the keys. In order to program the keys, a “key-access mode” is entered. When this mode is entered, all of the FPGA memory, including the keys and configuration data, is cleared. Once the keys are programmed, they cannot be reprogrammed without clearing the entire device. This “key access mode” is completely transparent to most users.

Keys are programmed using the ISC_PROGRAM instruction, as detailed in the JTAG 1532 specification. SVF generation is also supported, if keys are to be programmed using a different method, such as a microprocessor or JTAG test software.

Loading Encrypted Bitstreams

Once the device has been programmed with the correct keys, the device can be configured with an encrypted bitstream. Non-encrypted bitstreams may also be used to configure the device, and the stored keys are ignored. The method of configuration is not at all affected by encryption. Any of the modes may be used, and the signaling does not change (see Chapter 3: Configuration). However, all bitstreams must configure the entire device, since partial reconfiguration is not permitted.

Once the device has been configured with an encrypted bitstream, it cannot be reconfigured without toggling the PROG pin, cycling power, or performing the JTAG JSTART instruction. All of these events fully clear the configuration memory, but none of these events reset the keys as long as V_BATT or V_CCAUX are maintained.
**V\textsubscript{BATT}**

\( V_{\text{BATT}} \) is a separate battery voltage to allow the keys to remain programmed in the Virtex-II Pro device. \( V_{\text{BATT}} \) draws very little current (on the order of nA) to keep the keys programmed. A small watch battery is suitable (refer to \( V_{\text{BATT}} \) DC Characteristics in the [Virtex-II Pro Data Sheet](#) and the battery’s specifications to estimate its lifetime).

While the auxiliary voltage (\( V_{\text{CCAUX}} \)) is applied, \( V_{\text{BATT}} \) does not draw any current, and the battery can be removed or exchanged.

---

**CORE Generator System**

**Introduction**

This section on the Xilinx CORE Generator™ System and the Xilinx Intellectual Property (IP) Core offerings is provided as an overview of products that facilitate the Virtex-II Pro design process. For more detailed and complete information, consult the [CORE Generator Guide](#), which can be accessed online in the Xilinx software installation, as well as at the [http://toolbox.xilinx.com/docsan/xilinx4/manuals.htm](http://toolbox.xilinx.com/docsan/xilinx4/manuals.htm) site under the “Design Entry Tools” heading.

**The CORE Generator System**

The Xilinx CORE Generator System is the cataloging, customization, and delivery vehicle for IP cores targeted to Xilinx FPGAs. This tool is included with all Xilinx ISE BaseX, ISE Foundation, and ISE Alliance Series software packages. The CORE Generator provides centralized access to a catalog of ready-made IP functions ranging in complexity from simple arithmetic operators, such as adders, accumulators, and multipliers, to system-level building blocks, such as filters, transforms, and memories. Cores can be displayed alphabetically, by function, by vendor, or by type. Each core comes with its own data sheet, which documents the core’s functionality in detail.

The CORE Generator User Interface (see Figure 2-127) has direct links to key Xilinx web support pages, such as the Xilinx IP Center website ([www.xilinx.com/ipcenter](http://www.xilinx.com/ipcenter)) and Xilinx Technical Support, making it very easy to access the latest Virtex-II Pro IP releases and get helpful, up-to-date specifications and information on technical issues. Links to partner IP providers are also built into the informational GUIs for the various partner-supplied AllianceCORE products described under AllianceCORE Program, page 341.

The use of CORE Generator IP cores in Virtex-II Pro designs enables designers to shorten design time, and it also helps them realize high levels of performance and area efficiency.
without any special knowledge of the Virtex-II Pro architecture. The IP cores achieve these high levels of performance and logic density by using Xilinx Smart-IP™ technology.

Smart-IP Technology

Smart-IP technology leverages Xilinx FPGA architectural features, such as look-up tables (LUTs), distributed RAM, segmented routing and floorplanning information, as well as relative location constraints and expert logic mapping to optimize the performance of every core instance in a given Xilinx FPGA design. In the context of Virtex-II Pro cores, Smart-IP technology includes the use of the special high-performance Virtex-II Pro architectural features, such as embedded 18x18 multipliers, block memory, shift register look-up tables (SRL16’s), and special wide mux elements.

Smart-IP technology delivers:

- Physical layouts optimized for high performance
- Predictable high performance and efficient resource utilization
- Reduced power requirements through compact design and interconnect minimization
- Performance independent of device size
- Ability to use multiple cores without deterioration of performance
- Reduced compile time over competing architectures
CORE Generator Design Flow

A block diagram of the CORE Generator design flow is shown in Figure 2-128.

Note:
1. The outputs produced by the CORE Generator consist of an implementation Netlist and optional schematic symbol, HDL template files, and HDL simulation model wrapper files.

Core Types

Parameterized Cores

The CORE Generator System supplies a wide assortment of parameterized IP cores that can be customized to meet specific Virtex-II Pro design needs and size constraints. See Figure 2-129. For each parameterized core, the CORE Generator System supplies:

- A customized EDIF implementation netlist (.EDN)
- A parameterized Verilog or VHDL behavioral simulation model (.V, .VHD) and corresponding wrapper file (also .V, .VHD)
- Verilog or VHDL templates (.VEO, .VHO)
- An ISE Foundation or Viewlogic® schematic symbol

The EDIF implementation netlist is used by the Xilinx tools to implement the core. The other design files generated depend on the Design Entry settings specified (target CAE vendor, and design flow type -- schematic or HDL). Schematic symbol files are generated when a schematic design flow is specified for the project.

Parameterized HDL simulation models are provided in two separate HDL simulation libraries, one for Verilog functional simulation support, and the other for VHDL functional simulation support. The libraries, which are included as part of the Xilinx installation, are in the following locations:

- $XILINX/verilog/src/XilinxCoreLib
- $XILINX/vhdl/src/XilinxCoreLib
If using a compiled simulator, these libraries must be precompiled before performing a functional simulation of the cores. An analyze_order file describing the required compile order of these models is included with each XilinxCoreLib library, one for Verilog (verilog_analyze_order) and one for VHDL (vhdl_analyze_order).

For an HDL design flow, Verilog and VHDL templates (.VEO and .VHO files) are also provided to facilitate the integration of the core into the design for the purposes of functional simulation, synthesis, and implementation. The Verilog (.V) and VHDL (.VHD) wrapper files are also generated. The wrapper files for a particular core are compiled like normal simulation models. They convey custom parameter values to the corresponding generic, parameterized behavioral model for that core in the XilinxCoreLib library. The custom parameter values are used to tailor the behavior of the customized core.

The following is a sample VHO template:

```vhdl
component adder8
    port (  
        a: IN std_logic_VECTOR(7 downto 0);  
        b: IN std_logic_VECTOR(7 downto 0);  
        c: IN std_logic;  
        ce: IN std_logic;  
        ci: IN std_logic;  
        clr: IN std_logic;  
        s: OUT std_logic_VECTOR(8 downto 0));
    end component;

-- Synplicity black box declaration
attribute black_box : boolean;
attribute black_box_of test: component is true;

-- COMP_TAG_END ------ End COMPONENT Declaration -----------

-- The following code must appear in the VHDL architecture
-- body. Substitute your own instance name and net names.
```
Fixed Netlist Cores

The other type of Virtex-II Pro core provided by the CORE Generator is the fixed netlist core. These are preset, non-parameterized designs that are shipped with the following:

- A fixed EDIF implementation netlist (as opposed to one that is customized on the fly)
- .VEO and .VHO templates
- Non-parameterized .V and .VHD behavioral simulation models
- Schematic symbol support

Examples include the fixed netlist Xilinx FFTs and most AllianceCORE products. Since the HDL behavioral models for fixed netlist cores are not parameterized, the corresponding .VEO and .VHO template files are correspondingly simple. They do not need to pass customizing parameter values to a library behavioral model.

Xilinx IP Solutions and the IP Center

The CORE Generator works in conjunction with the Xilinx IP Center on the world wide web to provide the latest IP and software upgrades. To make the most of this resource, Xilinx highly recommends that whenever starting a design, first do a quick search of the Xilinx IP Center (www.xilinx.com/ipcenter) to see whether a ready-made core solution is already available.

A complete catalog of Xilinx cores and IP tools resides on the IP Center, including:

- LogiCORE Products
- AllianceCORE Products
- Reference Designs
- XPERTS Partner Consultants
- Design Reuse Tools

When installing the CORE Generator software, the designer gains immediate access to dozens of cores supplied by the LogiCORE Program. In addition, data sheets are available for all AllianceCORE products, and additional, separately licensed, advanced function LogiCORE products are also available. New and updated Virtex-II Pro IP for the CORE Generator can be downloaded from the IP Center and added to the CORE Generator catalog.

LogiCORE Program

LogiCORE products are designed, sold, licensed, and supported by Xilinx. LogiCORE products include a wide selection of generic, parameterized functions, such as muxes, adders, multipliers, and memory cores which are bundled with the Xilinx CORE Generator.
software at no additional cost to licensed software customers. System-level cores, such as PCI, Reed-Solomon, ADPCM, HDLC, POS-PHY, and Color Space Converters are also available as optional, separately licensed products. Probably, the most common application of the CORE Generator is to use it to quickly generate Virtex-II Pro block and distributed memories. A more detailed listing of available Virtex-II Pro LogiCORE products is available in Table 2-61 and on the Xilinx IP Center website (www.xilinx.com/ipcenter).

Types of IP currently offered by the Xilinx LogiCORE program include:

- Basic Elements: logic gates, registers, multiplexers, adders, multipliers
- Communications and Networking: ADPCM modules, HDLC controllers, ATM building blocks, forward error correction modules, and POS-PHY Interfaces
- DSP and Video Image Processing: cores ranging from small building blocks (e.g., Time Skew Buffers) to larger system-level functions (e.g., FIR Filters and FFTs)
- System Logic: accumulators, adders, subtracters, complementers, multipliers, integrators, pipelined delay elements, single and dual-port distributed and block RAM, ROM, and synchronous and asynchronous FIFOs
- Standard Bus Interfaces: PCI 64/66 (64-bit, 66 MHz), 64/33 (64-bit, 33 MHz), and 32/33 (32-bit, 3 MHz) Interfaces

AllianceCORE Program

The AllianceCORE program is a cooperative effort between Xilinx and third-party IP developers to provide additional system-level IP cores optimized for Xilinx FPGAs. To ensure a high level of quality, AllianceCORE products are implemented and verified in a Xilinx device as part of the certification process.

Xilinx develops relationships with AllianceCORE partners who can complement the Xilinx LogiCORE product offering. Where Xilinx does not offer a LogiCORE for a particular function, Xilinx partners with an AllianceCORE partner to offer that function. A large percentage of Xilinx AllianceCORE partners focus on data and telecommunication applications, as well as processor and processor peripheral designs.

Together, Xilinx and the AllianceCORE partners are able to provide an extensive library of cores to accelerate the design process. AllianceCORE products include customizable cores which can be configured to exact needs, as well as fixed netlist cores targeted toward specific applications. In many cases, partners can provide cores customized to meet the specific design needs if the primary offerings do not fit the requirements. Additionally, source code versions of the cores are often available from the partners at additional cost for those who need maximum flexibility.

The library of Xilinx and AllianceCORE IP cores allows designers to leverage the expertise of experienced designers who are well-versed in optimizing designs for Virtex-II Pro and other Xilinx architectures. This enables designers to obtain high performance and density in the target Virtex-II Pro device with a faster time to market.

Reference Designs

Xilinx offers two types of reference designs; application notes (XAPPs) developed by Xilinx, and reference designs developed through the Xilinx Reference Design Alliance Program. Both types are extremely valuable to customers looking for guidance when designing systems. Reference designs can often be used as starting points for implementing a broad spectrum of functions in Xilinx programmable logic.

Application notes developed by Xilinx usually include supporting design files. They are supplied free of charge, without technical support or warranty. To see currently available reference designs, visit the www.xilinx.com/products/logicore/refdes.htm website.

Reference designs developed through the Xilinx Reference Design Alliance Program are developed, owned, and controlled by the partners in the program. The goal of the program
is to form strategic engineering and marketing partnerships with other semiconductor manufacturers and design houses so as to assist in the development of high quality, multicomponent reference designs that incorporate Xilinx devices and demonstrate how they can operate at the system level with other specialized and general purpose semiconductors.

The reference designs in the Xilinx Reference Design Alliance Program are fully functional and applicable to a wide variety of digital electronic systems, including those used for networking, communications, video imaging, and DSP applications. Visit the www.xilinx.com/company/reference_design/referencepartners.htm website to see a list of designs currently available through this program.

XPERTS Program

Xilinx established the XPERTS Program to provide customers with access to a worldwide network of certified design consultants proficient with Xilinx Platform FPGAs, software, and IP core integration. All XPERT members are certified and have extensive expertise and experience with Xilinx technology in various vertical applications, such as communications and networking, DSP, video and image processing, system I/O interfaces, and home networking.

XPERTS partners are an integral part of Xilinx strategy to provide customers with cost-efficient design solutions, while accelerating time to market. For more information on Xilinx XPERTS Program, visit the www.xilinx.com/company/consultants/index.htm website.

Design Reuse Tools

To facilitate the archiving and sharing of IP created by different individuals and workgroups within a company, Xilinx offers the IP Capture Tool. The IP Capture Tool helps to package design modules created by individual engineers in a standardized format so that they can be cataloged and distributed using the Xilinx CORE Generator. A core can take the form of synthesizable VHDL or Verilog code, or a fixed function netlist. Once it is packaged by the IP Capture Tool and installed into the CORE Generator, the “captured” core can be shared with other designers within a company through an internal network. The IP Capture Tool is supplied as a separate utility through the Xilinx IP Center. For more information, see the www.xilinx.com/ipcenter/designreuse/ipic.htm website.

CORE Generator Summary

The CORE Generator delivers a complete catalog of IP including behavioral models, synthesis templates, and netlists with performance guaranteed by Xilinx Smart-IP technology. It is a repository for LogiCORE products from Xilinx, AllianceCORE products from Xilinx partners, and it supports Design Reuse for internally developed IP. In addition, LogiCORE products are continuously updated to add support for new Xilinx architectures, such as Virtex-II Pro. The most current IP updates are available from the Xilinx IP Center. Utilizing the CORE Generator library of parameterizable cores, designed by Xilinx for Xilinx FPGAs, the designer can enjoy the advantages of design reuse, including faster time to market and lower cost solutions. For more information, visit the Xilinx IP Center www.xilinx.com/ipcenter website.

Virtex-II Pro IP Cores Support

Table 2-61 provides a partial listing of cores available for Virtex-II Pro designs. For a complete catalog of Virtex-II Pro IP, visit the Xilinx IP Center www.xilinx.com/ipcenter website.
<table>
<thead>
<tr>
<th>Function</th>
<th>Vendor Name</th>
<th>IP Type</th>
<th>Key Features</th>
<th>Application Examples</th>
</tr>
</thead>
<tbody>
<tr>
<td>Software-Only IP:</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Memory Tests utility</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Used to test Memory Interfaces</td>
<td></td>
</tr>
<tr>
<td>VxWorks Integration / RTOS Adaptation Layer</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Delivered with each peripheral with the Device Driver</td>
<td></td>
</tr>
<tr>
<td>Board Support Package (BSP)</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>BSP for the Xilinx development board including PPC405 boot code</td>
<td></td>
</tr>
<tr>
<td>Chip Support Package (CSP)</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Configurable BSP – Delivered through Platform Generator</td>
<td></td>
</tr>
<tr>
<td>Bus Infrastructure:</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>OPB Arbiter</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>PLB Arbiter</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>PLB-OPB Bridge</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>OPB-PLB Bridge</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>OPB IPIF Modules:</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IPIF-Slave Attachment</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>IPIF-Master Attachment</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>IPIF-Address Decode</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>IPIF-Interrupt Control</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>IPIF-Read Packet FIFOs</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>IPIF-Write Packet FIFOs</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>IPIF-DMA</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>IPIF-Scatter Gather</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>Memory Interfaces:</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PLB External Memory Controller</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>SRAM &amp; FLASH interface including Flash device driver</td>
<td></td>
</tr>
<tr>
<td>OPB External Memory Controller</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>SRAM &amp; FLASH interface including Flash device driver</td>
<td></td>
</tr>
<tr>
<td>PLB DDR Controller</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>DDR Memory Controller</td>
<td></td>
</tr>
<tr>
<td>OPB BRAM Controller</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>OPB BRAM Controller</td>
<td></td>
</tr>
<tr>
<td>OPB ZBT Controller</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>ZBT Memory Controller</td>
<td></td>
</tr>
<tr>
<td>Peripherals:</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Interrupt Controller</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>UART-16550</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>UART-16450</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
</tbody>
</table>
## Table 2-61: Virtex-II Pro IP Cores Support (Continued)

<table>
<thead>
<tr>
<th>Function</th>
<th>Vendor Name</th>
<th>IP Type</th>
<th>Key Features</th>
<th>Application Examples</th>
</tr>
</thead>
<tbody>
<tr>
<td>IIC Master &amp; Slave</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>SPI Master &amp; Slave</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>Ethernet 10/100 MAC</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>ATM Utopia Level 2 Slave</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>TimeBase/Watch Dog Timer</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>Timer/Counter</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>UART - Lite</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
<tr>
<td>GPIO</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Device driver included</td>
<td></td>
</tr>
</tbody>
</table>

### Basic Elements:

<table>
<thead>
<tr>
<th>Function</th>
<th>Vendor Name</th>
<th>IP Type</th>
<th>Key Features</th>
<th>Application Examples</th>
</tr>
</thead>
<tbody>
<tr>
<td>BUFE-based Multiplexer Slice</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>1-256 bits wide</td>
<td></td>
</tr>
<tr>
<td>BUFT-based Multiplexer Slice</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>1-256 bits wide</td>
<td></td>
</tr>
<tr>
<td>Binary Counter</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>2-256 bits output width</td>
<td></td>
</tr>
<tr>
<td>Binary Decoder</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>2-256 bits output width</td>
<td></td>
</tr>
<tr>
<td>Bit Bus Gate</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>1-256 bits wide</td>
<td></td>
</tr>
<tr>
<td>Bit Gate</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>1-256 bits wide</td>
<td></td>
</tr>
<tr>
<td>Bit Multiplexer</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>1-256 bits wide</td>
<td></td>
</tr>
<tr>
<td>Bus Gate</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>1-256 bits wide</td>
<td></td>
</tr>
<tr>
<td>Bus Multiplexer</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>10 widths up to 256 bits</td>
<td></td>
</tr>
<tr>
<td>Comparator</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>1-256 bits wide</td>
<td></td>
</tr>
<tr>
<td>FD-based Parallel Register</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>1-256 bits wide</td>
<td></td>
</tr>
<tr>
<td>FD-based Shift Register</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>1-64 bits wide</td>
<td></td>
</tr>
<tr>
<td>LD-based Parallel Latch</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>1-256 bits wide</td>
<td></td>
</tr>
<tr>
<td>RAM-based Shift Register</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>1-256 bits wide, 1024 words deep</td>
<td></td>
</tr>
</tbody>
</table>

### Communication & Networking:

<table>
<thead>
<tr>
<th>Function</th>
<th>Vendor Name</th>
<th>IP Type</th>
<th>Key Features</th>
<th>Application Examples</th>
</tr>
</thead>
<tbody>
<tr>
<td>3G FEC Package</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Viterbi Decoder, Turbo Codec, Convolutional Enc</td>
<td>3G Wireless Infrastructure</td>
</tr>
<tr>
<td>3GPP Compliant Turbo Convolutional Decoder</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>3GPP specs, 2 Mb/s, BER=10^-6 for 1.5dB SNR</td>
<td>3G Wireless Infrastructure</td>
</tr>
<tr>
<td>3GPP Compliant Turbo Convolutional Encoder</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Compliant w/ 3GPP, puncturing</td>
<td>3G Wireless Infrastructure</td>
</tr>
<tr>
<td>3GPP Turbo Decoder</td>
<td>SysOnChip</td>
<td>AllianceCORE</td>
<td>3GPP/UMTS compliant, IMT-2000, 2Mb/s data</td>
<td>Error correction, wireless</td>
</tr>
<tr>
<td>8b/10b Decoder</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Industry std 8b/10b en/decode for serial data transmission</td>
<td>Physical layer of Fiber Channel</td>
</tr>
<tr>
<td>8b/10b Encoder</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Industry std 8b/10b en/decode for serial data transmission</td>
<td>Physical layer of Fiber Channel</td>
</tr>
<tr>
<td>ADPCM 1024 Channel</td>
<td>Amphion</td>
<td>AllianceCORE</td>
<td>G.721, 723, 726, 726a, 727, 727a, u-law, a-law</td>
<td>DECT, VOIP, cordless telephony</td>
</tr>
<tr>
<td>Function</td>
<td>Vendor Name</td>
<td>IP Type</td>
<td>Key Features</td>
<td>Application Examples</td>
</tr>
<tr>
<td>-----------------------------------------------</td>
<td>-------------</td>
<td>-----------------</td>
<td>---------------------------------------------------</td>
<td>---------------------------------------------</td>
</tr>
<tr>
<td>ADPCM 256 Channel</td>
<td>Amphion</td>
<td>AllianceCORE</td>
<td>G.721, 723, 726, 726a, 727, 727a, u-law, a-law</td>
<td>DECT, VOIP, cordless telephony</td>
</tr>
<tr>
<td>ADPCM 512 Channel</td>
<td>Amphion</td>
<td>AllianceCORE</td>
<td>G.721, 723, 726, 726a, 727, 727a, u-law, a-law</td>
<td>DECT, VOIP, cordless telephony</td>
</tr>
<tr>
<td>ADPCM 768 Channel</td>
<td>Amphion</td>
<td>AllianceCORE</td>
<td>G.721, 723, 726, 726a, 727, 727a, u-law, a-law</td>
<td>DECT, VOIP, cordless telephony</td>
</tr>
<tr>
<td>ADPCM Speech Codec, 32 Channel (DO-DI-ADPCM32)</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>G.726, G.727, 32 duplex channels</td>
<td>DECT, VOIP, Wireless local loop, DSLAM, PBX</td>
</tr>
<tr>
<td>ADPCM Speech Codec, 64 Channel (DO-DI-ADPCM64)</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>G.726, G.727, 64 duplex channels</td>
<td>DECT, VOIP, wireless local loop, DSLAM, PBX</td>
</tr>
<tr>
<td>BOOST LITE Bluetooth Baseband Processor</td>
<td>NewLogic</td>
<td>AllianceCORE</td>
<td>Compliant to Bluetooth v1.1, BQB qualified software for L2CAP, LHP, HC1, voice support</td>
<td>Bluetooth applications</td>
</tr>
<tr>
<td>BOOST Lite Bluetooth Baseband Processor</td>
<td>NewLogic</td>
<td>AllianceCORE</td>
<td>Compliant to Bluetooth v1.1, BQB qualified software for L2CAP, LHP, HC1, voice support</td>
<td>Bluetooth applications</td>
</tr>
<tr>
<td>Convolutional Encoder</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>k from 3 to 9, puncturing from 2/3 to 12/13</td>
<td>3G base stations, broadcast, wireless LAN, cable modem, xDSL, satellite com, uwave</td>
</tr>
<tr>
<td>DVB-RCS Turbo Decoder</td>
<td>iCODING</td>
<td>AllianceCORE</td>
<td>DVB-RCS compliant, 9 Mb/s data rate, switchable code rates and frame sizes</td>
<td>Error correction, wireless, DVB, Satellite data link</td>
</tr>
<tr>
<td>Flexbus 4 Interface Core, 16-Channel (DO-DI-FLX4C16)</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Line card: terabit routers &amp; optical switches</td>
<td></td>
</tr>
<tr>
<td>Flexbus 4 Interface Core, 4-Channel (DO-DI-FLX4C4)</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Line card: terabit routers &amp; optical switches</td>
<td></td>
</tr>
<tr>
<td>Flexbus 4 Interface Core, 1-Channel (DO-DI-FLX4C1)</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Line card: terabit routers &amp; optical switches</td>
<td></td>
</tr>
<tr>
<td>HDLC Controller Core, 32 Channels</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>32 full duplex, CRC-16/32, 8/16-bit address insertion/deletion</td>
<td>X.25, POS, cable modems, frame relay switches, video conferencing over ISDN</td>
</tr>
<tr>
<td>HDLC Controller Core, Single Channel</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>16/32-bit frame seq, 8/16-bit addr insert/delete, flag/zerop insert/detect</td>
<td>X.25, POS, cable modems, frame relay switches, video conf. over ISDN</td>
</tr>
<tr>
<td>Interleaver/De-interleaver</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Convolutional, width up to 256 bits, 256 branches</td>
<td>Broadcast, wireless LAN, cable modem, xDSL, satellite com, uwave nets, digital TV</td>
</tr>
<tr>
<td>PE-MACMII Dual Speed 10/100 Mb/s Ethernet MAC</td>
<td>Alcatel</td>
<td>AllianceCORE</td>
<td>802.3 compliant, Supports single &amp; multimode fiber optic devices, M11 interfaces, RMON and Etherstate statistics</td>
<td>Networking, Broadband, NIC, SOHO, Home networking, storage, routers, switches, printers</td>
</tr>
<tr>
<td>POS-PHY Level 3 Link Layer Interface Core, 48 Channel (DO-DI-POSL3LINK48A)</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Line card: terabit routers &amp; optical switches</td>
<td></td>
</tr>
<tr>
<td>Function</td>
<td>Vendor Name</td>
<td>IP Type</td>
<td>Key Features</td>
<td>Application Examples</td>
</tr>
<tr>
<td>------------------------------------------------------</td>
<td>-------------</td>
<td>-----------</td>
<td>------------------------------------------------------------------------------</td>
<td>-------------------------------------------------------------------------------------</td>
</tr>
<tr>
<td>POS-PHY L3 Link Layer Interface, 16-Ch (DO-DI-</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td></td>
<td>Line card: terabit routers &amp; optical switches</td>
</tr>
<tr>
<td>POSL3LINK16)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>POS-PHY L3 Link Layer Interface, 4-Ch (DO-DI-</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td></td>
<td>Line card: terabit routers &amp; optical switches</td>
</tr>
<tr>
<td>POSL3LINK4)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>POS-PHY L3 Link Layer Interface, 2-Ch (DO-DI-</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td></td>
<td>Line card: terabit routers &amp; optical switches</td>
</tr>
<tr>
<td>POSL3LINK2)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>POS-PHY L3 Link Layer Interface, Single Channel</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td></td>
<td></td>
</tr>
<tr>
<td>POS-PHY L4 Multi-Channel Interface (DO-DI-POSL4MC)</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reed-Solomon Decoder</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Std or custom coding, 3-12 bit symbol width, up to 4095 symbols</td>
<td>Broadcast, wireless LAN, digital TV, cable modem, xDSL, satellite com, uwave nets</td>
</tr>
<tr>
<td>Reed-Solomon Decoder</td>
<td>TILAB</td>
<td>AllianceCORE</td>
<td>parameterizable, RTL available</td>
<td>Error correction, wireless, DSL</td>
</tr>
<tr>
<td>Reed-Solomon Encoder</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Std or custom coding, 3-12 bit width, up to 4095 symbols with 256 check symb.</td>
<td>Broadcast, wireless LAN, digital TV, cable modem, xDSL, satellite com, uwave nets</td>
</tr>
<tr>
<td>SDLC Controller</td>
<td>CAST</td>
<td>AllianceCORE</td>
<td>Like Intel 8XC152 Global Serial Channel, Serial Comm., HDLC apps, telecom</td>
<td>Embedded systems, professional audio, video</td>
</tr>
<tr>
<td>SPEEDROUTER Network Processor</td>
<td>IP</td>
<td>AllianceCORE</td>
<td>Solution requires SPEEDAnalyzer ASIC, 2.5 Gb/s fdx wire speed; net processor (NPV)</td>
<td>Networking, edge and access, Switches and routers</td>
</tr>
<tr>
<td>Turbo Decoder - 3GPP</td>
<td>SysOnChip</td>
<td>AllianceCORE</td>
<td>3GPP/UMTS compliant, 2 Mb/s data rate</td>
<td>Error correction, wireless</td>
</tr>
<tr>
<td>Turbo Encoder</td>
<td>TILAB</td>
<td>AllianceCORE</td>
<td>3GPP/UMTS compliant, upto 4 interleaver laws</td>
<td>Error correction, wireless</td>
</tr>
<tr>
<td>TURBO_DEC Turbo Decoder</td>
<td>TILAB</td>
<td>AllianceCORE</td>
<td>3GPP/UMTS compliant, &gt;2 Mb/s data rate</td>
<td>Error correction, wireless</td>
</tr>
<tr>
<td>Viterbi Decoder</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Puncturing, serial &amp; parallel architecture, 3G base stations, broadcast,</td>
<td>L/MMDS, cable modem, broadcast equip, wireless LAN, xDSL, satellite com, uwave nets</td>
</tr>
<tr>
<td>Viterbi Decoder, IEEE 802-compatible</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Constraint length(k)=7, G0=171, G1=133</td>
<td>L/MMDS, cable modem, broadcast equip, wireless LAN, xDSL, sat com, uwave nets</td>
</tr>
<tr>
<td>Digital Signal Processing:</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1024-Point Complex FFT IFFT for Virtex-II</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>16 bit complex data, 2’s comp, forward and inverse transform</td>
<td></td>
</tr>
</tbody>
</table>

Table 2-61: Virtex-II Pro IP Cores Support (Continued)
Table 2-61: Virtex-II Pro IP Cores Support (Continued)

<table>
<thead>
<tr>
<th>Function</th>
<th>Vendor Name</th>
<th>IP Type</th>
<th>Key Features</th>
<th>Application Examples</th>
</tr>
</thead>
<tbody>
<tr>
<td>16-Point Complex FFT IFFT for Virtex-II</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>16 bit complex data, 2’s comp, forward and inverse transform</td>
<td></td>
</tr>
<tr>
<td>256-Point Complex FFT IFFT for Virtex-II</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>16 bit complex data, 2’s comp, forward and inverse transform</td>
<td></td>
</tr>
<tr>
<td>32 Point Complex FFT/IFFT</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>16 bit complex data, 2’s comp, forward and inverse transform</td>
<td></td>
</tr>
<tr>
<td>64-Point Complex FFT IFFT for Virtex-II</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>16 bit complex data, 2’s comp, forward and inverse transform</td>
<td></td>
</tr>
<tr>
<td>Bit Correlator</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>4096 taps, serial/parallel input, 4096 bits width</td>
<td></td>
</tr>
<tr>
<td>Cascaded Integrator Comb (CIC)</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>32 bits data width, rate change from 8 to 16384</td>
<td></td>
</tr>
<tr>
<td>Direct Digital Synthesizer</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>8-65K samples, 32-bits output precision, phase dithering/offset</td>
<td></td>
</tr>
<tr>
<td>Distributed Arithmetic FIR Filter</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>32-bit input/coeff width, 1024 taps, 1-8 chan, polyphase, online coeff reload</td>
<td></td>
</tr>
<tr>
<td>GVA-300 Virtex-II DSP Hardware Accelerator</td>
<td>GV</td>
<td>AllianceCORE</td>
<td>2 Virtex-II, Spartan-II FPGAs, 1 CPLD, Matlab I/F</td>
<td>DSP prototyping</td>
</tr>
<tr>
<td>LFSR, Linear Feedback Shift Register</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>168 input widths, SRL16/register implementation</td>
<td></td>
</tr>
</tbody>
</table>

Math Functions:

<table>
<thead>
<tr>
<th>Function</th>
<th>Vendor Name</th>
<th>IP Type</th>
<th>Key Features</th>
<th>Application Examples</th>
</tr>
</thead>
<tbody>
<tr>
<td>Accumulator</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>1-256s bit wide</td>
<td></td>
</tr>
<tr>
<td>Adder Subtractor</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>1-256s bit wide</td>
<td></td>
</tr>
<tr>
<td>DFP2INT Floating Point to Integer Converter</td>
<td>Digital</td>
<td>AllianceCORE</td>
<td>Full IEEE-754 compliance, 4 pipelines, Single precision real format support</td>
<td>DSP, Math, Arithmetic apps</td>
</tr>
<tr>
<td>DFPADD Floating Point Adder</td>
<td>Digital</td>
<td>AllianceCORE</td>
<td>Full IEEE-754 compliance, 4 pipelines, Single precision real format support</td>
<td>DSP, Math, Arithmetic apps</td>
</tr>
<tr>
<td>DFPCOMP Floating Point Comparator</td>
<td>Digital</td>
<td>AllianceCORE</td>
<td>Full IEEE-754 compliance, 4 pipelines, Single precision real format support</td>
<td>DSP, Math, Arithmetic apps</td>
</tr>
<tr>
<td>DFPDIV Floating Point Divider</td>
<td>Digital</td>
<td>AllianceCORE</td>
<td>Full IEEE-754 compliance, 15 pipelines, Single precision real format support</td>
<td>DSP, Math, Arithmetic apps</td>
</tr>
<tr>
<td>DFPMUL Floating Point Multiplier</td>
<td>Digital</td>
<td>AllianceCORE</td>
<td>Full IEEE-754 compliance, 7 pipelines,32x32 mult, Single precision real format support</td>
<td>DSP, Math, Arithmetic apps</td>
</tr>
</tbody>
</table>
## Table 2-61: Virtex-II Pro IP Cores Support (Continued)

<table>
<thead>
<tr>
<th>Function</th>
<th>Vendor Name</th>
<th>IP Type</th>
<th>Key Features</th>
<th>Application Examples</th>
</tr>
</thead>
<tbody>
<tr>
<td>DFPSQRT Floating Point Square Root</td>
<td>Digital</td>
<td>AllianceCORE</td>
<td>Full IEEE-754 compliance, 4 pipelines, Single precision real format support</td>
<td>DSP, Math, Arithmetic apps</td>
</tr>
<tr>
<td>DINT2FP Integer to Floating Point Converter</td>
<td>Digital</td>
<td>AllianceCORE</td>
<td>Full IEEE-754 compliance, double word input, 2 pipelines, Single precision real output</td>
<td>DSP, Math, Arithmetic apps</td>
</tr>
<tr>
<td>Multiply Accumulator (MAC)</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Input width up to 32 bits, 65-bit accumulator, truncation rounding</td>
<td></td>
</tr>
<tr>
<td>Multiply Generator</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>64-bit input data width, constant, reloadable or variable inputs, parallel/sequential implementation</td>
<td></td>
</tr>
<tr>
<td>Pipelined Divider</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>32-bit input data width, multiple clock per output</td>
<td></td>
</tr>
<tr>
<td>Sine Cosine Look Up Table</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>3-10 bit in, 4-32 bit out, distributed/block ROM</td>
<td></td>
</tr>
<tr>
<td>Twos Complementer</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Input width up to 256 bits</td>
<td></td>
</tr>
</tbody>
</table>

### Memories & Storage Elements:

<table>
<thead>
<tr>
<th>Function</th>
<th>Vendor Name</th>
<th>IP Type</th>
<th>Key Features</th>
<th>Application Examples</th>
</tr>
</thead>
<tbody>
<tr>
<td>Asynchronous FIFO</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>1-256 bits, 15-65535 words, DRAM or BRAM, independent I/O clock domains</td>
<td></td>
</tr>
<tr>
<td>Content Addressable Memory (CAM)</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>1-512 bits, 2-10K words, SRL16</td>
<td></td>
</tr>
<tr>
<td>Distributed Memory</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>1-1024 bit, 16-65536 word, RAM/ROM/SRL16, opt output regs and pipelining</td>
<td></td>
</tr>
<tr>
<td>Dual-Port Block Memory</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>1-256 bits, 2-13K words</td>
<td></td>
</tr>
<tr>
<td>Single-Port Block Memory</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>1-256 bits, 2-128K words</td>
<td></td>
</tr>
<tr>
<td>Synchronous FIFO</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>1-256 bits, 16-256 words, distributed/block RAM</td>
<td></td>
</tr>
</tbody>
</table>

### Microprocessors, Controllers & Peripherals:

<table>
<thead>
<tr>
<th>Function</th>
<th>Vendor Name</th>
<th>IP Type</th>
<th>Key Features</th>
<th>Application Examples</th>
</tr>
</thead>
<tbody>
<tr>
<td>10/100 Ethernet MAC</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Interfaces through OPB to MicroBlaze™</td>
<td>Networking, comm., processor applications</td>
</tr>
<tr>
<td>AX1610 16-bit RISC Processor</td>
<td>Loarant</td>
<td>AllianceCORE</td>
<td>44 opcode, 64-K word data, program, Harvard arch.</td>
<td>Control functions, State mach, Coprocessor</td>
</tr>
<tr>
<td>C165X MicroController</td>
<td>CAST</td>
<td>AllianceCORE</td>
<td>Microchip 16C5X PIC like</td>
<td>Embedded systems, telecom</td>
</tr>
<tr>
<td>C68000 Microprocessor</td>
<td>CAST</td>
<td>AllianceCORE</td>
<td>MC68000 Compatible</td>
<td>Embedded systems, pro audio, video</td>
</tr>
<tr>
<td>CPU FPGA (Virtex-II) MicroEngine Cards</td>
<td>NMI</td>
<td>AllianceCORE</td>
<td>Hitachi SH-3 CPU</td>
<td>Embedded systems</td>
</tr>
<tr>
<td>CZ80CPU Microprocessor</td>
<td>CAST</td>
<td>AllianceCORE</td>
<td>Zilog Z80 compatible, 8-bit processor</td>
<td>Embedded systems, Communications</td>
</tr>
<tr>
<td>Function</td>
<td>Vendor Name</td>
<td>IP Type</td>
<td>Key Features</td>
<td>Application Examples</td>
</tr>
<tr>
<td>-------------------------------</td>
<td>---------------</td>
<td>---------------</td>
<td>-------------------------------------------------------------------------------</td>
<td>-----------------------------------------------------------</td>
</tr>
<tr>
<td>DDR SDRAM Controller Core</td>
<td>Memec-Core</td>
<td>AllianceCORE</td>
<td>DDR SDRAM burst length support for 2,4,8 per access, supports data 16,32, 64, 72.</td>
<td>Digital video, embedded computing, networking</td>
</tr>
<tr>
<td>DFPIC125X Fast RISC Micro-Controller</td>
<td>Digital</td>
<td>AllianceCORE</td>
<td>PIC 12c4x like, 2X faster, 12-bit wide instruction set, 33 instructions</td>
<td>Embedded systems, telecom, audio and video</td>
</tr>
<tr>
<td>DFPIC1655X Fast RISC Micro-Controller</td>
<td>Digital</td>
<td>AllianceCORE</td>
<td>S/W compatible with PIC16C55X, 14-bit instruction set, 35 instructions</td>
<td>Embedded systems, telecom, audio and video</td>
</tr>
<tr>
<td>DFPIC165X Fast RISC Micro-Controller</td>
<td>Digital</td>
<td>AllianceCORE</td>
<td>PIC 12c4x like, 2X faster, 12-bit wide instruction set, 33 instructions</td>
<td>Embedded systems, telecom, audio and video</td>
</tr>
<tr>
<td>DI2CM I2C Bus Controller Master</td>
<td>Digital</td>
<td>AllianceCORE</td>
<td>I2C-like, multi master, fast/std. modes</td>
<td>Embedded systems</td>
</tr>
<tr>
<td>DI2CM I2C Bus Controller Slave</td>
<td>Digital</td>
<td>AllianceCORE</td>
<td>I2C-like, Slave</td>
<td>Embedded</td>
</tr>
<tr>
<td>DI2CSB I2C Bus Controller Slave Base</td>
<td>Digital</td>
<td>AllianceCORE</td>
<td>I2C-like, Slave</td>
<td>Embedded Systems</td>
</tr>
<tr>
<td>DR8051 RISC MicroController</td>
<td>Digital</td>
<td>AllianceCORE</td>
<td>80C31 instruction set, RISC architecture 6.7X faster than standard 8051</td>
<td>Embedded systems, telecom, video</td>
</tr>
<tr>
<td>DR8051BASE RISC MicroController</td>
<td>Digital</td>
<td>AllianceCORE</td>
<td>80C31 instruction set, high speed multiplier, RISC architecture 6.7X faster than standard 8051</td>
<td>Embedded systems, telecom, video</td>
</tr>
<tr>
<td>DR8052EX RISC MicroController</td>
<td>Digital</td>
<td>AllianceCORE</td>
<td>80C31 instruction set, high speed multi/div, RISC 6.7X faster than standard 8051</td>
<td>Embedded systems, telecom, video</td>
</tr>
<tr>
<td>e8254 Programmable Interval Timer/Counter</td>
<td>einfochips</td>
<td>AllianceCORE</td>
<td>Three 8-bit parallel ports, 24 programmable IO lines, 8-bit bidi data bus</td>
<td>Processor, I/O interface</td>
</tr>
<tr>
<td>e8255 Peripheral Interface</td>
<td>einfochips</td>
<td>AllianceCORE</td>
<td>Three 8-bit parallel ports, 24 programmable IO lines, 8-bit bidi data bus</td>
<td>Processor, I/O interface</td>
</tr>
<tr>
<td>Flip805x-PS Microprocessor</td>
<td>Dolphin</td>
<td>AllianceCORE</td>
<td>Avg 8X faster &amp; code compatible v. legacy 8051, verification bus monitor, SFR IF, DSP focused</td>
<td>DSP, Telecom, industrial, high speed control</td>
</tr>
<tr>
<td>IIC Master and Slave</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Interfaces through OPB to MicroBlaze™</td>
<td>Networking, com, processor applic</td>
</tr>
<tr>
<td>LavaCORE Configurable Java Processor Core</td>
<td>Derivation</td>
<td>AllianceCORE</td>
<td>32b data/address optional DES</td>
<td>Internet appliance, industrial control</td>
</tr>
<tr>
<td>LavaCORE Configurable Java Processor Core</td>
<td>Derivation</td>
<td>AllianceCORE</td>
<td>32b data/address optional DES</td>
<td>Internet appliance, industrial control</td>
</tr>
<tr>
<td>Lightfoot 32-bit Java Processor Core</td>
<td>Digital</td>
<td>AllianceCORE</td>
<td>32bit data, 24 bit address, 3 Stage pipeline, Java/C dev. tools</td>
<td>Internet appliance, industrial control, HAVi multimedia, set top boxes</td>
</tr>
</tbody>
</table>
## Table 2-61: Virtex-II Pro IP Cores Support (Continued)

<table>
<thead>
<tr>
<th>Function</th>
<th>Vendor Name</th>
<th>IP Type</th>
<th>Key Features</th>
<th>Application Examples</th>
</tr>
</thead>
<tbody>
<tr>
<td>MicroBlaze™ Soft RISC Processor</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Soft RISC Processor, small footprint</td>
<td>Networking, communications</td>
</tr>
<tr>
<td>OPB Arbiter</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Bundled in the MicroBlaze Development Kit</td>
<td>Processor applications</td>
</tr>
<tr>
<td>OPB GPIO</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Bundled in the MicroBlaze Development Kit</td>
<td>Processor applications</td>
</tr>
<tr>
<td>OPB Interrupt Controller</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Bundled in the MicroBlaze Development Kit</td>
<td>Processor applications</td>
</tr>
<tr>
<td>OPB Memory Interface (Flash, SRAM)</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Bundled in the MicroBlaze Development Kit</td>
<td>Processor applications</td>
</tr>
<tr>
<td>OPB Timer/Counter</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Bundled in the MicroBlaze Development Kit</td>
<td>Processor applications</td>
</tr>
<tr>
<td>OPB UART (16450, 16550)</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Interfaces through OPB to MicroBlaze</td>
<td>Processor applications</td>
</tr>
<tr>
<td>OPB UART Lite</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Bundled in the MicroBlaze Development Kit</td>
<td>Processor applications</td>
</tr>
<tr>
<td>OPB WDT</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Bundled in the MicroBlaze Development Kit</td>
<td>Processor applications</td>
</tr>
<tr>
<td>PF3100 PC/104-Plus Reconfigurable Module</td>
<td>Derivation</td>
<td>AllianceCORE</td>
<td>PC/104 &amp; PC/104+ development board</td>
<td>Internet appliance, industrial control</td>
</tr>
<tr>
<td>SPI</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>Interfaces through OPB to MicroBlaze</td>
<td>Networking, communications, processor applications</td>
</tr>
<tr>
<td>XF-UART Asynchronous Communications Core</td>
<td>Memec-Core</td>
<td>AllianceCORE</td>
<td>UART and baud rate generator</td>
<td>Serial data communication</td>
</tr>
</tbody>
</table>

### Standard Bus Interfaces:

- **PCI32 Virtex Interface Design Kit (DO-DI-PCI32-DKT)**
  - Vendor: Xilinx
  - IP Type: LogiCORE
  - Key Features: Includes PCI32 board, drive development kit, and customer education 3-day training class
  - Application Examples: PC add-in boards, CPCI, Embedded

- **PCI32 Virtex Interface, IP Only (DO-DI-PCI32-IP)**
  - Vendor: Xilinx
  - IP Type: LogiCORE
  - Key Features: v2.2 comp, assured PCI timing, 3.3/5-V, 0-waitstate, CPCI hot swap friendly
  - Application Examples: PC boards, CPCI, Embedded, hiperf video, gb ethernet

- **PCI64 & PCI32, IP Only (DO-DI-PCI-AL)**
  - Vendor: Xilinx
  - IP Type: LogiCORE
  - Key Features: v2.2 comp, assured PCI timing, 3.3/5-V, 0-waitstate, CPCI hot swap friendly
  - Application Examples: PC boards, CPCI, Embedded, hiperf video, gb ethernet

- **PCI64 Virtex Interface Design Kit (DO-DI-PCI64-DKT)**
  - Vendor: Xilinx
  - IP Type: LogiCORE
  - Key Features: v2.2 comp, assured PCI timing, 3.3/5-V, 0-waitstate, CPCI hot swap friendly
  - Application Examples: PC boards, CPCI, Embedded, hiperf video, gb ethernet

- **PCI64 Virtex Interface, IP Only (DO-DI-PCI64-IP)**
  - Vendor: Xilinx
  - IP Type: LogiCORE
  - Key Features: v2.2 comp, assured PCI timing, 3.3/5-V, 0-waitstate, CPCI hot swap friendly
  - Application Examples: PC boards, CPCI, Embedded, hiperf video, gb ethernet

- **RapidIO 8-bit port LP-LVDS Phy Layer (DO-DI-RIO8-PHY)**
  - Vendor: Xilinx
  - IP Type: LogiCORE
  - Key Features: RapidIO Interconnect v1.1 compliant, verified with Motorola’s RapidIO bus functional model v1.4
  - Application Examples: Routers, switches, backplane, control plane, data path, embedded sys, high speed interface to memory and encryption engines, high end video
### Table 2-61: Virtex-II Pro IP Cores Support (Continued)

<table>
<thead>
<tr>
<th>Function</th>
<th>Vendor Name</th>
<th>IP Type</th>
<th>Key Features</th>
<th>Application Examples</th>
</tr>
</thead>
<tbody>
<tr>
<td>USB 1.1 Device Controller</td>
<td>Memec-Core</td>
<td>AllianceCORE</td>
<td>Compliant with USB1.1 spec., Supports VCI bus, Performs CRC, Supports 1.5 Mb/s &amp; 12 Mb/s</td>
<td>Scanners, Printers, Handhelds, Mass Storage</td>
</tr>
</tbody>
</table>

#### Video & Image Processing:

<table>
<thead>
<tr>
<th>Function</th>
<th>Vendor Name</th>
<th>IP Type</th>
<th>Key Features</th>
<th>Application Examples</th>
</tr>
</thead>
<tbody>
<tr>
<td>1-D Discrete Cosine Transform</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td>8-24 bits for coeff &amp; input, 8-64 pts</td>
<td></td>
</tr>
<tr>
<td>2-D DCT/IDCT Forward/Inverse Discrete Cosine Transform</td>
<td>Xilinx</td>
<td>LogiCORE</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FASTJPEG_BW Decoder</td>
<td>BARCOSILEX</td>
<td>AllianceCORE</td>
<td>Conforms to ISO/IEC Baseline 10918-1, Gray-Scale</td>
<td>Video editing, digital camera, scanners</td>
</tr>
<tr>
<td>FASTJPEG_C Decoder</td>
<td>BARCOSILEX</td>
<td>AllianceCORE</td>
<td>Conforms to ISO/IEC Baseline 10918-1, color, multi-scan, Gray-Scale</td>
<td>Video editing, digital camera, scanners</td>
</tr>
</tbody>
</table>
Chapter 3

Configuration

Summary

This chapter covers the following topics:

- Introduction
- Configuration Solutions
- Master Serial Programming Mode
- Slave Serial Programming Mode
- Master SelectMAP Programming Mode
- Slave SelectMAP Programming Mode
- JTAG/ Boundary Scan Programming Mode
  - Boundary-Scan for Virtex-II Pro Devices Using IEEE Standard 1149.1
  - Boundary-Scan for Virtex-II Pro Devices Using IEEE Standard 1532
- Configuration Details
- Readback

Introduction

Virtex-II Pro devices are configured by loading application-specific configuration data into internal memory. Configuration is carried out using a subset of the device pins, some of which are dedicated, while others can be reused as general-purpose inputs and outputs after configuration is complete.

Depending on the system design, several configuration modes are selectable via mode pins. The mode pins M2, M1, and M0 are dedicated pins. An additional pin, HSWAP_EN, is used in conjunction with the mode pins to select whether user I/O pins have pull-up resistors during configuration. By default, HSWAP_EN is tied High (internal pull-up resistor), which shuts off pull-up resistors on the user I/O pins during configuration. When HSWAP_EN is tied Low, the pull-up resistors are on and therefore, the user I/Os have pull-up resistors during configuration.

Other dedicated pins are:

- CCLK - the configuration clock pin
- DONE - configuration status pin
- TDI, TDO, TMS, TCK - boundary-scan pins
- PROG_B - configuration reset pin
Depending on the configuration mode selected, CCLK can be an output generated by the Virtex-II Pro FPGA or an input accepting externally generated clock data. For correct operation, these pins require a \( V_{C_{\text{CAUX}}} \) of 2.5V to permit LVCMOS operations.

All dual-function configuration pins are contained in banks 4 and 5. Bank 4 contains pins used in serial configuration modes, and banks 4 and 5 contain pins used for SelectMAP modes.

A persist option is available, which can be used to force pins to retain their configuration function even after device configuration is complete. If the persist option is not selected, then the configuration pins with the exception of CCLK, PROG_B, and DONE can be used for user I/O in normal operation. The persist option does not apply to boundary-scan related pins. The persist feature is valuable in applications that employ partial reconfiguration, dynamic reconfiguration, or readback.

### Configuration Modes

Virtex-II Pro supports the following configuration modes:

- Master-Serial
- Slave-Serial (default)
- Master SelectMAP
- Slave SelectMAP
- Boundary-Scan (IEEE 1532 and IEEE 1149)

Table 3-1 shows Virtex-II Pro configuration mode pin settings.

<table>
<thead>
<tr>
<th>Configuration Mode</th>
<th>M2</th>
<th>M1</th>
<th>M0</th>
<th>CCLK Direction</th>
<th>Data Width</th>
<th>Serial Dout</th>
</tr>
</thead>
<tbody>
<tr>
<td>Master Serial</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>Out</td>
<td>1</td>
<td>Yes</td>
</tr>
<tr>
<td>Slave Serial</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>In</td>
<td>1</td>
<td>Yes</td>
</tr>
<tr>
<td>Master SelectMAP</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>Out</td>
<td>8</td>
<td>No</td>
</tr>
<tr>
<td>Slave SelectMAP</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>In</td>
<td>8</td>
<td>No</td>
</tr>
<tr>
<td>Boundary Scan</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>N/A</td>
<td>1</td>
<td>No</td>
</tr>
</tbody>
</table>

Notes:
1. The HSWAP_EN pin controls the pullups. Setting M2, M1, and M0 selects the configuration mode, while the HSWAP_EN pin controls whether or not the pullups are used.
2. Daisy chaining is possible only in modes where Serial Dout is used. For example, in SelectMAP modes, the first device does NOT support daisy chaining of downstream devices.

Table 3-2 lists the total number of bits required to configure each device.

<table>
<thead>
<tr>
<th>Device</th>
<th>Total Number of Configuration Bits</th>
<th>Device</th>
<th>Total Number of Configuration Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>XC2VP2</td>
<td>1,305,440</td>
<td>XC2VP40</td>
<td>15,868,256</td>
</tr>
<tr>
<td>XC2VP4</td>
<td>3,006,560</td>
<td>XC2VP50</td>
<td>19,021,408</td>
</tr>
<tr>
<td>XC2VP7</td>
<td>4,485,472</td>
<td>XC2VP70</td>
<td>26,099,040</td>
</tr>
<tr>
<td>XC2VP20</td>
<td>8,214,624</td>
<td>XC2VP100</td>
<td>34,292,832</td>
</tr>
<tr>
<td>XC2VP30</td>
<td>11,589,984</td>
<td>XC2VP125</td>
<td>43,602,784</td>
</tr>
</tbody>
</table>
Configuration Process and Flow

The configuration process involves loading the configuration bitstream into the FPGA using the selected mode. There are four major phases in the configuration process:

- Clearing Configuration Memory
- Initialization
- Loading Configuration Data
- Device Startup

Figure 3-1 illustrates the configuration process flow.

*Note: If power-up is at room temperature, VCCO-4 > or = 1.5V is acceptable.

Figure 3-1: Configuration Process
Power Up

The $V_{CCINT}$ power pins must be supplied with a 1.5V source. (Refer to the Virtex-II Pro Data Sheet for DC characteristics.) The IOB voltage input for Bank 4 ($V_{CCO_4}$) and the auxiliary voltage input ($V_{CCAUX}$) are also used as a logic input to the Power-On-Reset (POR) circuitry. Even if this bank is not being used, $V_{CCO_4}$ must be connected to a 1.5V or greater source.

Clearing Configuration Memory

In the memory clear phase, non-configuration I/O pins are 3-stated with optional pull-up resistors. The INIT_B and DONE pins are driven Low by the FPGA, and the memory is cleared. After PROG_B transitions High, memory is cleared twice and initialization can begin.

The INIT_B pin transitions High when the clearing of configuration memory is complete. A logic Low on the PROG_B input resets the configuration logic and holds the FPGA in the clear configuration memory state. When PROG_B is released, the FPGA continues to hold INIT_B Low until it has completed clearing all of the configuration memory. The minimum Low pulse time for PROG_B is defined by the $T_{PROGRAM}$ timing parameter. There is no maximum value. The power-up timing of configuration signals is shown in Figure 3-2 and the corresponding timing characteristics are listed in Table 3-3.

![Power-Up Timing Configuration Signals](ds022_020_022900)

**Figure 3-2:** Power-Up Timing Configuration Signals

**Table 3-3:** Power-Up Timing Characteristics

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Value</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Program Latency</td>
<td>$T_{PL}$</td>
<td>4 µs per frame max</td>
<td></td>
</tr>
<tr>
<td>Power-on-Reset</td>
<td>$T_{POR}$</td>
<td>ms, max</td>
<td></td>
</tr>
<tr>
<td>CCLK (output) Delay</td>
<td>$T_{ICCK}$</td>
<td>µs, min</td>
<td>µs, max</td>
</tr>
<tr>
<td>Program Pulse Width</td>
<td>$T_{PROGRAM}$</td>
<td>ns, min</td>
<td></td>
</tr>
</tbody>
</table>
Initialization

For the initialization phase, the INIT_B pin is released, the mode pins are sampled, the appropriate pins become active, and the configuration process begins. It is possible to delay configuration by externally holding INIT_B Low.

Delaying Configuration

The INIT_B pin can also be held Low externally to delay configuration of the FPGA. The FPGA samples its mode pins on the rising edge of INIT_B. After INIT_B transitions to High, configuration can begin. No additional time-out or waiting periods are required, but configuration does not need to commence immediately after the transition of INIT_B. The configuration logic does not begin processing data until the synchronization word from the bitstream is loaded.

Loading Configuration Data

Once configuration begins, the target FPGA starts to receive data frames. Cyclic Redundancy Checking (CRC) is performed before and after the last data frame. CRC is also automatically checked after each block write to an internal data register (FDRI). If the CRC checks prove valid, the device start-up phase can begin.

If the CRC values do not match, INIT_B is asserted Low to indicate that a CRC error has occurred, startup is aborted, and the FPGA does not become active.

To reconfigure the device, the PROG_B pin should be asserted to reset the configuration logic. Recycling power also resets the FPGA for configuration. For more information on CRC calculation, see "Cyclic Redundancy Checking Algorithm" on page 403.

The details of loading configuration data in each of the five modes are discussed in the following sections:

- Master Serial Programming Mode, page 368
- Master SelectMAP Programming Mode, page 371
- Slave Serial Programming Mode, page 369
- Slave SelectMAP Programming Mode, page 373
- JTAG/ Boundary Scan Programming Mode, page 377
Device Startup

Device startup is a transition phase from the configuration mode to normal programmed device operation. Although the order of the start-up events are user programmable via software, the default sequence of events is as follows:

Upon completion of the start-up sequence, the target FPGA is operational.

The Start-Up Sequencer is an 8-phase sequential state machine that counts from phase 0 to phase 7. (See Figure 3-3.)

The Start-Up Sequencer performs the following tasks:

- Release the DONE pin.
- Negate GTS, activating all of the I/Os.
- Assert GWE, allowing all RAMs and flip-flops to change state.
- Assert EOS. The End-Of-Start-Up flag is always set in phase 7. This is an internal flag that is not user accessible.

BitGen options control the order of the Start-Up Sequence. The default Start-Up Sequence is the bold line in Figure 3-3. The Start-Up Sequence can also be stalled at any phase until either DONE has been externally forced High, or a specified DCM or DCI has established LOCK. For details, see Appendix A, “BitGen and PROMGen Switches and Options.”

At the cycle selected for the DONE to be released, the sequencer always waits in that state until the DONE is externally released. However, this does not delay the GTS or GWE if they are selected to be released prior to DONE. Therefore, DONE is selected first in the sequence for default settings.

<table>
<thead>
<tr>
<th>Start-upCLK</th>
<th>Phase</th>
<th>DONE</th>
<th>GTS</th>
<th>GWE</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>1</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>3</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>4</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>5</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>6</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>7</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Figure 3-3: Default Start-Up Sequence**
**Configuration Pins**

Certain pins in the FPGA are designated for configuration and are listed in Table 3-4. Some pins are dedicated to the configuration function and others are dual-function pins that can be user I/O after configuration.

**Table 3-4: Configuration Pins**

<table>
<thead>
<tr>
<th>Name</th>
<th>Direction</th>
<th>Driver Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CCLK</td>
<td>Input/Output</td>
<td>Active</td>
<td>Configuration clock. Output in Master mode.</td>
</tr>
<tr>
<td>PROG_B</td>
<td>Input</td>
<td></td>
<td>Asynchronous reset to configuration logic.</td>
</tr>
<tr>
<td>DONE</td>
<td>Input/Output</td>
<td>Active/Open-Drain</td>
<td>Configuration status and start-up control.</td>
</tr>
<tr>
<td>M2, M1, M0</td>
<td>Input</td>
<td></td>
<td>Configuration mode selection.</td>
</tr>
<tr>
<td>HSWAP_EN</td>
<td>Input</td>
<td></td>
<td>I/O pullups during configuration.</td>
</tr>
<tr>
<td>TMS</td>
<td>Input</td>
<td></td>
<td>Boundary Scan Mode Select.</td>
</tr>
<tr>
<td>TCK</td>
<td>Input</td>
<td></td>
<td>Boundary Scan Clock.</td>
</tr>
<tr>
<td>TDI</td>
<td>Input</td>
<td></td>
<td>Boundary Scan Data Input.</td>
</tr>
<tr>
<td>TDO</td>
<td>Output</td>
<td>Open-Drain</td>
<td>Boundary Scan Data Output.</td>
</tr>
</tbody>
</table>

**Dedicated Pins**

**Dual Function Pins**

<table>
<thead>
<tr>
<th>Name (D0)</th>
<th>Input/Output</th>
<th>Active Bidirectional</th>
<th>Serial configuration data input/SelectMAP readback data output.</th>
</tr>
</thead>
<tbody>
<tr>
<td>D1:D7</td>
<td>Input/Output</td>
<td>Active Bidirectional</td>
<td>SelectMAP configuration data input, readback data output.</td>
</tr>
<tr>
<td>CS_B</td>
<td>Input</td>
<td></td>
<td>Chip Select (SelectMAP mode only).</td>
</tr>
<tr>
<td>RDWR_B</td>
<td>Input</td>
<td></td>
<td>Active Low write select, read select (SelectMAP mode only).</td>
</tr>
<tr>
<td>BUSY/DOUT</td>
<td>Output</td>
<td>Active</td>
<td>Serial configuration data output for serial daisy chains (active).</td>
</tr>
<tr>
<td>INIT_B</td>
<td>Input/Output</td>
<td>Open-Drain</td>
<td>Delay configuration, indicate configuration error.</td>
</tr>
</tbody>
</table>

**Mixed Voltage Environments**

Virtex-II Pro devices have separate voltage sources. \( V_{CCINT} \) (1.5V) powers the internal circuitry. \( V_{CCAUX} \) (2.5V) powers the input buffers and auxiliary circuitry. \( V_{CCO} \) (1.5V, 1.8V, 2.5V, or 3.3V) powers the IOB circuitry. SelectIO™-Ultra is separated into eight banks of I/O groups. Each bank can be configured with one of several I/O standards. Refer to the Design Considerations section for I/O banking rules and available I/O standards. Before and during configuration, all I/O banks are set for the LVCMOS standard, which requires an output voltage \( (V_{CCO}) \) of 2.5V for normal operation.
All dedicated configuration pins are powered by \( \text{VCCAUX} \). All dual-function configuration pins are located within banks 4 and 5. As described under Configuration Process and Flow, the \( \text{VCCO}_4 \) input voltage is used as a logic input to the power-on-reset (POR) circuitry.

For JTAG configuration mode, JTAG inputs are independent of \( \text{VCCO} \) and work between 2.5V and 3.3V TTL levels (\( \text{VIL}_{\text{max}} = 0.8\text{V}, \text{VIH}_{\text{min}} = 2.0\text{V} \)). The JTAG input pins are 3.3V tolerant. The JTAG output (TDO) is an open-drain output and must be pulled up to the appropriate voltage level (typically 3.3V) through an external resistor. The value of the external pullup resistor depends on the capacitive loading on the TDO pin and the operating frequency, but it should not be less than 200Ω. The optimal TDO pullup value can be determined through IBIS simulation.

For serial configuration mode, \( \text{VCCO}_4 \) pins require a 2.5V supply for output configuration pins to operate normally. In serial mode, all of the configuration pins are in bank 4.

For SelectMAP configuration mode, \( \text{VCCO}_4 \) and \( \text{VCCO}_5 \) pins require a 2.5V supply for output configuration pins to operate normally. In SelectMAP mode, all of the configuration pins are in banks 4 and 5.

If the Virtex-II Pro device is being configured in serial or SelectMAP mode, and banks 4 and 5 are being configured for an I/O standard that requires a \( \text{VCCO} \) other than 2.5V, then \( \text{VCCO}_4 \) and \( \text{VCCO}_5 \) (SelectMAP only) must be switched from 2.5V and used during configuration at the same voltage required after configuration. If readback is performed using SelectMAP mode after configuration, then \( \text{VCCO}_4 \) and \( \text{VCCO}_5 \) require a 2.5V supply after configuration, as well.

### Table 3-5: Configuration Modes and \( \text{VCCO} \) Voltages

<table>
<thead>
<tr>
<th>Configuration Mode</th>
<th>Pins Used</th>
<th>( \text{VCCO}_4 )</th>
<th>( \text{VCCO}_5 )</th>
</tr>
</thead>
<tbody>
<tr>
<td>JTAG</td>
<td>Dedicated Pins</td>
<td>not a concern</td>
<td>not a concern</td>
</tr>
<tr>
<td>Serial</td>
<td>Dedicated Pins plus DOUT, DIN, and INIT</td>
<td>2.5V</td>
<td>not a concern</td>
</tr>
<tr>
<td>SelectMAP</td>
<td>Dedicated Pins plus dual-function pins</td>
<td>2.5V</td>
<td>2.5V</td>
</tr>
</tbody>
</table>

Configuration Solutions

Several configuration solutions are available to support Virtex-II Pro devices, each targeted to specific application requirements. Guidance and support (application notes, reference designs, and so forth) is also available for designers looking to develop and implement their own configuration solution for Virtex FPGAs.

System Advanced Configuration Environment (System ACE™) Series

The System ACE series of configuration solutions offers a system-level configuration manager for designers using multiple FPGAs or FPGAs requiring multiple bitstreams. This solution combines standard industry Flash storage with Xilinx-designed configuration control. Features common to the entire System ACE family include:

- Support for multiple bitstreams
- Built-in support for embedded processors in FPGAs
- Support for reconfiguring, updating, or debugging systems over a network
- Built-in system interface
- Scalability (density) and reusability (across many designs)
Centralization of configuration control for reduced board space and simpler debugging
Use of excess storage capacity for non-configuration, system storage

System ACE CF

System ACE CF (CompactFlash™) solution combines a standard CompactFlash Association (CFA) Type-I or Type-II memory module (CompactFlash or 1” disk drive) with a Xilinx-designed ACE Controller™ configuration control chip. See Figure 3-4.

The CompactFlash card stores an unlimited number of bitstreams and ranges in density from 128 Mb to 3 Gb. This card is capable of storing one large bitstream or several smaller bitstreams. If several bitstreams are used, the system can be set up so that individual bitstreams are callable as needed, allowing for dynamic reconfiguration of the Virtex-II Pro device and other Xilinx FPGAs in the JTAG chain.

The ACE Controller drives bits through the FPGA JTAG chain and has three other ports:

- A port for interfacing with a microprocessor, a network, or a MultiLINX cable
- A port for interfacing with the CompactFlash card
- A port that provides access to the FPGA JTAG chain for FPGA testing or configuration via automatic test equipment or via desktop or third-party programmers

For further information on any System ACE product, visit the [www.xilinx.com/systemace](http://www.xilinx.com/systemace) website.

System ACE Multi-Package Module (MPM)

System ACE MPM is a multi-package module consisting of a packaged standard Flash from AMD, a packaged FPGA, and a packaged configuration PROM, all in a 388-pin BGA package. The Flash stores configuration and other data, while the FPGA acts as an advanced configuration controller and is configured by the PROM. This solution provides high density and high-speed configuration capability in a single package, helping to simplify the design and manufacturing process. It is available in 16 Mb, 32 Mb, and 64 Mb densities.
System ACE Soft Controller (SC)

System ACE SC is a downloadable version of the configuration controller found in System ACE MPM; versions are provided that support various standard Flash interfaces. System ACE SC provides all of the features of System MPM without the Single Package. It allows designers to use the Flash memory already in their system to store configuration data. The System ACE SC controller is available free of charge in the form of a PROM file that can be downloaded from the System ACE website. This pre-engineered solution is implemented by connecting up to four Flash chips on a board to an FPGA that will be used as a configuration controller and then downloading the controller file into a PROM. Figure 3-5 describes the controller for both System ACE MPM and System ACE SC.

**Figure 3-5: System ACE MPM/SC Controller**

System ACE MPM and System ACE SC have these unique features:

- High speed configuration up to 154 Mb/s
- Support for both SelectMAP (8-bit) (see Figure 3-6) and Slave Serial (1-bit) (see Figure 3-7) configuration
- Configuration of multiple FPGAs in parallel
- Bitstream compression for increased storage capability
- Storage of up to 8 different bitstreams
Figure 3-6: SelectMAP (8-bit) Configuration

Figure 3-7: Slave Serial (1-bit) Configuration
Chapter 3: Configuration

Configuration PROMs

Using XC18V00 PROMs

The XC18V00 family of Flash in-system programmable (ISP) configuration PROMs offers the flexibility of re-programmability and multiple package offerings, combined with both serial and SelectMAP FPGA configurability. This family is JTAG programmable and ranges in density from 256 Kb to 4 Mb; these PROMs can also be cascaded to support larger bitstreams.

The 18V00 family offers data throughput rates of up to 264 Mb/s. It is also capable of triggering FPGA reconfiguration via a JTAG command. The parts can be JTAG programmed via cable, HW-130, or standard third party programmers. The XC18V00 PROMs are available in SO20, PC20, VQ44, and PC44 packages. Refer to Appendix B, XC18V00 Series PROMs for the latest version of the XC18V00 PROMs data sheet and package diagrams for the entire PROM family. See Table 3-6 to determine which PROMs go with which Virtex-II Pro FPGAs.

Using XC17V00 PROMs

The XC17V00 family of one-time programmable (OTP) PROMs provides a proven, low-cost, compact, and pre-engineered configuration solution. Ranging from 1 Mb to 16 Mb, this family is also the PROM density leader; it can also be daisy-chained to support larger bitstreams. This family supports serial configuration of Virtex-II Pro FPGAs; in addition, the XC17V08 and XC17V16 support SelectMAP configuration modes.

The XC17V00 family can be used for stabilized designs that are in a high-volume production flow and/or for designs requiring a low-cost solution. XC17V00 PROMs can be programmed either by using the HW-130 or by using a variety of third-party programmers. The XC17V00 PROMs are available in VO8, SO20, PC20, VQ44, and PC44 packages. Data sheets for PROMs are available at www.xilinx.com. See Table 3-6 to determine which PROMs go with which Virtex-II Pro FPGAs and see Appendix B, XC18V00 Series PROMs for package diagrams.

Flash PROMs With a CPLD Configuration Controller

Some designers prefer to leverage existing Flash memory in their system to store the configuration bitstreams. A small CPLD-based configuration controller can provide the mechanism to access the bitstreams in the FLASH and deliver them quickly to Virtex-II Pro devices. The following application notes describe the details for a serial or SelectMAP configuration architecture using FLASH memories and CPLDs:

- XAPP079, Configuring Xilinx FPGAs Using an XC9500 CPLD and Parallel PROM (www.xilinx.com/apps/xappsumm.htm#xapp079) describes an architecture that configures a chain of Virtex-II Pro devices using Master-Serial mode. See Figure 3-8 for an example of FPGA configuration using a CPLD and a parallel PROM.
Figure 3-8: Configuring Virtex-II Pro Devices Using a CPLD and Parallel PROM

- **XAPP137**, Configuring Virtex FPGAs From Parallel EPROMs With a CPLD (www.xilinx.com/apps/xappsumm.htm#xapp137) describes an architecture that configures one or more Virtex-II Pro devices using the Slave SelectMAP mode. See Figure 3-9 for an example of FPGA configuration using a CPLD and a parallel EPROM.

Figure 3-9: Configuring Virtex-II Pro Devices from Parallel EPROMs
Embedded Solutions

Using an Embedded Microcontroller

*XAPP058, Xilinx In-System Programming Using an Embedded Microcontroller* (www.xilinx.com/apps/xappsumm.htm#xapp058) describes a compact and robust process that (re)configures Virtex-II Pro devices directly from a microprocessor through the JTAG test port of the Virtex-II Pro device. The process additionally supports (re)configuration of XC18V00 ISP PROMs and CPLDs that reside on the JTAG scan chain. Portable, reference C-code is provided with the application note for rapid implementation.

Using IEEE Standard 1532

Systems that implement an IEEE Standard 1532 player can configure Virtex-II Pro devices. Users will require a 1532 BSDL file and a 1532 configuration data file. 1532 BSDL files for Xilinx devices and information on the Xilinx JDRIVE 1532 configuration engine are available here:

http://www.support.xilinx.com/xlnx/xil_prodcat_landingpage.jsp?title=Configuration+Solutions

Choose the JDrive Engine entry from the selection menu on the left of the page.

PROM and System ACE Selection Guide

Use Table 3-6 to determine which PROM or System ACE device goes with which Virtex-II Pro FPGA.

**Table 3-6: PROM and System ACE Solutions for Virtex-II Pro Devices**

<table>
<thead>
<tr>
<th>Virtex-II Pro Device</th>
<th>Bitstream Length (bits)</th>
<th>PROM Solution</th>
<th>System ACE Solution</th>
</tr>
</thead>
<tbody>
<tr>
<td>XCV2VP2</td>
<td>1,305,504</td>
<td>XC17V01</td>
<td>XC18V02</td>
</tr>
<tr>
<td>XCV2VP4</td>
<td>3,006,624</td>
<td>XC17V04</td>
<td>XC18V04</td>
</tr>
<tr>
<td>XCV2VP7</td>
<td>4,485,536</td>
<td>XC17V08</td>
<td>XC18V02 + XC18V04</td>
</tr>
<tr>
<td>XCV2VP20</td>
<td>8,214,688</td>
<td>XC17V08</td>
<td>2 x XC18V04</td>
</tr>
<tr>
<td>XCV2VP30</td>
<td>11,364,608</td>
<td>XC17V08 + XC17V04</td>
<td>XCCACEM16, XCCACE128</td>
</tr>
<tr>
<td>XCV2VP40</td>
<td>15,563,264</td>
<td>XC17V16</td>
<td>4 x XC18V04</td>
</tr>
<tr>
<td>XCV2VP50</td>
<td>19,021,472</td>
<td>System ACE solution only</td>
<td>XCCACEM32, XCCACE128</td>
</tr>
<tr>
<td>XCV2VP70</td>
<td>25,604,096</td>
<td>System ACE solution only</td>
<td>XCCACEM32, XCCACE128</td>
</tr>
<tr>
<td>XCV2VP100</td>
<td>33,645,312</td>
<td>System ACE solution only</td>
<td>XCCACEM64, XCCACE128</td>
</tr>
<tr>
<td>XCV2VP125</td>
<td>42,782,208</td>
<td>System ACE solution only</td>
<td>XCCACEM64, XCCACE128</td>
</tr>
</tbody>
</table>

Notes:
1. Requires XCCACE-TQ144 CompactFlash Controller
Software Support and Data Files

This section provides information on Xilinx device programming software and configuration-related data files.

iMPACT

To program Virtex-II Pro and other Xilinx devices with a personal computer, Xilinx provides iMPACT as a part of the ISE software package. A free version of iMPACT is also available through the WebPACK software suite. More information on WebPACK is available at:


Programming Cables

iMPACT supports several Xilinx programming cables that are compatible with Virtex-II Pro devices, including the Parallel-Cable III, Parallel-Cable IV, and MultiLINX cables. For more information on these cables, or to order programming cables online, please visit:


Boundary Scan Interconnect Testing for Virtex-II Pro Devices

Virtex-II Pro supports the EXTEST, INTEST, and SAMPLE/PRELOAD instructions that are required for Boundary Scan interconnect tests. Xilinx does not provide direct support for Boundary Scan software, although several third party suppliers offer Boundary Scan test equipment that is compatible with Virtex-II Pro. A list of third-parties offering Boundary Scan test equipment is available at:

http://www.support.xilinx.com/xlnx/xil_prodcat_landingpage.jsp?title=Configuration+Solutions

Choose Third-Party Tools from the selection menu on the left of the page.
Master Serial Programming Mode

In serial configuration mode, the FPGA is configured by loading one bit per CCLK cycle. In Master Serial mode, the FPGA drives the CCLK pin. In Slave Serial mode, the FPGAs CCLK pin is driven by an external source. In both serial configuration modes, the MSB of each data byte is always written to the DIN pin first.

The Master Serial mode is designed so the FPGA can be configured from a Serial PROM, Figure 3-10. The speed of the CCLK is selectable by BitGen options, see Appendix A, “BitGen and PROMGen Switches and Options.” Be sure to select a CCLK speed supported by the PROM.

Figure 3-10 shows a Master Serial FPGA configuring from a PROM.

![Master Serial Mode Circuit Diagram](image)

**Figure 3-10:** Master Serial Mode Circuit Diagram

**Notes:**

1. If the Virtex-II Pro device has not selected the DriveDONE option, then an external pull-up resistor of 330Ω should be added to the DONE pin. This pull-up resistor is not needed if DriveDONE = Yes.

![Master Serial Configuration Clocking Sequence](image)

**Figure 3-11:** Master Serial Configuration Clocking Sequence

**Notes:**

1. For Master configurations, the CCLK does not transition until after initialization as indicated by the arrow.
Slave Serial Programming Mode

In serial configuration mode, the FPGA is configured by loading one bit per CCLK cycle. In Slave Serial mode, the FPGA's CCLK pin is driven by an external source. In both serial configuration modes, the MSB of each data byte is always written to the DIN pin first.

The Slave Serial configuration mode allows for FPGAs to be configured from other logic devices, such as microprocessors, or in a daisy-chain fashion. Figure 3-12 shows a Master Serial FPGA configuring from a PROM with a Slave Serial FPGA in a daisy chain with the Master.

Daisy-Chain Configuration

Virtex-II Pro FPGAs can be used in a daisy-chain configuration only with XC4000X, SpartanXL, Spartan-II, or other Virtex FPGAs. For serial daisy chains consisting of both XC4000X and Virtex devices, Xilinx recommends that all Virtex-E/Virtex-II/Virtex-II Pro devices be grouped at the beginning of the serial daisy chain, with the XC4000X/Spartan devices following. For a serial daisy chain consisting only of Spartan-II/E and Virtex/E/II/II Pro devices, there are no restrictions on the order of the devices in the chain. However, there are restrictions on the total number of bits that an FPGA can pass to the downstream FPGAs in the daisy chain. For the limits of each FPGA family, see Solution Record 8985 on the Xilinx Support webpage at:

http://support.xilinx.com/xilnx/xil_ans_display.jsp?iLanguageID=1&iCountryID=1&getPagePath=8985

If a Virtex-II Pro FPGA is placed as the Master and a non-Virtex-II Pro FPGA is placed as a slave, select a configuration CCLK speed supported by all devices in the chain.

The separate bitstreams for the FPGAs in a daisy chain must be combined into a single PROM file, by using either iMPACT or the PROMGen utility (see Appendix A, “BitGen and PROMGen Switches and Options”). Separate .bit files cannot be simply concatenated together to form a daisy-chain bitstream.

Notes:

1. If none of the devices have been selected to DriveDONE, then an external pull-up resistor of 330Ω should be added to the common DONE line. This pull-up resistor is not needed if DriveDONE = Yes. If used, DriveDONE should be selected only for the last device in the configuration chain.
The first device in the chain is the first to be configured. No data is passed onto the DOUT pin until all the data frames, start-up command, and CRC check have been loaded. CRC checks only include the data for the current device, not for any others in the chain. After finishing the first stream, data for the next device is loaded. The data for the downstream device appears on DOUT typically about 80 CCLK cycles after being loaded into DIN. This is due to internal packet processing. Each daisy-chained bitstream carries its own synchronization word. Nothing of the first bitstream is passed to the next device in the chain other than the daisy-chained configuration data.

The DONE_cycle must be set before GTS, or during the same cycle to guarantee each Virtex-II Pro device to move to the operation state when all the DONE pins have been released. When daisy-chaining multiple devices, either set the last device in the chain to DriveDONE, or add external pull-up resistors to counteract the combined capacitive loading on DONE. If non-Virtex devices are included in the daisy chain, it is important to set their bitstreams to SyncToDONE with BitGen options. For more information on Virtex BitGen options, see Appendix A, “BitGen and PROMGen Switches and Options.”.

Notes:
1. For Slave configurations, a free running CCLK can be used, as shown in Figure 3-13.

Table 3-7: Master/Slave Serial Mode Programming Switching

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Values</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>DIN setup/hold, slave mode</td>
<td>$T_{DCC}/T_{CCD}$</td>
<td>5.0/0.0 ns</td>
<td></td>
</tr>
<tr>
<td>DIN setup/hold, master mode</td>
<td>$T_{DSCK}/T_{SCKD}$</td>
<td>5.0/0.0 ns</td>
<td></td>
</tr>
<tr>
<td>DOUT</td>
<td>$T_{CCO}$</td>
<td>12.0 ns</td>
<td></td>
</tr>
<tr>
<td>High time</td>
<td>$T_{CCH}$</td>
<td>5.0 ns</td>
<td></td>
</tr>
<tr>
<td>Low time</td>
<td>$T_{CCL}$</td>
<td>5.0 ns</td>
<td></td>
</tr>
<tr>
<td>Maximum Frequency</td>
<td>$F_{CC_SERIAL}$</td>
<td>66 MHz</td>
<td></td>
</tr>
<tr>
<td>Frequency Tolerance, master mode</td>
<td></td>
<td>+45% -30%</td>
<td></td>
</tr>
</tbody>
</table>
Master SelectMAP Programming Mode

The SelectMAP mode provides an 8-bit bidirectional data bus interface to the Virtex-II Pro configuration logic that can be used for both configuration and readback. Virtex-II Pro devices can not be serially daisy-chained when the SelectMAP interface is used. However, they can be connected in a parallel-chain as shown in Figure 3-16. The DATA pins (D0:D7), CCLK, RDWR_B, BUSY, PROG_B, DONE, and INIT_B can be connected in common between all of the devices. CS_B inputs should be kept separate so each device can be accessed individually. If all devices are to be configured with the same bitstream, readback is not being used, and CCLK is less than FCC_SelectMAP, the CS_B pins can be connected to a common line so the devices are configured simultaneously.

Figure 3-14: Virtex-II Pro Device Interfaced With an 18V00 PROM

Notes:
1. If none of the Virtex-II Pro devices have been selected to DriveDONE, add an external 330 Ω pull-up resistor to the common DONE line. This pull-up resistor is not needed if DriveDONE is selected. If used, DriveDONE should be selected only for the last device in the configuration chain.

The following pins are involved in Master SelectMAP configuration mode:

**DATA Pins (D[0:7])**

The D0 through D7 pins function as a bidirectional data bus in the SelectMAP mode. Configuration data is written to the bus, and readback data is read from the bus. The bus direction is controlled by the RDWR_B signal. See “Configuration Details” on page 394. The D0 pin is considered the MSB of each byte.

**RDWR_B**

When asserted Low, the RDWR_B signal indicates that data is being written to the data bus. When High, the RDWR_B signal indicates that data is being read from the data bus.

**CS_B**

The Chip Select input (CS_B) enables the SelectMAP data bus. To write or read data onto or from the bus, the CS_B signal must be asserted Low. When CS_B is High, Virtex-II Pro devices do not drive onto or read from the bus.
CCLK

The CCLK pin is a clock output in the Master SelectMAP interface. It synchronizes all loading and reading of the data bus for configuration and readback. The CCLK pin is driven by the FPGA.

Data Loading

To load data in the Master SelectMAP mode, a data byte is loaded on every rising CCLK edge as shown in Figure 3-15. If the CCLK frequency is less than $F_{CC\_SelectMAP}$, this can be done without handshaking. For frequencies above $F_{CC\_SelectMAP}$, the BUSY signal must be monitored. If BUSY is High, the current byte must be reloaded when BUSY is Low.

The first byte can be loaded on the first rising CCLK edge that INIT_B is High, and when both CS_B and RDWR_B are asserted Low. CS_B and RDWR_B can be asserted anytime before or after INIT_B has gone High. However, the SelectMAP interface is not active until after INIT_B has gone High. The order of CS_B and RDWR_B does not matter, but RDWR_B must be asserted throughout configuration. If RDWR_B is de-asserted before all data has been loaded, the FPGA aborts the operation. To complete configuration, the FPGA must be reset by PROG_B and reconfigured with the entire stream. For applications that need to de-assert RDWR_B between bytes, see “Controlled CCLK” on page 376.

Extra processing time is needed when the bitstream is encrypted. Because of this, BUSY handshaking is required for encrypted bitstreams at a lower speed than for non-encrypted bitstreams. The maximum speed at which a Virtex-II/Virtex-II Pro device can be configured via SelectMAP without BUSY handshaking is 5 MHz.

![Figure 3-15: Data Loading in SelectMAP](image-url)
Slave SelectMAP Programming Mode

The SelectMAP mode provides an 8-bit bidirectional data bus interface to the Virtex-II Pro configuration logic that can be used for both configuration and readback. Virtex-II Pro devices can not be serially daisy-chained when the SelectMAP interface is used. However, they can be connected in a parallel-chain as shown in Figure 3-16. The DATA pins (D0:D7), CCLK, RDWR_B, BUSY, PROG_B, DONE, and INIT_B can be connected in common between all of the devices. CS_B inputs should be kept separate so each device can be accessed individually. If all devices are to be configured with the same bitstream, readback is not being used, and CCLK is less than F_{CC>SelectMAP}, the CS_B pins can be connected to a common line so the devices are configured simultaneously.

Although Figure 3-16 does not show a control module for the SelectMAP interface, the SelectMAP interface is typically driven by a processor, micro controller, or some other logic device such as an FPGA or a CPLD.

Notes:
1. If none of the Virtex-II Pro devices have been selected to DriveDONE, add an external 330 Ω pull-up resistor to the common DONE line. This pull-up resistor is not needed if DriveDONE = Yes. If used, DriveDONE should be selected only for the last device in the configuration chain.

The following pins are involved in Slave SelectMAP configuration mode:

**DATA Pins (D[0:7])**

The D0 through D7 pins function as a bidirectional data bus in the SelectMAP mode. Configuration data is written to the bus, and readback data is read from the bus. The bus direction is controlled by the RDWR_B signal. See “Configuration Details” on page 394. The D0 pin is considered the MSB of each byte.
RDWR_B
When asserted Low, the RDWR_B signal indicates that data is being written to the data bus. When asserted High, the RDWR_B signal indicates that data is being read from the data bus.

CS_B
The Chip Select input (CS_B) enables the SelectMAP data bus. To write or read data onto or from the bus, the CS_B signal must be asserted Low. When CS_B is High, Virtex-II Pro devices do not drive onto or read from the bus.

BUSY
When CS_B is asserted, the BUSY output indicates when the FPGA can accept another byte. If BUSY is Low, the FPGA reads the data bus on the next rising CCLK edge where both CS_B and RDWR_B are asserted Low. If BUSY is High, the current byte is ignored and must be reloaded on the next rising CCLK edge when BUSY is Low. When CS_B is not asserted, BUSY is 3-stated.

BUSY is only necessary for CCLK frequencies above $F_{CC \_SelectMAP}$. For frequencies at or below $F_{CC \_SelectMAP}$, BUSY is ignored, see 'Data Loading' on page 372. For parallel chains, as shown in Figure 3-16, where the same bitstream is to be loaded into multiple devices simultaneously, BUSY should not be used. Thus, the maximum CCLK frequency for such an application must be less than $F_{CC \_SelectMAP}$.

CCLK
Unlike the Master SelectMAP mode of configuration, the CCLK pin is an input in the Slave SelectMAP mode interface. The CCLK signal synchronizes all loading and reading of the data bus for configuration and readback. Additionally, the CCLK drives internal configuration circuitry. The CCLK can be driven either by a free running oscillator or an externally-generated signal.

Several scenarios exist when configuring the FPGA in SelectMAP mode, depending on the source of CCLK.

Free-Running CCLK
A free-running oscillator can be used to drive Virtex-II Pro CCLK pins. For applications that can provide a continuous stream of configuration data, refer to the timing diagram discussed in Data Loading, page 372. For applications that cannot provide a continuous data stream, missing the clock edges, refer to the timing diagram discussed in Non-Contiguous Data Strobe, page 375. An alternative to a free-running CCLK is discussed in Controlled CCLK, page 376.

Express-Style Loading
In express-style loading, a data byte is loaded on every rising CCLK edge as shown in Figure 3-17. If the CCLK frequency is less than $F_{CC \_SelectMAP}$, this can be done without handshaking. For frequencies above $F_{CC \_SelectMAP}$, the BUSY signal must be monitored. If BUSY is High, the current byte must be reloaded when BUSY is Low.

The first byte can be loaded on the first rising CCLK edge that INIT_B is High, and when both CS_B and RDWR_B are asserted Low. CS_B and RDWR_B can be asserted anytime before or after INIT_B has gone High. However, the SelectMAP interface is not active until after INIT_B has gone High. The order of CS_B and RDWR_B does not matter, but RDWR_B must be asserted throughout configuration. If RDWR_B is de-asserted before all data has been loaded, the FPGA aborts the operation. To complete configuration, the FPGA must be reset by PROG_B and reconfigured with the entire stream.
For applications that need to de-assert RDWR_B between bytes, see "Controlled CCLK" on page 376.

Non-Contiguous Data Strobe

In applications where multiple clock cycles might be required to access the configuration data before each byte can be loaded into the SelectMAP interface, data might not be ready for each consecutive CCLK edge. In such a case, the CS_B signal can be de-asserted until the next data byte is valid on the DATA[0:7] pins. This is demonstrated in Figure 3-18. While CS_B is High, the SelectMAP interface does not expect any data and ignores all CCLK transitions. However, RDWR_B must continue to be asserted while CS_B is asserted. If RDWR_B is High during a positive CCLK transition while CS_B is asserted, the FPGA aborts the operation. For applications that need to de-assert the RDWR_B signal without de-asserting CS_B, see “Controlled CCLK”.

Figure 3-17: "Express Style" Continuous Data Loading in SelectMAP

Figure 3-18: Separating Data Loads by Multiple CCLK Cycles Using CS_B
Controlled CCLK

Some applications require that RDWR_B be de-asserted between the loading of configuration data bytes asynchronously from the CS_B. Typically, this would be due to the RDWR_B signal being a common connection to other devices on the board, such as memory storage elements. In such a case, driving CCLK as a controlled signal instead of a free-running oscillator makes this type of operation possible. In Figure 3-19, the CCLK, CS_B, and RDWR_B are asserted Low while a data byte becomes active. Once the CCLK has gone High, the data is loaded. RDWR_B can be de-asserted and re-asserted as many times as necessary, just as long as it is Low before the next rising CCLK edge.

![Figure 3-19: Controlling CCLK for RDWR_B De-Assertion](image)

<table>
<thead>
<tr>
<th>Description</th>
<th>Symbol</th>
<th>Value</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>D_{0:7} Setup/Hold</td>
<td>$T_{SMDCC}/T_{SMCCD}$</td>
<td>5.0/0.0</td>
<td>ns, min</td>
</tr>
<tr>
<td>CS_B Setup/Hold</td>
<td>$T_{SMCSCC}/T_{SMCCCS}$</td>
<td>7.0/0.0</td>
<td>ns, min</td>
</tr>
<tr>
<td>RDWR_B Setup/Hold</td>
<td>$T_{SMCCW}/T_{SMWCC}$</td>
<td>7.0/0.0</td>
<td>ns, min</td>
</tr>
<tr>
<td>BUSY Propagation Delay</td>
<td>$T_{SMCKBY}$</td>
<td>12.0</td>
<td>ns, max</td>
</tr>
<tr>
<td>Maximum Frequency</td>
<td>$F_{CC_SelectMAP}$</td>
<td>66</td>
<td>MHz, max</td>
</tr>
<tr>
<td>Maximum Frequency with no handshake</td>
<td>$F_{CCNH}$</td>
<td>50</td>
<td>MHz, max</td>
</tr>
</tbody>
</table>
JTAG/ Boundary Scan Programming Mode

Introduction

Virtex-II Pro devices support the new IEEE 1532 standard for In-System Configuration (ISC), based on the IEEE 1149.1 standard. The IEEE 1149.1 Test Access Port and Boundary-Scan Architecture is commonly referred to as JTAG. JTAG is an acronym for the Joint Test Action Group, the technical subcommittee initially responsible for developing the standard. This standard provides a means to assure the integrity of individual components and the interconnections between them at the board level. With increasingly dense multi-layer PC boards, and more sophisticated surface mounting techniques, boundary-scan testing is becoming widely used as an important debugging standard.

Devices containing boundary-scan logic can send data out on I/O pins in order to test connections between devices at the board level. The circuitry can also be used to send signals internally to test the device specific behavior. These tests are commonly used to detect opens and shorts at both the board and device level.

In addition to testing, boundary-scan offers the flexibility for a device to have its own set of user-defined instructions. The added common vendor specific instructions, such as configure and verify, have increased the popularity of boundary-scan testing and functionality.

Boundary-Scan for Virtex-II Pro Devices Using IEEE Standard 1149.1

The Virtex-II Pro family is fully compliant with the IEEE Standard 1149.1 Test Access Port and Boundary-Scan Architecture. The architecture includes all mandatory elements defined in the IEEE 1149.1 Standard. These elements include the Test Access Port (TAP), the TAP controller, the instruction register, the instruction decoder, the boundary-scan register, and the bypass register. The Virtex-II Pro family also supports some optional instructions; the 32-bit identification register, and a configuration register in full compliance with the standard. Outlined in the following sections are the details of the JTAG architecture for Virtex-II Pro devices.

Test Access Port

The Virtex-II Pro TAP contains four mandatory dedicated pins as specified by the protocol (Table 3-9).

<table>
<thead>
<tr>
<th>Pin</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>TDI</td>
<td>Test Data In</td>
</tr>
<tr>
<td>TDO</td>
<td>Test Data Out</td>
</tr>
<tr>
<td>TMS</td>
<td>Test Mode Select</td>
</tr>
<tr>
<td>TCK</td>
<td>Test Clock</td>
</tr>
</tbody>
</table>

There are three input pins and one output pin to control the 1149.1 boundary-scan TAP controller. There are optional control pins, such as TRST (Test Reset) and enable pins, which might be found on devices from other manufacturers. It is important to be aware of these optional signals when interfacing Xilinx devices with parts from different vendors, because they might need to be driven.

The TAP controller is a 16-state state machine shown in Figure 3-20. The four mandatory TAP pins are outlined below.

- TMS - This pin determines the sequence of states through the TAP controller on the rising edge of TCK. TMS has an internal resistive pull-up to provide a logic High if the pin is not driven.
• **TCK** - This pin is the JTAG test clock. It sequences the TAP controller and the JTAG registers in the Virtex-II Pro devices.

• **TDI** - This pin is the serial input to all JTAG instruction and data registers. The state of the TAP controller and the current instruction held in the instruction register determine which register is fed by the TDI pin for a specific operation. TDI has an internal resistive pull-up to provide a logic High to the system if the pin is not driven. TDI is applied into the JTAG registers on the rising edge of TCK.

• **TDO** - This pin is the serial output for all JTAG instruction and data registers. The state of the TAP controller and the current instruction held in the instruction register determine which register (instruction or data) feeds TDO for a specific operation. TDO changes state on the falling edge of TCK and is only active during the shifting of instructions or data through the device. This pin is 3-stated at all other times.

**Notes:**

As specified by the IEEE Standard, the TMS and TDI pins all have internal pull-up resistors. These internal pull-up resistors of 50-150 kΩ are active, regardless of the mode selected. For JTAG configuration mode, JTAG inputs are independent of $V_{CCO}$ and work between 2.5V and 3.3V TTL levels ($V_{IL} \max = .8V$, $V_{IH} \min = 2.0V$). The JTAG input pins are 3.3V tolerant. The JTAG output (TDO) is an open-drain output and must be pulled up to the appropriate voltage level (typically 3.3V) through an external resistor. The value of the external pullup resistor depends on the capacitive loading on the TDO pin and the operating frequency, but it should not be less than 200Ω. The optimal TDO pullup value can be determined through IBIS simulation.

**TAP Controller**

Figure 3-20 diagrams a 16-state finite state machine. The four TAP pins control how data is scanned into the various registers. The state of the TMS pin at the rising edge of TCK determines the sequence of state transitions. There are two main sequences, one for shifting data into the data register and the other for shifting an instruction into the instruction register.

![State Diagram for the TAP Controller](image_url)
Boundary-Scan Instruction Set

To determine the operation to be invoked, an instruction is loaded into the Instruction Register (IR). The length of the IR is device size specific. The IR is 10 bits wide on the XC2VP2, XC2VP4, and XC2VP7; 14 bits wide on the XC2VP20, XC2VP30, XC2VP40, XC2VP50, XC2VP70, and XC2VP100; and 22 bits wide on the XC2VP125. The bottom six bits of the instruction codes are the same for all devices sizes, to support the new IEEE Standard 1532 for In-System Configurable (ISC) devices. The additional IR bits for each instruction are 1’s. Table 3-10 lists the available instructions for Virtex-II Pro devices.

Table 3-10: Virtex-II Pro Boundary Scan Instructions for XC2VP2 through XC2VP7

<table>
<thead>
<tr>
<th>Boundary Scan Command</th>
<th>Binary Code (9:0)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>EXTEST</td>
<td>1111000000</td>
<td>Enables boundary-scan EXTEST operation</td>
</tr>
<tr>
<td>SAMPLE</td>
<td>1111000001</td>
<td>Enables boundary-scan SAMPLE operation</td>
</tr>
<tr>
<td>USER1</td>
<td>1111000010</td>
<td>Access user-defined register 1</td>
</tr>
<tr>
<td>USER2</td>
<td>1111000011</td>
<td>Access user-defined register 2</td>
</tr>
<tr>
<td>CFG_OUT</td>
<td>11110000100</td>
<td>Access the configuration bus for readback</td>
</tr>
<tr>
<td>CFG_IN</td>
<td>11110000101</td>
<td>Access the configuration bus for configuration</td>
</tr>
<tr>
<td>INTEST</td>
<td>11110000111</td>
<td>Enables boundary-scan INTEST operation</td>
</tr>
<tr>
<td>USERCODE</td>
<td>1111001000</td>
<td>Enables shifting out user code</td>
</tr>
<tr>
<td>IDCODE</td>
<td>1111001001</td>
<td>Enables shifting out of ID code</td>
</tr>
<tr>
<td>HIGHZ</td>
<td>1111001010</td>
<td>3-states output pins while enabling the bypass register</td>
</tr>
<tr>
<td>JSTART</td>
<td>1111001100</td>
<td>Clocks the start-up sequence when StartClk is TCK</td>
</tr>
<tr>
<td>JSHUTDOWN</td>
<td>1111001101</td>
<td>Clocks the shutdown sequence</td>
</tr>
<tr>
<td>BYPASS</td>
<td>1111111111</td>
<td>Enables BYPASS</td>
</tr>
<tr>
<td>JPROG_B</td>
<td>1111001011</td>
<td>Equivalent to and has the same affect as PROG_B</td>
</tr>
<tr>
<td>RESERVED</td>
<td>All other codes</td>
<td>Xilinx reserved instructions</td>
</tr>
</tbody>
</table>

The mandatory IEEE 1149.1 commands are supported in Virtex-II Pro devices, as well as several Xilinx vendor-specific commands. Virtex-II Pro devices have a powerful command set. The EXTEST, INTEST, SAMPLE/PRELOAD, BYPASS, IDCODE, USERCODE, and HIGHZ instructions are all included. The TAP also supports two internal user-defined registers (USER1 and USER2) and configuration/readback of the device. The Virtex-II Pro boundary-scan operations are independent of mode selection. The boundary-scan mode in Virtex-II Pro devices overrides other mode selections. For this reason, boundary-scan instructions using the boundary-scan register (SAMPLE/PRELOAD, INTEST, EXTEST) must not be performed during configuration. All instructions except USER1 and USER2 are available before a Virtex-II Pro device is configured. After configuration, all instructions are available.

JSTART and JSHUTDOWN are instructions specific to the Virtex-II Pro architecture and configuration flow. As described in Table 3-10, the JSTART and JSHUTDOWN instructions clock the startup sequence when the appropriate bitgen option is selected. The instruction does not work correctly without the correct bitgen option selected.

bitgen -g startupclk:jtagclk designName.ncd
For details on the standard boundary-scan instructions EXTEST, INTEST, and BYPASS, refer to the IEEE Standard. The user-defined registers (USER1/USER2) are described in USER1, USER2 Registers, page 383.

**Boundary-Scan Architecture**

Virtex-II Pro device registers include all registers required by the IEEE 1149.1 Standard. In addition to the standard registers, the family contains optional registers for simplified testing and verification (Table 3-11).

**Table 3-11: Virtex-II Pro JTAG Registers**

<table>
<thead>
<tr>
<th>Register Name</th>
<th>Register Length</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Instruction register</td>
<td>Device specific</td>
<td>Holds current instruction OPCODE and captures internal device status.</td>
</tr>
<tr>
<td>Boundary scan register</td>
<td>3 bits per I/O</td>
<td>Controls and observes input, output, and output enable.</td>
</tr>
<tr>
<td>Bypass register</td>
<td>1 bit</td>
<td>Device bypass.</td>
</tr>
<tr>
<td>Identification register</td>
<td>32 bits</td>
<td>Captures device ID.</td>
</tr>
<tr>
<td>JTAG configuration register</td>
<td>64 bits</td>
<td>Allows access to the configuration bus when using the CFG_IN or CFG_OUT instructions.</td>
</tr>
<tr>
<td>USERCODE register</td>
<td>32 bits</td>
<td>Captures user-programmable code.</td>
</tr>
</tbody>
</table>

**Boundary-Scan Register**

The test primary data register is the boundary-scan register. Boundary-scan operation is independent of individual IOB configurations. Each IOB, bonded or un-bonded, starts as bidirectional with 3-state control. Later, it can be configured to be an input, output, or 3-state only. Therefore, three data register bits are provided per IOB (Figure 3-21).

When conducting a data register (DR) operation, the DR captures data in a parallel fashion during the CAPTURE-DR state. The data is then shifted out and replaced by new data during the SHIFT-DR state. For each bit of the DR, an update latch is used to hold the input data stable during the next SHIFT-DR state. The data is then latched during the UPDATE-DR state when TCK is Low.

The update latch is opened each time the TAP Controller enters the UPDATE-DR state. Care is necessary when exercising an INTEST or EXTEST to ensure that the proper data has been latched before exercising the command. This is typically accomplished by using the SAMPLE/PRELOAD instruction.

Consider internal pull-up and pull-down resistors when developing test vectors for testing opens and shorts. The boundary-scan mode determines if the IOB has a pull-up resistor. Figure 3-21 is a representation of Virtex-II Pro Boundary-Scan Architecture.
Bit Sequence

The order in each non-TAP IOB is described in this section. The input is first, then the output, and finally the 3-state IOB control. The 3-state IOB control is closest to the TDO. The input-only pins contribute only the input bit to the boundary-scan I/O data register. The bit sequence of the device is obtainable from the “Boundary-Scan Description Language Files” (BSDL files) for the Virtex family. These files can be obtained from the Xilinx software download area. The bit sequence is independent of the design. It always has the same bit order and the same number of bits.

Bypass Register

The other standard data register is the single flip-flop BYPASS register. It passes data serially from the TDI pin to the TDO pin during a bypass instruction. This register is initialized to zero when the TAP controller is in the CAPTURE-DR state.

Instruction Register

The instruction register loads the OPCODE necessary for the Virtex-II Pro boundary-scan instruction set. This register loads the current OPCODE and captures internal device status. The width of this register is device size specific.

Configuration Register (Boundary-Scan)

The configuration register is a 64-bit register. This register allows access to the configuration bus and readback operations.

Identification Register

Virtex devices have a 32-bit identification register, commonly referred to as the IDCODE register. This register is based upon IEEE Standard 1149.1 and allows easy identification of the part being tested or programmed via boundary scan.
Virtex-II Pro Identification Register

The Virtex-II Pro JTAG ID Code register has the following format.

\[
\begin{align*}
\text{vvvv} & \quad \text{ffff} \quad \text{fffa} \quad \text{aaaa} \quad \text{aaaa} \quad \text{cccc} \quad \text{cccc} \quad \text{cccl} \\
0001 & \quad 0010 \quad 0100 \quad 1010 \quad 0000 \quad 1001 \quad 0011 \\
\text{bin} & \quad \text{hex} \quad \text{v} \quad 2 \quad 4 \quad A \quad 0 \quad 9 \quad 3 \\
0001 & \quad 0010 \quad 0100 \quad 1010 \quad 0000 \quad 1001 \quad 0011 \\
\text{bin} & \quad \text{hex} \quad \text{v} \quad 2 \quad 9 \quad 2 \quad 0 \quad 9 \quad 3 \\
0001 & \quad 0010 \quad 1101 \quad 0110 \quad 0000 \quad 1001 \quad 0011 \\
\text{bin} & \quad \text{hex} \quad \text{v} \quad 2 \quad D \quad 6 \quad 0 \quad 9 \quad 3 \\
\end{align*}
\]

where

- \( v \) is the revision code
- \( f \) is the 7-bit family code, 0001001 for Virtex-II Pro
- \( a \) is the number of array rows plus columns in the part, expressed in 9 bits:

\[
\begin{align*}
\text{XC2VP2 rows + columns} & = 16 + 22 = 38 = 0x026 \\
\text{XC2VP4 rows + columns} & = 40 + 22 = 62 = 0x03E \\
\text{XC2VP7 rows + columns} & = 40 + 34 = 74 = 0x04A \\
\text{XC2VP20 rows + columns} & = 56 + 46 = 102 = 0x066 \\
\text{XC2VP30 rows + columns} & = 80 + 46 = 126 = 0x07E \\
\text{XC2VP40 rows + columns} & = 88 + 58 = 146 = 0x092 \\
\text{XC2VP50 rows + columns} & = 88 + 70 = 158 = 0x09E \\
\text{XC2VP70 rows + columns} & = 104 + 82 = 186 = 0x0BA \\
\text{XC2VP100 rows + columns} & = 120 + 94 = 214 = 0x0D6 \\
\text{XC2VP125 rows + columns} & = 136 + 106 = 242 = 0x0F2
\end{align*}
\]

- \( c \) is the company code = 00001001001. Since the last bit of the JTAG IDCODE is always one, the last three hex digits appear as 0x093.

Examples of how the binary digits translate into hex codes appear in Table 3-12.

<table>
<thead>
<tr>
<th></th>
<th>vvvv</th>
<th>ffff</th>
<th>fffa</th>
<th>aaaa</th>
<th>aaaa</th>
<th>cccc</th>
<th>cccc</th>
<th>ccc1</th>
</tr>
</thead>
<tbody>
<tr>
<td>XC2VP7</td>
<td>0001</td>
<td>0000</td>
<td>0101</td>
<td>0100</td>
<td>1000</td>
<td>1001</td>
<td>0011</td>
<td></td>
</tr>
<tr>
<td>bin</td>
<td>hex</td>
<td>&lt;v&gt;</td>
<td>1</td>
<td>2</td>
<td>4</td>
<td>A</td>
<td>0</td>
<td>9</td>
</tr>
<tr>
<td>XC2VP40</td>
<td>0001</td>
<td>0000</td>
<td>0101</td>
<td>1001</td>
<td>0010</td>
<td>0000</td>
<td>1001</td>
<td>0011</td>
</tr>
<tr>
<td>bin</td>
<td>hex</td>
<td>&lt;v&gt;</td>
<td>1</td>
<td>2</td>
<td>9</td>
<td>2</td>
<td>0</td>
<td>9</td>
</tr>
<tr>
<td>XC2VP100</td>
<td>0001</td>
<td>0000</td>
<td>1101</td>
<td>0110</td>
<td>0000</td>
<td>1001</td>
<td>0011</td>
<td></td>
</tr>
<tr>
<td>bin</td>
<td>hex</td>
<td>&lt;v&gt;</td>
<td>1</td>
<td>2</td>
<td>D</td>
<td>6</td>
<td>0</td>
<td>9</td>
</tr>
</tbody>
</table>
ID Codes assigned to Virtex-II Pro FPGAs are shown in Table 3-13.

Table 3-13: Virtex-II Pro Device ID Codes

<table>
<thead>
<tr>
<th>FPGA</th>
<th>IDCODE(1)</th>
<th>FPGA</th>
<th>IDCODE</th>
</tr>
</thead>
<tbody>
<tr>
<td>XC2VP2</td>
<td>&lt;v&gt;1226093</td>
<td>XC2VP40</td>
<td>&lt;v&gt;1292093</td>
</tr>
<tr>
<td>XC2VP4</td>
<td>&lt;v&gt;123E093</td>
<td>XC2VP50</td>
<td>&lt;v&gt;129E093</td>
</tr>
<tr>
<td>XC2VP7</td>
<td>&lt;v&gt;124A093</td>
<td>XC2VP70</td>
<td>&lt;v&gt;12BA093</td>
</tr>
<tr>
<td>XC2VP20</td>
<td>&lt;v&gt;1266093</td>
<td>XC2VP100</td>
<td>&lt;v&gt;12D6093</td>
</tr>
<tr>
<td>XC2VP30</td>
<td>&lt;v&gt;127E093</td>
<td>XC2VP125</td>
<td>&lt;v&gt;12F2093</td>
</tr>
</tbody>
</table>

Notes:
1. The <v> in the IDCODE stands for the device’s revision code (in hex).

USERCODE Register

USERCODE is supported in the Virtex family as well. This register allows a user to specify a design-specific identification code. The USERCODE can be programmed into the device and read back for verification at a later time. The USERCODE is embedded into the bitstream during bitstream generation (bitgen -g UserID option) and is valid only after configuration.

USER1, USER2 Registers

The USER1 and USER2 registers are only valid after configuration. These two registers must be defined by the user within the design. These registers can be accessed after they are defined by the TAP pins.

The BSCAN_VIRTEX2 library macro is required when creating these registers. This symbol is only required for driving internal scan chains (USER1 and USER2). The BSCAN_VIRTEX2 macro provides two user pins (SEL1 and SEL2) for determining usage of USER1 or USER2 instructions respectively. For these instructions, two corresponding pins (TDO1 and TDO2) allow user scan data to be shifted out of TDO. In addition, there are individual clock pins (DRCK1 and DRCK2) for each user register. There is a common input pin (TDI) and shared output pins that represent the state of the TAP controller (RESET, SHIFT, and UPDATE). Unlike earlier FPGA families that required the BSCAN macro to dedicate TAP pins for boundary scan, Virtex-II Pro TAP pins are dedicated and do not require the BSCAN_VIRTEX2 macro for normal boundary-scan instructions or operations.

Note that these are user-defined registers. The example (Figure 3-22) is one of many implementations. For HDL, the BSCAN_VIRTEX2 macro needs to be instantiated in the design.
Using Boundary Scan in Virtex-II Pro Devices

Characterization data for some of the most commonly requested timing parameters shown in Figure 3-23 is listed in Table 3-14.
Configuring Through Boundary-Scan

One of the most common boundary-scan vendor-specific instructions is the configure instruction. An individual Virtex-II Pro device is configured via JTAG on power-up using TAP. If the Virtex-II Pro device is configured on power-up, it is advisable to tie the mode pins to the boundary-scan configuration mode settings; 101 (M2 = 1, M1 = 0, M0 = 1).

Configuration flow for Virtex-II Pro device configuration with JTAG is shown in Figure 3-24. The sections that follow describe how the Virtex-II Pro device can be configured as a single device via boundary-scan or as part of a multiple-device scan chain.

A configured device can be reconfigured by toggling the TAP and entering a CFG_IN instruction after pulsing the PROG_B pin or issuing the shut-down sequence. (Refer to Power Up, page 356). For additional details on power-up or the start-up sequence in Virtex-II Pro devices, see Device Startup, page 358.

Customers who wish to implement the Virtex-II Pro JTAG COnfiguration algorithm are encouraged to use the SVF-based flow provided in Xilinx Application Note XAPP058.

### Table 3-14: Boundary-Scan Port Timing Specifications

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Value</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>T_{TAP,TCK}</td>
<td>TMS and TDI setup time before TCK</td>
<td>4.0</td>
<td>ns, min</td>
</tr>
<tr>
<td>T_{TCK,TAP}</td>
<td>TMS and TDI hold times after TCK</td>
<td>2.0</td>
<td>ns, min</td>
</tr>
<tr>
<td>T_{TCK,TDO}</td>
<td>TCK falling edge to TDO output valid</td>
<td>11.0</td>
<td>ns, min</td>
</tr>
<tr>
<td>F_{TCK}</td>
<td>Maximum TCK clock frequency</td>
<td>33.0</td>
<td>MHz, max</td>
</tr>
</tbody>
</table>

For further information on the Startup sequence, bitstream, and internal configuration registers referenced here, refer to Readback, page 404.
Figure 3-24: Device Configuration Flow Diagram
Single Device Configuration

Configure a Virtex-II Pro part as a single device via boundary-scan operations as follows. Ensure that the bitstream is generated with the JTAG clock option.

```
bitgen -g startupclk:jtagclk designName.ncd
```

Also, when using iMPACT software, verify that the most current version is being used.

Table 3-15 describes the TAP controller commands required to configure a Virtex-II Pro device. Refer to Figure 3-20 for TAP controller states. These TAP controller commands are issued automatically if configuring the part with the iMPACT software.

<table>
<thead>
<tr>
<th>TAP Controller Step and Description</th>
<th>Set &amp; Hold</th>
<th># of Clocks</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>TDI</td>
</tr>
<tr>
<td>1. On power-up, place a logic “one” on the TMS and clock the TCK five times. This ensures starting in the TLR (Test-Logic-Reset) state.</td>
<td>X</td>
<td>1</td>
</tr>
<tr>
<td>2. Move into the RTI state.</td>
<td>X</td>
<td>0</td>
</tr>
<tr>
<td>3. Move into the SELECT-IR state.</td>
<td>X</td>
<td>1</td>
</tr>
<tr>
<td>4. Enter the SHIFT-IR state.</td>
<td>X</td>
<td>0</td>
</tr>
<tr>
<td>5. Start loading the CFG_IN instruction, LSB first: XC2VP2 → XC2VP7: XC2VP20 → XC2VP100: XC2VP125:</td>
<td>111_000101</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>111_1111_000101</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>111_1111_1111_1111_000101</td>
<td>0</td>
</tr>
<tr>
<td>6. Load the MSB of CFG_IN instruction when exiting SHIFT-IR, as defined in the IEEE standard.</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>7. Enter the SELECT-DR state.</td>
<td>X</td>
<td>1</td>
</tr>
<tr>
<td>8. Enter the SHIFT-DR state.</td>
<td>X</td>
<td>0</td>
</tr>
<tr>
<td>9. Shift in the Virtex-II Pro bitstream. Bit₀ (MSB) is the first bit in the bitstream(1).</td>
<td>bit₁…bitₙ</td>
<td>0</td>
</tr>
<tr>
<td>10. Shift in the last bit of the bitstream. Bit₀ (LSB) shifts on the transition to EXIT1-DR.</td>
<td>bit₀</td>
<td>1</td>
</tr>
<tr>
<td>11. Enter UPDATE-DR state.</td>
<td>X</td>
<td>1</td>
</tr>
<tr>
<td>12. Reset TAP by clocking five 1’s on TMS</td>
<td>X</td>
<td>1</td>
</tr>
<tr>
<td>13. Enter the SELECT-IR state.</td>
<td>X</td>
<td>1</td>
</tr>
<tr>
<td>14. Move to the SHIFT-IR state.</td>
<td>X</td>
<td>0</td>
</tr>
<tr>
<td>15. Start loading the JSTART instruction. The JSTART instruction initializes the startup sequence.</td>
<td>01100</td>
<td>0</td>
</tr>
<tr>
<td>16. Load the last bit of the JSTART instruction.</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>17. Move to the UPDATE-IR state.</td>
<td>X</td>
<td>1</td>
</tr>
</tbody>
</table>
Multiple Device Configuration

It is possible to configure multiple Virtex-II Pro devices in a chain. The devices in the JTAG chain are configured one at a time. The multiple device configuration steps can be applied to any size chain. Ensure the bitstream is generated with the JTAG clock option.

```
bitgen -g startupclk:jtagclk designName.ncd
```

Refer to the State Diagram in Figure 3-20 for the following TAP controller steps.

1. On power-up, place a logic “one” on the TMS and clock the TCK five times. This ensures starting in the TLR (Test-Logic-Reset) state.
2. Load the CFG_IN instruction into the target device (and BYPASS in all other devices). Go through RTI (RUN-TEST/IDLE).
3. Load in the configuration bitstream per step 7 through step 11 in Table 3-15.
4. Repeat step 2 and step 3 for each device.
5. Reset all TAPs by clocking five 1’s on TMS.
6. Load the JSTART command into all devices.
7. Go to RTI and clock TCK 12 times.

All devices are active at this point.

Table 3-15: Single Device Configuration Sequence (Continued)

<table>
<thead>
<tr>
<th>TAP Controller Step and Description</th>
<th>Set &amp; Hold</th>
<th># of Clocks</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>TDI</td>
</tr>
<tr>
<td>18. Move to RTI and clock the STARTUP sequence by applying a minimum of 12 clock cycles to the TCK.</td>
<td>X</td>
<td>0</td>
</tr>
<tr>
<td>19. Move to the TLR state. The device is now functional.</td>
<td>X</td>
<td>1</td>
</tr>
</tbody>
</table>

Notes:

1. In the Configuration Register, data is shifted in from the right (TDI) to the left (TDO).

Notes:

1. PROG_B pin should be deasserted during JTAG operation.

Figure 3-25: Boundary Scan Chain of Devices

Notes:

1. PROG_B pin should be deasserted during JTAG operation.
Reconfiguring Through Boundary Scan

The ability of Virtex-II Pro devices to perform partial reconfiguration is the reason that the configuration memory is not cleared when reconfiguring the device. When reconfiguring a chain of devices, refer to step 3 in Table 3-15. There are two methods to reconfigure Virtex-II Pro devices without possible internal contention. The first method is to pulse the PROG_B pin which resets the internal configuration memory. The alternate method is to perform a shutdown sequence, placing the device in a safe state. The following shutdown sequence includes using internal registers. (For details on internal registers, refer to Readback, page 404.)

1. Load the CFG_IN instruction.
2. In SHIFT-DR state, load the synchronization word followed by the Reset CRC Register (RCRC) command.

   1111 1111 1111 1111 1111 1111 1111 1111 -> Dummy word
   1010 1010 1001 1001 0101 0101 0110 0110 -> Synchronization word
   0011 0000 0000 0000 1000 0000 0000 0001 -> Header: Write to CMD register
   0000 0000 0000 0000 0000 0000 0000 0111 -> RCRC command
   0000 0000 0000 0000 0000 0000 0000 0000 -> flush pipe
   0000 0000 0000 0000 0000 0000 0000 0000 -> flush pipe

3. Load JSHUTDOWN.
4. Go to RTI and clock TCK at least 12 times to clock the shutdown sequence.
5. Proceed to SHIFT-IR state and load the CFG_IN instruction again.
6. Go to SHIFT-DR state and load the configuration bits. Make sure the configuration bits contain AGHIGH command, which asserts the global signal GHIGH_B. This prevents contention while writing configuration data.

   0011 0000 0000 0000 1000 0000 0000 0001 -> Header: Write to CMD
   0000 0000 0000 0000 0000 0000 0000 1000 -> AGHIGH command asserts GHIGH_B

7. When all configuration bits have been loaded, reset the TAP by clocking five 1’s on TMS.
8. Go to SHIFT-IR state and load the JSTART instruction.
9. Go to RTI and clock TCK at least 12 times to clock the startup sequence.
10. Go to TLR state to complete the reconfiguration process.

Debugging Configuration

To verify successful configuration, there are several options. Some of the most helpful verification steps include using TAP pins and the readback command. Using the Virtex-II Pro TAP controller and status pins is discussed first.

When using TAP controller pins, TDO is driven only in the SHIFT-DR and SHIFT-IR state. If the output of the TDO can be changed via an external pull-up resistor, the TAP is not in SHIFT-IR or SHIFT-DR. If the TAP can be controlled precisely, use this to test the application.

In JTAG configuration, the status pin (DONE) functions the same as in the other configuration modes. The DONE pin can be monitored to determine if a bitstream has been completely loaded into the device. If DONE is Low, the entire bitstream has not been sent or the start-up sequence is not finished. If DONE is High, the entire bitstream has been received correctly. The INIT_B pin functions similar to a normal INIT_B but does not indicate a configuration error in boundary-scan configuration.

In addition to external pin monitoring, an internal test can be conducted. The second method includes the following steps to capture the internal device status register contents:
1. Move the TAP to TLR state.
2. Go to SHIFT-IR state and load in the CFG_IN instruction.
3. Go to SHIFT-DR state and shift in the following 64-bit pattern with the MSB (left-most bit), shifted in first.

```
1111 1111 1111 1111 1111 1111 1111 1111-> Dummy word
1010 1010 1001 1001 0101 0101 0110 0110-> Synchronization word
0010 1000 0000 0000 1110 0000 0000 0010-> Read STATus Register 1)
0000 0000 0000 0000 0000 0000 0000 0000-> flush pipe
0000 0000 0000 0000 0000 0000 0000 0000-> flush pipe
0000 0000 0000 0000 0000 0000 0000 0000-> flush pipe
```

**Notes:**
1. Since the JTAG readback shift register is 64-bit long, two 32-bit words are needed to fill the shift register.

4. After shifting in the pattern, load the CFG_OUT instruction in the SHIFT-IR state.
5. Move to SHIFT-DR state and clock TCK 32 times while reading TDO. The data seen on TDO is the content of the status register. The last bit out is a one if a CRC error occurred. If successful, it should read as follows.

```
0000 0000 0000 0000 0001 1MMM 1110 111011,2)
```

**Notes:**
1. MMM is the mode pins value.
2. Assuming that the device is in normal operation mode.

Since the read status activity causes the crc_error status to be asserted, it is important to clear the crc_error status to ensure normal device operation. This can be done by writing the precalculated CRC value to the CRC register or writing an RCRC command.

6. Go to SHIFT-IR state and load the CFG_IN instruction again.
7. Move to SHIFT-DR state and shift in the following bit pattern:

```
0011 0000 0000 0000 1000 0000 0000 0000-> Header: Write to CMD register
0000 0000 0000 0000 0000 0000 0000 0111-> RCRC command
0000 0000 0000 0000 0000 0000 0000 0000-> flush pipe
0000 0000 0000 0000 0000 0000 0000 0000-> flush pipe
```

8. Put the TAP in TLR state when finished.

The device status register also gives the status of the DONE and INIT_B signals. For information on the status register, refer to Figure 3-30.
Boundary-Scan for Virtex-II Pro Devices Using IEEE Standard 1532

ISC Modal States

Once the device is powered up, it goes to an Unprogrammed state. The I/Os are all either 3-stated or pulled up. When ISC_ENABLE is successfully executed, the ISC_Enabled signal is asserted, and the device moves to ISC_Accessed state. When the device moves to ISC_Accessed state from Operational state, the shutdown sequence is executed. The I/Os are all either 3-stated or pulled up.

The StartUp sequence is executed when in the ISC_Accessed state. At the end of the StartUp Sequence, ISC_Enabled is cleared and the device moves to ISC_Complete. The minimum clock cycle requirement is the number of clock cycles required to complete the StartUp sequence. At the completion of the minimum required clock cycles, ISC_Enabled is deasserted.

Whether the StartUp sequence is successful or not is determined by CRC or configuration error status from the configuration processor. If the startup is completed, ISC_Done is asserted; otherwise, ISC_Done stays Low. The I/Os are either 3-stated or pulled up.

When ISC_Done is set in ISC_Complete state, the device moves to the Operational state. Otherwise, if ISC_Done is clear, the device moves to an Unprogrammed state. However, if the TAP controller goes to TLR state while the device is in ISC_Accessed state and if ISC_Done is set, then the device moves to the Operational state. However, the I/O is not active yet because the Startup sequence has not been performed. The Startup sequence has to be performed in the Operational state to bring the I/O active.
Clocking Startup and Shutdown Sequence (JTAG Version)

There are three clock sources for Startup and Shutdown sequence, CCLK, UserCLK, and JTAGCLK. Clock selection is set by bitgen. The Startup sequence is executed in ISC_Accessed state. When it is clocked by JTAGCLK, the Startup sequence receives the JTAGCLK in TAP Run/Test Idle state while ISC_DISABLE is the current JTAG instruction. The number of clock cycles in Run/Test Idle state for successful completion of ISC_DISABLE is determined by the number of clock cycles needed to complete the Startup sequence.

When UserCLK or CCLK is used to clock the Startup sequence, the user should know how many JTAGCLK cycles should be spent in Run/Test Idle to successfully complete the Startup sequence.

The Shutdown sequence is executed when the device transitions from an Operational to ISC_Accessed state. Shutdown is done while executing the ISC_ENABLE instruction. When the Shutdown sequence is clocked using JTAGCLK, the clock is supplied in the Run/Test Idle state of the ISC_ENABLE instruction. The number of clock cycles in Run/Test Idle is determined by the number of clock cycles needed to complete the Shutdown sequence.

When the Shutdown sequence is clocked by CCLK or UserCLK, the user is responsible for knowing how many JTAGCLK cycles in Run/Test Idle are needed to complete the Shutdown sequence.

Notes:

1. It has been decided that when configuring the device through JTAG, the startup and shutdown clock should come from TCK, regardless of the selection in bitgen.
2. In IEEE 1532 configuration mode, Startup and Shutdown clock source is always TCK.
JTAG/ Boundary Scan Programming Mode

Configuration Flows Using JTAG

Figure 3-27: IEEE 1532 Configuration Flow
Configuration Details

This section provides a bit-level understanding of the configuration stream. For the purpose of debugging, designing embedded readback operations, or otherwise complex styles of configuring multiple FPGAs, the Virtex-II bitstream, internal configuration logic, and internal processing of configuration data are described here.
Data Frames

The internal configuration memory is partitioned into segments called “Frames.” The portions of the bitstream that actually get written to the configuration memory are “Data Frames.” The number and size of frames varies with device size as shown in Table 3-16. The total number of configuration bits for a particular device is calculated by multiplying the number of frames by the number of bits per frame, and then adding the total number of bits needed to perform the configuration register writes shown in Table 3-22.

Table 3-16: Virtex-II Pro Configuration Data Frames and Programming Times

<table>
<thead>
<tr>
<th>Device</th>
<th>No. of Frames</th>
<th>Frame Length in Bits</th>
<th>Configuration Bits</th>
<th>Total No. of Bits (including Header)</th>
<th>Approx. SelectMAP Download Time (50 MHz) ms</th>
<th>Approx. Serial Download Time (50 MHz) ms</th>
<th>Approx. JTAG Download Time (33 MHz) ms</th>
</tr>
</thead>
<tbody>
<tr>
<td>XC2VP2</td>
<td>884</td>
<td>1,472</td>
<td>1,301,248</td>
<td>1,305,440</td>
<td>3.26</td>
<td>26.11</td>
<td>39.56</td>
</tr>
<tr>
<td>XC2VP4</td>
<td>884</td>
<td>3,392</td>
<td>2,998,528</td>
<td>3,006,560</td>
<td>7.52</td>
<td>60.13</td>
<td>91.11</td>
</tr>
<tr>
<td>XC2VP7</td>
<td>1,320</td>
<td>3,392</td>
<td>4,477,440</td>
<td>4,485,472</td>
<td>11.21</td>
<td>89.71</td>
<td>135.92</td>
</tr>
<tr>
<td>XC2VP20</td>
<td>1,756</td>
<td>4,672</td>
<td>8,204,032</td>
<td>8,214,624</td>
<td>20.54</td>
<td>164.29</td>
<td>248.93</td>
</tr>
<tr>
<td>XC2VP30</td>
<td>1,756</td>
<td>6,592</td>
<td>11,575,552</td>
<td>11,589,984</td>
<td>28.97</td>
<td>231.80</td>
<td>351.21</td>
</tr>
<tr>
<td>XC2VP40</td>
<td>2,192</td>
<td>7,232</td>
<td>15,852,544</td>
<td>15,868,256</td>
<td>39.67</td>
<td>317.37</td>
<td>480.86</td>
</tr>
<tr>
<td>XC2VP50</td>
<td>2,628</td>
<td>7,232</td>
<td>19,005,696</td>
<td>19,021,408</td>
<td>47.55</td>
<td>380.43</td>
<td>576.41</td>
</tr>
<tr>
<td>XC2VP70</td>
<td>3,064</td>
<td>8,512</td>
<td>26,080,768</td>
<td>26,099,040</td>
<td>65.24</td>
<td>521.98</td>
<td>790.88</td>
</tr>
<tr>
<td>XC2VP100</td>
<td>3,500</td>
<td>9,792</td>
<td>34,272,000</td>
<td>34,292,832</td>
<td>85.73</td>
<td>685.86</td>
<td>1,039.18</td>
</tr>
<tr>
<td>XC2VP125</td>
<td>3,936</td>
<td>11,072</td>
<td>43,579,392</td>
<td>43,602,784</td>
<td>109.00</td>
<td>872.06</td>
<td>1,321.30</td>
</tr>
</tbody>
</table>

Configuration Registers

The Virtex-II Pro configuration logic was designed so that an external source can have complete control over all configuration functions by accessing and loading addressed internal configuration registers over a common configuration bus. The internal configuration registers that are used for configuration and readback are listed in Table 3-17. All configuration data, except the synchronization word and dummy words, is written to internal configuration registers.

Table 3-17: Internal Configuration Registers

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Register Name</th>
<th>Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>CRC</td>
<td>CRC Register</td>
<td>00000</td>
</tr>
<tr>
<td>FAR</td>
<td>Frame Address Register</td>
<td>00001</td>
</tr>
<tr>
<td>FDRI</td>
<td>Frame Data Input Register (Write Configuration Data)</td>
<td>00010</td>
</tr>
<tr>
<td>FDRO</td>
<td>Frame Data Output Register (Readback Configuration Data)</td>
<td>00011</td>
</tr>
<tr>
<td>CMD</td>
<td>Command Register</td>
<td>00100</td>
</tr>
<tr>
<td>CTL</td>
<td>Control Register</td>
<td>00101</td>
</tr>
<tr>
<td>MASK</td>
<td>Masking Register for CTL</td>
<td>00110</td>
</tr>
<tr>
<td>STAT</td>
<td>Status Register</td>
<td>00111</td>
</tr>
<tr>
<td>LOUT</td>
<td>Legacy Output Register (DOUT for daisy chain)</td>
<td>01000</td>
</tr>
<tr>
<td>COR</td>
<td>Configuration Option Register</td>
<td>01001</td>
</tr>
</tbody>
</table>
Command Register (CMD)

Commands shown in Table 3-18 are executed by loading the binary code into the CMD register.

Table 3-18: CMD Register Commands

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Command</th>
<th>Binary Code</th>
</tr>
</thead>
<tbody>
<tr>
<td>WCFG</td>
<td>Write Configuration Data</td>
<td>0001</td>
</tr>
<tr>
<td>MFWR</td>
<td>Multi-Frame Write</td>
<td>0010</td>
</tr>
<tr>
<td>DGHIGH</td>
<td>De-asserts GHIGH</td>
<td>0011</td>
</tr>
<tr>
<td>RCFG</td>
<td>Read Configuration Data</td>
<td>0100</td>
</tr>
<tr>
<td>START</td>
<td>Begin STARTUP Sequence</td>
<td>0101</td>
</tr>
<tr>
<td>RCAP</td>
<td>Reset CAPTURE (after Single-Shot Capture)</td>
<td>0110</td>
</tr>
<tr>
<td>RCRC</td>
<td>Reset CRC Register</td>
<td>0111</td>
</tr>
<tr>
<td>AGHIGH</td>
<td>Assert GHIGH</td>
<td>1000</td>
</tr>
<tr>
<td>SWITCH</td>
<td>Switch CCLK Frequency</td>
<td>1001</td>
</tr>
<tr>
<td>GRESTORE</td>
<td>Pulse GRESTORE Signal</td>
<td>1010</td>
</tr>
<tr>
<td>SHUTDOWN</td>
<td>Begin SHUTDOWN Sequence</td>
<td>1011</td>
</tr>
<tr>
<td>GCAPTURE</td>
<td>Pulse GCAPTURE Signal (one shot)</td>
<td>1100</td>
</tr>
<tr>
<td>DESYNCH</td>
<td>Forces realignment to 32 bits</td>
<td>1101</td>
</tr>
</tbody>
</table>

Frame Length Register (FLR)

The FLR is used to indicate the frame size to the internal configuration logic. This allows the internal configuration logic to be identical for all Virtex-II Pro devices. The value loaded into this register is the number of actual configuration words that get loaded into the configuration memory frames.

Configuration Option Register (COR)

The COR is loaded with the user selected options from bitstream generation. See Appendix A, “BitGen and PROMGen Switches and Options.”.

Table 3-19: Configuration Option Register

<table>
<thead>
<tr>
<th>Name</th>
<th>Description</th>
<th>Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>CRC_BYPASS</td>
<td>Does not check against updated CRC value.</td>
<td>29</td>
</tr>
<tr>
<td>SHUT_RST_DCI</td>
<td>DCI resets if SHUTDOWN and AGHIGH are performed.</td>
<td>27</td>
</tr>
<tr>
<td>SHUT_RST_DCM</td>
<td>DCM resets if SHUTDOWN and AGHIGH are performed.</td>
<td>26</td>
</tr>
<tr>
<td>DONE_PIPE</td>
<td>Add pipeline stage to DONEIN.</td>
<td>25</td>
</tr>
<tr>
<td>DRIVE_DONE</td>
<td>DONE pin is an active driver, not open drain.</td>
<td>24</td>
</tr>
<tr>
<td>SINGLE</td>
<td>Readback capture is one shot.</td>
<td>23</td>
</tr>
</tbody>
</table>
Configuration Details

Table 3-19: Configuration Option Register (Continued)

<table>
<thead>
<tr>
<th>Name</th>
<th>Description</th>
<th>Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>OSCFSEL</td>
<td>Select CCLK frequency in Master Serial Mode.</td>
<td>22:17</td>
</tr>
<tr>
<td>SSCLKSRC</td>
<td>Select STARTUP block clock source.</td>
<td>16:15</td>
</tr>
<tr>
<td>DONE_CYCLE</td>
<td>Startup cycle when DONE is asserted/de-asserted.</td>
<td>14:12</td>
</tr>
<tr>
<td>MATCH_CYCLE</td>
<td>Stall in this Startup cycle until DCI match signals are asserted.</td>
<td>11:9</td>
</tr>
<tr>
<td>LOCK_CYCLE</td>
<td>Stall in this Startup cycle until DCM signals are asserted.</td>
<td>8:6</td>
</tr>
<tr>
<td>GTS_CYCLE</td>
<td>Startup cycle when GTS_CFG_B is de-asserted.</td>
<td>5:3</td>
</tr>
<tr>
<td>GWE_CYCLE</td>
<td>Startup cycle when GWE is asserted.</td>
<td>2:0</td>
</tr>
</tbody>
</table>

Control Register (CTL)
The CTL controls internal functions such as Security and Port Persistence.

Table 3-20: Control Register

<table>
<thead>
<tr>
<th>Name</th>
<th>Description</th>
<th>Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>SBITS</td>
<td>Security level.</td>
<td>4:5</td>
</tr>
<tr>
<td>PERSIST</td>
<td>Configuration ports remain after configuration.</td>
<td>3</td>
</tr>
<tr>
<td>Reserved</td>
<td>For internal use.</td>
<td>2:1</td>
</tr>
<tr>
<td>GTS_USR_B</td>
<td>Active Low global 3-state I/Os. Turns off pullups if</td>
<td></td>
</tr>
<tr>
<td></td>
<td>GTS_CFG_B is also asserted.</td>
<td>0</td>
</tr>
</tbody>
</table>

Mask Register (MASK)
The MASK is a safety mechanism that controls which bits of the CTL register can be reloaded. Prior to loading new data into the CTL register, each bit must be independently enabled by its corresponding bit in the MASK register. Any CTL bit not selected by the MASK register is ignored when reloading the CTL register.

Frame Address Register (FAR)
The FAR sets the starting frame address for the next configuration data input write cycle.

Frame Data Register Input (FDRI)
The FDRI is the input stage for configuration data frames to be stored in the configuration memory. Starting with the frame address specified in the FAR, the FDRI writes its contents to the configuration memory frames. The FDRI automatically increments the frame address after writing each frame for the number of frames specified in the FDRI write command. This is detailed in the next section.

CRC Register (CRC)
The CRC is loaded with a CRC value that is embedded in the bitstream and compared against an internally calculated CRC value. Resetting the CRC register and circuitry is controlled by the CMD register.

Frame Data Register Output (FDRO)
FDRO is an output stage for reading frame data from the configuration memory during readback. This works the same as the FDRI but with data flowing in the other direction.

Legacy Data Output Register (LOUT)
LOUT is pipeline data to be sent out the DOUT pin for serially daisy-chained configuration data output.
Status Register (STAT)

The STAT register contains bits that indicate the state of the device. Such bits include the status of error pins, global signals, the DCM, and DCI. This register is read-only and can be read using the JTAG or SelectMAP port for debugging purposes.

![Figure 3-30: Status Register Fields](image)

<table>
<thead>
<tr>
<th>Name</th>
<th>Description</th>
<th>Bit Location</th>
</tr>
</thead>
<tbody>
<tr>
<td>ID_ERROR</td>
<td>IDCODE not validated while trying to write FDRI</td>
<td>13</td>
</tr>
<tr>
<td>DONE</td>
<td>DONEIN input form DONE pin</td>
<td>12</td>
</tr>
<tr>
<td>INIT_B</td>
<td>Value of CFG_RDY (INIT_B)</td>
<td>11</td>
</tr>
<tr>
<td>MODE</td>
<td>Value or MODE pins (M2, M1, M0)</td>
<td>10:8</td>
</tr>
<tr>
<td>GHIGH_B</td>
<td>Status of GHIGH</td>
<td>7</td>
</tr>
<tr>
<td>GWE</td>
<td>Status of GWE</td>
<td>6</td>
</tr>
<tr>
<td>GTS_CFG_B</td>
<td>Status of GTS_CFG_B</td>
<td>5</td>
</tr>
<tr>
<td>IN_ERROR</td>
<td>Legacy input error</td>
<td>4</td>
</tr>
<tr>
<td>DCI_MATCH</td>
<td>DCI matched</td>
<td>3</td>
</tr>
<tr>
<td>DCM_LOCK</td>
<td>DCM matched</td>
<td>2</td>
</tr>
<tr>
<td>Reserved</td>
<td>For internal use</td>
<td>1</td>
</tr>
<tr>
<td>CRC_ERROR</td>
<td>CRC error</td>
<td>0</td>
</tr>
</tbody>
</table>
Configuration Data Processing Flow

The complete (standard) reconfiguration of a Virtex-II device follows the internal flow shown in Figure 3-31. All associated configuration commands are listed in Table 3-22.

Figure 3-31: Internal Configuration Processing Flow
The first command set prepares the internal configuration logic for the loading of the data frames. The internal configuration logic is first initialized with several CCLK cycles represented by dummy words, then it is synchronized to recognize the 32-bit word boundaries by the synchronization word. The CRC register and circuitry must then be reset by writing the RCRC command to the CMD register. The frame length size for the device being configured is then loaded into the FLR register. The configuration options are loaded into the COR. The CCLK frequency selected is specified in the COR; however, to switch to that frequency the SWITCH command must be loaded into the CMD register. The ID register is written to ensure that the correct bitstream is being used. Now the data frames can be loaded.

The second command set loads the configuration data frames. First, a WCFG (Write Configuration) command is loaded into the CMD register activating the circuitry that writes the data loaded into the FDRI into the configuration memory cells. To load a set of data frames, the starting address for the first frame is first loaded to the FAR, followed by a write command, and then by the data frames to the FDRI. The FDRI write command also specifies the amount of data that is to follow in terms of the number of 32-bit words that comprise the data frames being written. When all but the last frame has been loaded, an initial CRC checksum is loaded into the CRC register. The De-assert GHIGH (DGHIGH) is loaded into the CMD register.

<table>
<thead>
<tr>
<th>Type</th>
<th>Number of 32-bit Words</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Command Set 1</strong></td>
<td></td>
</tr>
<tr>
<td>Dummy words</td>
<td>1</td>
</tr>
<tr>
<td>Synchronization word</td>
<td>1</td>
</tr>
<tr>
<td>Write CMD (RCRC)</td>
<td>2</td>
</tr>
<tr>
<td>Write FLR</td>
<td>2</td>
</tr>
<tr>
<td>Write COR</td>
<td>2</td>
</tr>
<tr>
<td>Write ID</td>
<td>2</td>
</tr>
<tr>
<td>Write MASK</td>
<td>2</td>
</tr>
<tr>
<td>Write CMD (SWITCH)</td>
<td>2</td>
</tr>
<tr>
<td><strong>Command Set 2</strong></td>
<td></td>
</tr>
<tr>
<td>Write FAR</td>
<td>2</td>
</tr>
<tr>
<td>Write CMD (WCFG)</td>
<td>2</td>
</tr>
<tr>
<td>Write FDRI</td>
<td>part size dependent</td>
</tr>
<tr>
<td>Write CMD (DGHIGH)</td>
<td>2</td>
</tr>
<tr>
<td><strong>Command Set 3</strong></td>
<td></td>
</tr>
<tr>
<td>Write COR</td>
<td>2</td>
</tr>
<tr>
<td>Write CMD (START)</td>
<td>2</td>
</tr>
<tr>
<td>Write CTL</td>
<td>2</td>
</tr>
<tr>
<td>Write CRC</td>
<td>2</td>
</tr>
<tr>
<td>Write CMD (DESYNCH)</td>
<td></td>
</tr>
<tr>
<td>Dummy words</td>
<td>4</td>
</tr>
<tr>
<td><strong>TOTAL</strong></td>
<td>40</td>
</tr>
</tbody>
</table>
The third command set initializes the Start-Up Sequence and finishes CRC checking. After all the data frames have been loaded, the START command is loaded into the CMD register, followed by any internal control data to CTL, the final CRC value into the CRC register, and the DESYNCH command to the CMD register. The four dummy words at the end are flushed through the system to provide the finishing CCLK cycles to activate the FPGA.

Standard Bitstream

Virtex-II Pro devices have the ability to be only partially re-configured or read back. The standard bitstream, currently generated by BitGen, follows the format shown in Table 3-23, Table 3-24, and Table 3-25. This format assumes D0 is considered the MSB. It is divided into three tables to follow the three command sets described in the previous subsection. Table 3-23 shows the first set of commands in the bitstream that prepare the configuration logic for rewriting the memory frames. All commands are described as 32-bit words, since configuration data is internally processed from a common 32-bit bus.

Table 3-23:  Bitstream Header and Configuration Options

<table>
<thead>
<tr>
<th>Data Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Dummy word</td>
<td>Synchronization word</td>
</tr>
<tr>
<td>Packet Header: Write to CMD register</td>
<td>Packet Data: RCRC</td>
</tr>
<tr>
<td>Packet Header: Write to FLR register</td>
<td>Packet Data: Frame Length</td>
</tr>
<tr>
<td>Packet Header: Write to COR</td>
<td>Packet Data: Configuration options (user defined)</td>
</tr>
<tr>
<td>Packet Header: Write to ID register</td>
<td>Packet Data: IDCODE</td>
</tr>
<tr>
<td>Packet Header: Write to CMD register</td>
<td>Packet Data: SWITCH</td>
</tr>
<tr>
<td>Packet Data: WCFG</td>
<td></td>
</tr>
</tbody>
</table>

From Table 3-23, the first dummy word pads the front of the bitstream to provide the clock cycles necessary for initialization of the configuration logic. No actual processing takes place until the synchronization word is loaded. Since the Virtex-II Pro configuration logic processes data as 32-bit words, but can be configured from a serial or 8-bit source, the synchronization word is used to define the 32-bit word boundaries. That is, the first bit after the synchronization word is the first bit of the next 32-bit word, and so on.

After synchronization, all data (register writes and frame data) are encapsulated in packets. There are two kinds of packets, Header and Data. A header packet has two types: Type 1 and Type 2. Type 1 Packet Headers are used for register writes. A combination of Type 1 and Type Packet Headers are used for frame data writes. A Type 1 Packet Header, shown in Figure 3-32, is always a single 32-bit word that describes the header type, whether it is a read/write function to a specific configuration register address (see Table 3-17) as the destination, and how many 32-bit words are in the following Packet Data portion. A Type 1 Packet Data portion can contain anywhere from 0 to 2,047 32-bit data words.
The first packet header in Table 3-23 is a Type 1 packet header that specifies writing one data word to the CMD register. The following packet data is a data word specifying a reset of the CRC register (compare the data field of Table 3-23 to the binary codes of Table 3-18).

The second packet header in Table 3-23 loads the frame size into the FLR.

The third packet header loads the configuration options into the COR register. The binary description of this register is not documented. Following this is a similar write of the SWITCH command to the CMD register which selects the CCLK frequency specified in the COR. Finally, the WCFG command is loaded into the CMD register so that the loading of frame data can commence.

The fourth packet header writes to the ID register. This ensures the correct bitstream for the correct Virtex-II Pro family member.

Table 3-24 shows the packets that load all of the data frames, starting with a Type 1 packet header to load the starting frame address, which is always 0h.

Table 3-24: Bitstream Data Frames and CRC Sequence

<table>
<thead>
<tr>
<th>Data Type</th>
</tr>
</thead>
<tbody>
<tr>
<td>Packet Header: Write to FAR register</td>
</tr>
<tr>
<td>Packet Data: Starting frame address</td>
</tr>
<tr>
<td>Packet Header: Write to FDRI</td>
</tr>
<tr>
<td>Packet Header Type 2: Data words</td>
</tr>
<tr>
<td>Packet Data: Configuration data frames in 32-bit words. Total number of words specified in Type 2 Packet Header</td>
</tr>
<tr>
<td>Packet Data: CRC value</td>
</tr>
<tr>
<td>Packet Header: Write to CMD register</td>
</tr>
<tr>
<td>Packet Data: GRESTORE</td>
</tr>
<tr>
<td>Packet Header: Write to CMD register</td>
</tr>
<tr>
<td>Packet Data: DGHIGH</td>
</tr>
<tr>
<td>Packet Header: NO OP</td>
</tr>
<tr>
<td>Packet Data: one frame of NO OP</td>
</tr>
</tbody>
</table>

The loading of data frames requires a combination of Type 1 and Type 2 packet headers. Type 2 packet headers must always be preceded by a Type 1 packet header. The Type 2 packet data can be up to 67,108,863 data words in size.
The Type 2 packet header, shown in Figure 3-33, differs slightly from a Type 1 packet header in that there is no Register Address or Byte Address fields.

To write a set of data frames to the configuration memory, after the starting frame address has been loaded into the FAR, a Type 1 packet header issues a write command to the FDRI, followed by a Type 2 packet header specifying the number of data words to be loaded, and then followed by the actual frame data as Type 2 packet data. Writing data frames might require a Type 1/Type 2 packet header combination, or a Type 1 only. This depends on the amount of data being written.

Table 3-25 shows the packets needed to issue the start-up operations and load the final CRC check. The FPGA does not go active until after the final CRC is loaded. The number of clock cycles required to complete the start-up sequence depends on the BitGen options selected. Completion of the configuration process requires 8 to 16 clock cycles after the DESYNCH command. The DESYNCH command forces realignment to 32-bit boundaries and, therefore, a synchronization word is needed.

Table 3-25: Bitstream Final CRC and Start-Up Sequence

<table>
<thead>
<tr>
<th>Data Type</th>
<th>Packet Header: Write to CMD register</th>
</tr>
</thead>
<tbody>
<tr>
<td>Packet Data:</td>
<td>START</td>
</tr>
<tr>
<td>Packet Header: Write to MASK</td>
<td></td>
</tr>
<tr>
<td>Packet Data:</td>
<td>CTL mask</td>
</tr>
<tr>
<td>Packet Header: Write to CTL</td>
<td></td>
</tr>
<tr>
<td>Packet Data:</td>
<td>Control commands</td>
</tr>
<tr>
<td>Packet Header: Write to CRC</td>
<td></td>
</tr>
<tr>
<td>Packet Data:</td>
<td>CRC value</td>
</tr>
<tr>
<td>Packet Header: Write to CMD</td>
<td></td>
</tr>
<tr>
<td>Packet Data:</td>
<td>DESYNCH command</td>
</tr>
<tr>
<td>Dummy word</td>
<td></td>
</tr>
<tr>
<td>Dummy word</td>
<td></td>
</tr>
<tr>
<td>Dummy word</td>
<td></td>
</tr>
<tr>
<td>Dummy word</td>
<td></td>
</tr>
</tbody>
</table>

Typically, DONE is released within the first seven CCLK cycles after the final CRC value is loaded, but the rest of the dummy data at the end of the stream should continue to be loaded. The FPGA needs the additional clock cycles to finish internal processing, but this is not a concern when a free-running oscillator is used for CCLK. In serial mode, this requires only 16 bits (two bytes), but in SelectMAP mode, this requires 16 bytes of dummy words at the end of the bitstream. Since the intended configuration mode to be used is unknown by Bitgen, four 32-bit dummy words (16 bytes) are always placed at the end of the bitstream.

Cyclic Redundancy Checking Algorithm

Virtex-II Pro configuration uses a standard 16-bit CRC checksum algorithm to verify bitstream integrity during configuration. The 16-bit CRC polynomial is shown below.

\[ \text{CRC-16} = x^{16} + x^{15} + x^2 + 1 \]

The algorithm is implemented by shifting the data stream into a 16-bit shift register, shown in Figure 3-34. Register Bit(0) receives an XOR of the incoming data and the output of Bit(15). Bit(2) receives an XOR of the input to Bit(0) and the output of Bit(1). Bit(15) receives an XOR of the input to Bit(0) and the output of Bit(14).
**Chapter 3: Configuration**

**RA CRC Reset** resets all the CRC registers to zero. As data is shifted into the CRC circuitry, a CRC calculation accumulates in the registers. When the CRC value is loaded into the CRC calculation register, the ending CRC checksum is loaded into the CRC Register. The value loaded into the CRC Register should be zero; otherwise, the configuration failed CRC check.

Not all of the configuration stream is loaded into the CRC circuitry. Only data that is written to one of the registers shown in Table 3-22 is included. For each 32-bit word that is written to one of the registers (Table 3-22), the address code for the register and the 32-bit data word is shifted LSB first into the CRC calculation circuitry, see Figure 3-34. When multiple 32-bit words are written to the same register, the same address is loaded after each word. All other data in the configuration stream is ignored and does not affect the CRC checksum.

This description is a model that can be used to generate an identical CRC value. The actual circuitry in the device is a slightly more complex Parallel CRC circuit that produces the same result.

**Readback**

Readback is the process of reading all the data in the internal configuration memory. This can be used to verify that the current configuration data is correct and to read the current state of all internal CLB and IOB registers as well as the current LUT RAM and block RAM values.

Readback is only available through the SelectMAP and Boundary Scan interfaces. This discussion covers the use of the SelectMAP interface for performing readback. For information on using the Boundary Scan interface for readback see ‘Readback When Using Boundary Scan’ on page 405.

**Readback Verification and Capture**

Readback verification is used to verify the validity of the stored configuration data. This is most commonly used in space-based applications where exposure to radiation might alter the data stored in the configuration memory cells.

Readback capture is used to list the states of all the internal flip-flops. This can be used for hardware debugging and functional verification. When Capture is initiated, the internal register states are loaded into unused spaces in the configuration memory which can be extracted after a readback of the configuration memory.

While both Verify and Capture can be performed in one readback, each require slightly different preparation and post processing.

**Figure 3-34: Serial 16-bit CRC Circuitry**

A CRC Reset resets all the CRC registers to zero. As data is shifted into the CRC circuitry, a CRC calculation accumulates in the registers. When the CRC value is loaded into the CRC calculation register, the ending CRC checksum is loaded into the CRC Register. The value loaded into the CRC Register should be zero; otherwise, the configuration failed CRC check.

Not all of the configuration stream is loaded into the CRC circuitry. Only data that is written to one of the registers shown in Table 3-22 is included. For each 32-bit word that is written to one of the registers (Table 3-22), the address code for the register and the 32-bit data word is shifted LSB first into the CRC calculation circuitry, see Figure 3-34. When multiple 32-bit words are written to the same register, the same address is loaded after each word. All other data in the configuration stream is ignored and does not affect the CRC checksum.

This description is a model that can be used to generate an identical CRC value. The actual circuitry in the device is a slightly more complex Parallel CRC circuit that produces the same result.
Preparing for Readback in Design Entry

If only a readback verification is to be performed, there are no additional steps at the time of design entry. However, if readback capture is to be used, the Virtex-II Pro library primitive CAPTURE_VIRTEX2 must be instantiated in the user design as shown in Figure 3-35.

The CAPTURE_VIRTEX2 component is used in the FPGA design to control when the logic states of all the registers are captured into configuration memory. The CLK pin can be driven by any clock source that would synchronize Capture to the changing logic states of the registers. The CAP pin is an enable control. When CAP is asserted, the register states are captured in memory on the next CLK rising edge.

Capture can be performed in two ways: single-shot or continuous. In continuous capture, the CAP line is held High until the desired capture event occurs causing CAP to go Low. See Figure 3-35. Continuous capture does not require a readback operation to reset the CAPTURE block. In single-shot capture, the CAP line is pulsed once, and subsequent pulses are ignored until a readback operation has been performed. Captured data is read using the same process as a normal readback.

Enabling Readback in the Software

Since readback is performed through the SelectMAP interface after configuration, the configuration ports must continue to be active by setting the persistence switch in BitGen. Additionally, a readback bit file, which contains the commands to execute a readback and a bitmap for data verification, can optionally be generated by setting the readback option in BitGen. An example of the BitGen command line is shown below.

```
bitgen -w -l -m -g readback -g persist:yes...
```

The -w option overwrites existing output. The -l option generates a Logic Allocation file. The -m option generates a Mask file. The -g readback option generates a readback bit file, and the -g persist:yes option keeps the SelectMAP interface active after configuration. For more information on BitGen options, see Appendix A, “BitGen and PROMGen Switches and Options.”

Readback When Using Boundary Scan

Regular Readback Flow

It is highly recommended to perform shutdown before reading back bitstream to ensure normal operation. The Shutdown Sequence can be executed by loading the JSHUTDOWN instruction and spending at least 12 TCK cycles in RTI TAP controller state. CRC_ERROR status and configuration error (CFGERR) must be cleared after readback by issuing Reset CRC bitstream command or writing the correct CRC value to CRC register.
IEEE 1532 Readback Flow

In IEEE 1532 readback mode, full chip shutdown is performed when ISC_ENABLE is executed. At the end of readback, CRC Error status must be cleared by issuing Reset CRC command or writing the correct CRC value to CRC register. ISC_DISABLE cannot be executed correctly unless the CRC error status is cleared.
Figure 3-37: IEEE 1532 Readback Flow
Using ChipScope Pro

The ChipScope Pro on-chip verification tool is sold separately through an authorized Xilinx distributor or over the Xilinx web site. This program uses a combination of PC software and instantiated soft cores to capture states of internal signals. Communication is accomplished via the JTAG USER1 or USER2 scan chain using a Xilinx communication cable. The initial release of ChipScope Pro supports only Virtex-II and Virtex-II Pro devices and allows for internal debug of any internal user logic. ChipScope Pro also allows direct, on-chip debug of the CoreConnect bus in Virtex-II Pro devices.

ChipScope Pro supports a high speed USB interface between a host computer and the Virtex-II Pro device using the Xilinx MultiLINX cable on Windows 98/2000 platforms and the RS232 connection using the Xilinx JTAG cable on Windows 98/2000/NT platforms. Solaris 2.7 and 2.8 support is available for core generation and core insertion only. More details are available on the www.xilinx.com/chipscope web site.
Chapter 4

PCB Design Considerations

Summary

This chapter covers the following topics:

- Pinout Information
- Pinout Diagrams
- Package Specifications
- Flip-Chip Packages
- Thermal Data
- Printed Circuit Board Considerations
- Board Routability Guidelines
- XPower
- IBIS Models
- BSDL and Boundary Scan Models

Pinout Information

Introduction

This section describes the pinouts for Virtex-II Pro devices in the following packages:

- FG256 and FG456: wire-bond fine-pitch BGA of 1.00 mm pitch
- FF672, FF896, FF1152, FF1148, FF1517, FF1704, and FF1696: flip-chip fine-pitch BGA of 1.00 mm pitch

All of the devices supported in a particular package are pinout compatible and are listed in the same table (one table per package). Pins that are not available for the smaller devices are listed in the "No Connects" column.

Each device is split into eight I/O banks to allow for flexibility in the choice of I/O standards (see the Virtex-II Pro Data Sheet). Global pins, including JTAG, configuration, and power/ground pins, are listed at the end of each table. Table 4-2 provides definitions for all pin types.

The FG256 pinout (Table 4-3, page 413) is included as an example. All Virtex-II Pro pinout tables are available on the distribution CD-ROM, or on the web (at http://www.xilinx.com).

Table 4-1 shows the number of 3.3V SelectI/Os in each bank and the total for each device/package combination.
Table 4-1: 3.3V SelectIO™-Ultra Banks

<table>
<thead>
<tr>
<th>Virtex-II Pro Device</th>
<th>Package</th>
<th>Bank0</th>
<th>Bank1</th>
<th>Bank2</th>
<th>Bank3</th>
<th>Bank4</th>
<th>Bank5</th>
<th>Bank6</th>
<th>Bank7</th>
<th>Total 3.3V I/O</th>
</tr>
</thead>
<tbody>
<tr>
<td>2VP2</td>
<td>FG256</td>
<td>17</td>
<td>18</td>
<td>18</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>53</td>
</tr>
<tr>
<td></td>
<td>FG456</td>
<td>21</td>
<td>18</td>
<td>18</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>57</td>
</tr>
<tr>
<td></td>
<td>FF672</td>
<td>27</td>
<td>24</td>
<td>24</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>75</td>
</tr>
<tr>
<td>2VP4</td>
<td>FG256</td>
<td>17</td>
<td>17</td>
<td>17</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>51</td>
</tr>
<tr>
<td></td>
<td>FG456</td>
<td>21</td>
<td>40</td>
<td>42</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>103</td>
</tr>
<tr>
<td></td>
<td>FF672</td>
<td>27</td>
<td>60</td>
<td>60</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>147</td>
</tr>
<tr>
<td>2VP7</td>
<td>FG456</td>
<td>21</td>
<td>40</td>
<td>42</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>103</td>
</tr>
<tr>
<td></td>
<td>FF672</td>
<td>39</td>
<td>60</td>
<td>60</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>159</td>
</tr>
<tr>
<td></td>
<td>FF896</td>
<td>39</td>
<td>60</td>
<td>60</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>159</td>
</tr>
<tr>
<td>2VP20</td>
<td>FF896</td>
<td>55</td>
<td>84</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>139</td>
</tr>
<tr>
<td></td>
<td>FF1152</td>
<td>57</td>
<td>57</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>114</td>
</tr>
<tr>
<td>2VP30</td>
<td>FF896</td>
<td>55</td>
<td>84</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>139</td>
</tr>
<tr>
<td></td>
<td>FF1152</td>
<td>57</td>
<td>57</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>114</td>
</tr>
<tr>
<td>2VP40</td>
<td>FF1152</td>
<td>69</td>
<td>69</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>138</td>
</tr>
<tr>
<td></td>
<td>FF1148</td>
<td>69</td>
<td>69</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>138</td>
</tr>
<tr>
<td></td>
<td>FF1517</td>
<td>69</td>
<td>69</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>138</td>
</tr>
<tr>
<td>2VP50</td>
<td>FF1152</td>
<td>69</td>
<td>69</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>138</td>
</tr>
<tr>
<td></td>
<td>FF1148</td>
<td>71</td>
<td>71</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>142</td>
</tr>
<tr>
<td></td>
<td>FF1517</td>
<td>81</td>
<td>81</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>162</td>
</tr>
<tr>
<td>2VP70</td>
<td>FF1517</td>
<td>93</td>
<td>93</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>186</td>
</tr>
<tr>
<td></td>
<td>FF1704</td>
<td>93</td>
<td>93</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>186</td>
</tr>
<tr>
<td>2VP100</td>
<td>FF1704</td>
<td>104</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>104</td>
</tr>
<tr>
<td></td>
<td>FF1696</td>
<td>111</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>111</td>
</tr>
<tr>
<td>2VP125</td>
<td>FF1704</td>
<td>104</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>104</td>
</tr>
<tr>
<td></td>
<td>FF1696</td>
<td>119</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>119</td>
</tr>
</tbody>
</table>
Table 4-2 provides a description of each pin type listed in Virtex-II Pro pinout tables.

### Table 4-2: Virtex-II Pro Pin Definitions

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Direction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>User I/O Pins</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IO_LXXY_#</td>
<td>Input/Output</td>
<td>All user I/O pins are capable of differential signalling and can implement LVDS, ULVDS, BLVDS, LVPECL, or LDT pairs. Each user I/O is labeled “IO_LXXY_#”, where:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IO indicates a user I/O pin.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>LXXY indicates a differential pair, with XX a unique pair in the bank and Y = P/N for the positive and negative sides of the differential pair.</td>
</tr>
<tr>
<td></td>
<td></td>
<td># indicates the bank number (0 through 7)</td>
</tr>
<tr>
<td><strong>Dual-Function Pins</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IO_LXXY_#/ZZZ</td>
<td></td>
<td>The dual-function pins are labelled “IO_LXXY_#/ZZZ”, where ZZZ can be one of the following pins:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Per Bank - VRP, VRN, or VREF</td>
</tr>
<tr>
<td>With /ZZZ:</td>
<td></td>
<td>Globally - GCLKx(S/P), BUSY/DOUT, INIT_B, DIN/D0 – D7, RDWR_B, or CS_B</td>
</tr>
<tr>
<td>DIN / D0, D1, D2, D3, D4, D5, D6, D7</td>
<td>Input/Output</td>
<td>In SelectMAP mode, D0 through D7 are configuration data pins. These pins become user I/Os after configuration, unless the SelectMAP port is retained. In bit-serial modes, DIN (D0) is the single-data input. This pin becomes a user I/O after configuration.</td>
</tr>
<tr>
<td>CS_B</td>
<td>Input</td>
<td>In SelectMAP mode, this is the active-low Chip Select signal. The pin becomes a user I/O after configuration, unless the SelectMAP port is retained.</td>
</tr>
<tr>
<td>RDWR_B</td>
<td>Input</td>
<td>In SelectMAP mode, this is the active-low Write Enable signal. The pin becomes a user I/O after configuration, unless the SelectMAP port is retained.</td>
</tr>
<tr>
<td>BUSY/DOUT</td>
<td>Output</td>
<td>In SelectMAP mode, BUSY controls the rate at which configuration data is loaded. The pin becomes a user I/O after configuration, unless the SelectMAP port is retained. In bit-serial modes, DOUT provides preamble and configuration data to downstream devices in a daisy-chain. The pin becomes a user I/O after configuration.</td>
</tr>
<tr>
<td>INIT_B</td>
<td>Bidirectional (open-drain)</td>
<td>When Low, this pin indicates that the configuration memory is being cleared. When held Low, the start of configuration is delayed. During configuration, a Low on this output indicates that a configuration data error has occurred. The pin becomes a user I/O after configuration.</td>
</tr>
<tr>
<td>GCLKx (S/P)</td>
<td>Input</td>
<td>These are clock input pins that connect to Global Clock Buffers. These pins become regular user I/Os when not needed for clocks.</td>
</tr>
<tr>
<td>VRP</td>
<td>Input</td>
<td>This pin is for the DCI voltage reference resistor of P transistor (per bank, to be pulled low with reference resistor).</td>
</tr>
</tbody>
</table>
### Virtex-II Pro Pin Definitions (Continued)

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Direction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>VRN</td>
<td>Input</td>
<td>This pin is for the DCI voltage reference resistor of N transistor (per bank, to be pulled low with reference resistor).</td>
</tr>
<tr>
<td>ALT_VRP</td>
<td>Input</td>
<td>This is the alternative pin for the DCI voltage reference resistor of P transistor.</td>
</tr>
<tr>
<td>ALT_VRN</td>
<td>Input</td>
<td>This is the alternative pin for the DCI voltage reference resistor of N transistor.</td>
</tr>
<tr>
<td>VREF</td>
<td>Input</td>
<td>These are input threshold voltage pins. They become user I/Os when an external threshold voltage is not needed (per bank).</td>
</tr>
</tbody>
</table>

### Dedicated Pins (1)

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Direction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CCLK</td>
<td>Input/Output</td>
<td>Configuration clock. Output in Master mode or Input in Slave mode.</td>
</tr>
<tr>
<td>PROG_B</td>
<td>Input</td>
<td>Active Low asynchronous reset to configuration logic. This pin has a permanent weak pull-up resistor.</td>
</tr>
<tr>
<td>DONE</td>
<td>Input/Output</td>
<td>DONE is a bidirectional signal with an optional internal pull-up resistor. As an output, this pin indicates completion of the configuration process. As an input, a Low level on DONE can be configured to delay the start-up sequence.</td>
</tr>
<tr>
<td>M2, M1, M0</td>
<td>Input</td>
<td>Configuration mode selection.</td>
</tr>
<tr>
<td>HSWAP_EN</td>
<td>Input</td>
<td>Enable I/O pullups during configuration.</td>
</tr>
<tr>
<td>TCK</td>
<td>Input</td>
<td>Boundary Scan Clock.</td>
</tr>
<tr>
<td>TDI</td>
<td>Input</td>
<td>Boundary Scan Data Input.</td>
</tr>
<tr>
<td>TDO</td>
<td>Output (open-drain)</td>
<td>Boundary Scan Data Output.</td>
</tr>
<tr>
<td>TMS</td>
<td>Input</td>
<td>Boundary Scan Mode Select.</td>
</tr>
<tr>
<td>PWRDWN_B</td>
<td>Input</td>
<td>Power down pin.</td>
</tr>
</tbody>
</table>

### Other Pins

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Direction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>DXN, DXP</td>
<td>N/A</td>
<td>Temperature-sensing diode pins (Anode: DXP, Cathode: DXN).</td>
</tr>
<tr>
<td>V_BATT</td>
<td>Input</td>
<td>Decryptor key memory backup supply. (Do not connect if battery is not used.)</td>
</tr>
<tr>
<td>RSVD</td>
<td>N/A</td>
<td>Reserved pin - do not connect.</td>
</tr>
<tr>
<td>V_CCO</td>
<td>Input</td>
<td>Power-supply pins for the output drivers (per bank).</td>
</tr>
<tr>
<td>V_CCAUX</td>
<td>Input</td>
<td>Power-supply pins for auxiliary circuits.</td>
</tr>
<tr>
<td>V_CCINT</td>
<td>Input</td>
<td>Power-supply pins for the internal core logic.</td>
</tr>
<tr>
<td>GND</td>
<td>Input</td>
<td>Ground.</td>
</tr>
<tr>
<td>AVCCAUXRX#</td>
<td>Input</td>
<td>Analog power supply for receive circuitry of the multi gigabit transceiver (2.5V).</td>
</tr>
<tr>
<td>AVCCAUXTX#</td>
<td>Input</td>
<td>Analog power supply for transmit circuitry of the multi gigabit transceiver (2.5V).</td>
</tr>
</tbody>
</table>
Table 4-2: Virtex-II Pro Pin Definitions (Continued)

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Direction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>VTRXPAD#</td>
<td>Input</td>
<td>Receive termination supply for the multi gigabit transceiver (1.8V to 2.8V).</td>
</tr>
<tr>
<td>VTTXPAD#</td>
<td>Input</td>
<td>Transmit termination supply for the multi gigabit transceiver (1.8V to 2.8V).</td>
</tr>
<tr>
<td>GNDA#</td>
<td>Input</td>
<td>Ground for the analog circuitry of the multi gigabit transceiver.</td>
</tr>
<tr>
<td>RXPPAD#</td>
<td>Output</td>
<td>Positive differential receive port of the multi gigabit transceiver.</td>
</tr>
<tr>
<td>RXNPAD#</td>
<td>Output</td>
<td>Negative differential receive port of the multi gigabit transceiver.</td>
</tr>
<tr>
<td>TXPPAD#</td>
<td>Input</td>
<td>Positive differential transmit port of the multi gigabit transceiver.</td>
</tr>
<tr>
<td>TXNPAD#</td>
<td>Input</td>
<td>Negative differential transmit port of the multi gigabit transceiver.</td>
</tr>
</tbody>
</table>

Notes:
1. All dedicated pins (JTAG and configuration) are powered by $V_{CCAUX}$ (independent of the bank $V_{CCO}$ voltage).

FG256 Fine-Pitch BGA Package

As shown in Table 4-3, XC2VP2 and XC2VP4 Virtex-II Pro devices are available in the FG256 fine-pitch BGA package. The pins in each of these devices are identical.

The FG256 pinout information (Table 4-3) is included as an example. All Virtex-II Pro pinout tables are available on the distribution CD-ROM, or on the web (at www.xilinx.com).

Table 4-3: FG256 — XC2VP2 and XC2VP4

<table>
<thead>
<tr>
<th>Bank</th>
<th>Pin Description</th>
<th>Pin Number</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>IO_L01N_0/VRP_0</td>
<td>C2</td>
</tr>
<tr>
<td>0</td>
<td>IO_L01P_0/VRN_0</td>
<td>C3</td>
</tr>
<tr>
<td>0</td>
<td>IO_L02N_0</td>
<td>B3</td>
</tr>
<tr>
<td>0</td>
<td>IO_L02P_0</td>
<td>C4</td>
</tr>
<tr>
<td>0</td>
<td>IO_L03N_0</td>
<td>A2</td>
</tr>
<tr>
<td>0</td>
<td>IO_L03P_0/VREF_0</td>
<td>A3</td>
</tr>
<tr>
<td>0</td>
<td>IO_L06N_0</td>
<td>D5</td>
</tr>
<tr>
<td>0</td>
<td>IO_L06P_0</td>
<td>C5</td>
</tr>
<tr>
<td>0</td>
<td>IO_L07P_0</td>
<td>D6</td>
</tr>
<tr>
<td>0</td>
<td>IO_L09N_0</td>
<td>E6</td>
</tr>
<tr>
<td>0</td>
<td>IO_L09P_0/VREF_0</td>
<td>E7</td>
</tr>
<tr>
<td>0</td>
<td>IO_L69N_0</td>
<td>D7</td>
</tr>
<tr>
<td>0</td>
<td>IO_L69P_0/VREF_0</td>
<td>C7</td>
</tr>
<tr>
<td>0</td>
<td>IO_L74N_0/GCLK7P</td>
<td>D8</td>
</tr>
<tr>
<td>0</td>
<td>IO_L74P_0/GCLK6S</td>
<td>C8</td>
</tr>
<tr>
<td>0</td>
<td>IO_L75N_0/GCLK5P</td>
<td>B8</td>
</tr>
<tr>
<td>0</td>
<td>IO_L75P_0/GCLK4S</td>
<td>A8</td>
</tr>
<tr>
<td>Bank</td>
<td>Pin Description</td>
<td>Pin Number</td>
</tr>
<tr>
<td>------</td>
<td>----------------</td>
<td>------------</td>
</tr>
<tr>
<td>1</td>
<td>IO_L75N_1/GCLK3P</td>
<td>A9</td>
</tr>
<tr>
<td>1</td>
<td>IO_L75P_1/GCLK2S</td>
<td>B9</td>
</tr>
<tr>
<td>1</td>
<td>IO_L74N_1/GCLK1P</td>
<td>C9</td>
</tr>
<tr>
<td>1</td>
<td>IO_L74P_1/GCLK0S</td>
<td>D9</td>
</tr>
<tr>
<td>1</td>
<td>IO_L69N_1/VREF_1</td>
<td>C10</td>
</tr>
<tr>
<td>1</td>
<td>IO_L69P_1</td>
<td>D10</td>
</tr>
<tr>
<td>1</td>
<td>IO_L09N_1/VREF_1</td>
<td>E10</td>
</tr>
<tr>
<td>1</td>
<td>IO_L09P_1</td>
<td>E11</td>
</tr>
<tr>
<td>1</td>
<td>IO_L07N_1</td>
<td>D11</td>
</tr>
<tr>
<td>1</td>
<td>IO_L06N_1</td>
<td>C12</td>
</tr>
<tr>
<td>1</td>
<td>IO_L06P_1</td>
<td>D12</td>
</tr>
<tr>
<td>1</td>
<td>IO_L03N_1/VREF_1</td>
<td>A14</td>
</tr>
<tr>
<td>1</td>
<td>IO_L03P_1</td>
<td>A15</td>
</tr>
<tr>
<td>1</td>
<td>IO_L02N_1</td>
<td>C13</td>
</tr>
<tr>
<td>1</td>
<td>IO_L02P_1</td>
<td>B14</td>
</tr>
<tr>
<td>1</td>
<td>IO_L01N_1/VRP_1</td>
<td>C14</td>
</tr>
<tr>
<td>1</td>
<td>IO_L01P_1/VRN_1</td>
<td>C15</td>
</tr>
<tr>
<td>2</td>
<td>IO_L01N_2/VRP_2</td>
<td>E14</td>
</tr>
<tr>
<td>2</td>
<td>IO_L01P_2/VRN_2</td>
<td>E15</td>
</tr>
<tr>
<td>2</td>
<td>IO_L02N_2</td>
<td>E13</td>
</tr>
<tr>
<td>2</td>
<td>IO_L02P_2</td>
<td>F12</td>
</tr>
<tr>
<td>2</td>
<td>IO_L03N_2</td>
<td>F13</td>
</tr>
<tr>
<td>2</td>
<td>IO_L03P_2</td>
<td>F14</td>
</tr>
<tr>
<td>2</td>
<td>IO_L04N_2/VREF_2</td>
<td>F15</td>
</tr>
<tr>
<td>2</td>
<td>IO_L04P_2</td>
<td>F16</td>
</tr>
<tr>
<td>2</td>
<td>IO_L06N_2</td>
<td>G13</td>
</tr>
<tr>
<td>2</td>
<td>IO_L06P_2</td>
<td>G14</td>
</tr>
<tr>
<td>2</td>
<td>IO_L85N_2</td>
<td>G15</td>
</tr>
<tr>
<td>2</td>
<td>IO_L85P_2</td>
<td>G16</td>
</tr>
<tr>
<td>2</td>
<td>IO_L86N_2</td>
<td>G12</td>
</tr>
<tr>
<td>2</td>
<td>IO_L86P_2</td>
<td>H13</td>
</tr>
<tr>
<td>2</td>
<td>IO_L88N_2/VREF_2</td>
<td>H14</td>
</tr>
<tr>
<td>2</td>
<td>IO_L88P_2</td>
<td>H15</td>
</tr>
<tr>
<td>2</td>
<td>IO_L90N_2</td>
<td>H16</td>
</tr>
<tr>
<td>2</td>
<td>IO_L90P_2</td>
<td>J16</td>
</tr>
</tbody>
</table>
## Pinout Information

**Table 4-3: FG256 — XC2VP2 and XC2VP4 (Continued)**

<table>
<thead>
<tr>
<th>Bank</th>
<th>Pin Description</th>
<th>Pin Number</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>IO_L90N_3</td>
<td>J15</td>
</tr>
<tr>
<td>3</td>
<td>IO_L90P_3</td>
<td>J14</td>
</tr>
<tr>
<td>3</td>
<td>IO_L89N_3</td>
<td>J13</td>
</tr>
<tr>
<td>3</td>
<td>IO_L89P_3</td>
<td>K12</td>
</tr>
<tr>
<td>3</td>
<td>IO_L87N_3/VREF_3</td>
<td>K16</td>
</tr>
<tr>
<td>3</td>
<td>IO_L87P_3</td>
<td>K15</td>
</tr>
<tr>
<td>3</td>
<td>IO_L85N_3</td>
<td>K14</td>
</tr>
<tr>
<td>3</td>
<td>IO_L85P_3</td>
<td>K13</td>
</tr>
<tr>
<td>3</td>
<td>IO_L06N_3</td>
<td>L16</td>
</tr>
<tr>
<td>3</td>
<td>IO_L06P_3</td>
<td>L15</td>
</tr>
<tr>
<td>3</td>
<td>IO_L05N_3</td>
<td>L14</td>
</tr>
<tr>
<td>3</td>
<td>IO_L05P_3</td>
<td>L13</td>
</tr>
<tr>
<td>3</td>
<td>IO_L03N_3/VREF_3</td>
<td>L12</td>
</tr>
<tr>
<td>3</td>
<td>IO_L03P_3</td>
<td>M13</td>
</tr>
<tr>
<td>3</td>
<td>IO_L02N_3</td>
<td>M16</td>
</tr>
<tr>
<td>3</td>
<td>IO_L02P_3</td>
<td>N16</td>
</tr>
<tr>
<td>3</td>
<td>IO_L01N_3/VRP_3</td>
<td>M15</td>
</tr>
<tr>
<td>3</td>
<td>IO_L01P_3/VRN_3</td>
<td>M14</td>
</tr>
<tr>
<td>4</td>
<td>IO_L01N_4/DOUT</td>
<td>P15</td>
</tr>
<tr>
<td>4</td>
<td>IO_L01P_4/INIT_B</td>
<td>P14</td>
</tr>
<tr>
<td>4</td>
<td>IO_L02N_4/D0</td>
<td>R14</td>
</tr>
<tr>
<td>4</td>
<td>IO_L02P_4/D1</td>
<td>P13</td>
</tr>
<tr>
<td>4</td>
<td>IO_L03N_4/D2</td>
<td>T15</td>
</tr>
<tr>
<td>4</td>
<td>IO_L03P_4/D3</td>
<td>T14</td>
</tr>
<tr>
<td>4</td>
<td>IO_L06N_4/VRP_4</td>
<td>N12</td>
</tr>
<tr>
<td>4</td>
<td>IO_L06P_4/VRN_4</td>
<td>P12</td>
</tr>
<tr>
<td>4</td>
<td>IO_L07P_4/VREF_4</td>
<td>N11</td>
</tr>
<tr>
<td>4</td>
<td>IO_L09N_4</td>
<td>M11</td>
</tr>
<tr>
<td>4</td>
<td>IO_L09P_4/VREF_4</td>
<td>M10</td>
</tr>
<tr>
<td>4</td>
<td>IO_L69N_4</td>
<td>N10</td>
</tr>
<tr>
<td>4</td>
<td>IO_L69P_4/VREF_4</td>
<td>P10</td>
</tr>
<tr>
<td>4</td>
<td>IO_L74N_4/GCLK3S</td>
<td>N9</td>
</tr>
<tr>
<td>4</td>
<td>IO_L74P_4/GCLK2P</td>
<td>P9</td>
</tr>
<tr>
<td>4</td>
<td>IO_L75N_4/GCLK1S</td>
<td>R9</td>
</tr>
</tbody>
</table>
### Table 4-3: FG256 — XC2VP2 and XC2VP4 (Continued)

<table>
<thead>
<tr>
<th>Bank</th>
<th>Pin Description</th>
<th>Pin Number</th>
</tr>
</thead>
<tbody>
<tr>
<td>4</td>
<td>IO_L75P_4/GCLK0P</td>
<td>T9</td>
</tr>
<tr>
<td></td>
<td>IO_L75N_5/GCLK7S</td>
<td>T8</td>
</tr>
<tr>
<td>5</td>
<td>IO_L75P_5/GCLK6P</td>
<td>R8</td>
</tr>
<tr>
<td>5</td>
<td>IO_L74N_5/GCLK5S</td>
<td>P8</td>
</tr>
<tr>
<td>5</td>
<td>IO_L74P_5/GCLK4P</td>
<td>N8</td>
</tr>
<tr>
<td>5</td>
<td>IO_L69N_5/VREF_5</td>
<td>P7</td>
</tr>
<tr>
<td>5</td>
<td>IO_L69P_5</td>
<td>N7</td>
</tr>
<tr>
<td>5</td>
<td>IO_L09N_5/VREF_5</td>
<td>M7</td>
</tr>
<tr>
<td>5</td>
<td>IO_L09P_5</td>
<td>M6</td>
</tr>
<tr>
<td>5</td>
<td>IO_L07N_5/VREF_5</td>
<td>N6</td>
</tr>
<tr>
<td>5</td>
<td>IO_L06N_5/VRP_5</td>
<td>P5</td>
</tr>
<tr>
<td>5</td>
<td>IO_L06P_5/VRN_5</td>
<td>N5</td>
</tr>
<tr>
<td>5</td>
<td>IO_L03N_5/D4</td>
<td>T3</td>
</tr>
<tr>
<td>5</td>
<td>IO_L03P_5/D5</td>
<td>T2</td>
</tr>
<tr>
<td>5</td>
<td>IO_L02N_5/D6</td>
<td>P4</td>
</tr>
<tr>
<td>5</td>
<td>IO_L02P_5/D7</td>
<td>R3</td>
</tr>
<tr>
<td>5</td>
<td>IO_L01N_5/RDWR_B</td>
<td>P3</td>
</tr>
<tr>
<td>5</td>
<td>IO_L01P_5/CS_B</td>
<td>P2</td>
</tr>
<tr>
<td>6</td>
<td>IO_L01P_6/VRN_6</td>
<td>M3</td>
</tr>
<tr>
<td>6</td>
<td>IO_L01N_6/VRP_6</td>
<td>M2</td>
</tr>
<tr>
<td>6</td>
<td>IO_L02P_6</td>
<td>N1</td>
</tr>
<tr>
<td>6</td>
<td>IO_L02N_6</td>
<td>M1</td>
</tr>
<tr>
<td>6</td>
<td>IO_L03P_6</td>
<td>M4</td>
</tr>
<tr>
<td>6</td>
<td>IO_L03N_6/VREF_6</td>
<td>L5</td>
</tr>
<tr>
<td>6</td>
<td>IO_L05P_6</td>
<td>L4</td>
</tr>
<tr>
<td>6</td>
<td>IO_L05N_6</td>
<td>L3</td>
</tr>
<tr>
<td>6</td>
<td>IO_L06P_6</td>
<td>L2</td>
</tr>
<tr>
<td>6</td>
<td>IO_L06N_6</td>
<td>L1</td>
</tr>
<tr>
<td>6</td>
<td>IO_L85P_6</td>
<td>K4</td>
</tr>
<tr>
<td>6</td>
<td>IO_L85N_6</td>
<td>K3</td>
</tr>
<tr>
<td>6</td>
<td>IO_L87P_6</td>
<td>K2</td>
</tr>
<tr>
<td>6</td>
<td>IO_L87N_6/VREF_6</td>
<td>K1</td>
</tr>
<tr>
<td>6</td>
<td>IO_L89P_6</td>
<td>K5</td>
</tr>
<tr>
<td>6</td>
<td>IO_L89N_6</td>
<td>J4</td>
</tr>
<tr>
<td>Bank</td>
<td>Pin Description</td>
<td>Pin Number</td>
</tr>
<tr>
<td>------</td>
<td>--------------------</td>
<td>------------</td>
</tr>
<tr>
<td>6</td>
<td>IO_L90P_6</td>
<td>J3</td>
</tr>
<tr>
<td>6</td>
<td>IO_L90N_6</td>
<td>J2</td>
</tr>
<tr>
<td>7</td>
<td>IO_L90P_7</td>
<td>J1</td>
</tr>
<tr>
<td>7</td>
<td>IO_L90N_7</td>
<td>H1</td>
</tr>
<tr>
<td>7</td>
<td>IO_L88P_7</td>
<td>H2</td>
</tr>
<tr>
<td>7</td>
<td>IO_L88N_7/VREF_7</td>
<td>H3</td>
</tr>
<tr>
<td>7</td>
<td>IO_L86P_7</td>
<td>H4</td>
</tr>
<tr>
<td>7</td>
<td>IO_L86N_7</td>
<td>G5</td>
</tr>
<tr>
<td>7</td>
<td>IO_L85P_7</td>
<td>G1</td>
</tr>
<tr>
<td>7</td>
<td>IO_L85N_7</td>
<td>G2</td>
</tr>
<tr>
<td>7</td>
<td>IO_L06P_7</td>
<td>G3</td>
</tr>
<tr>
<td>7</td>
<td>IO_L06N_7</td>
<td>G4</td>
</tr>
<tr>
<td>7</td>
<td>IO_L04P_7</td>
<td>F1</td>
</tr>
<tr>
<td>7</td>
<td>IO_L04N_7/VREF_7</td>
<td>F2</td>
</tr>
<tr>
<td>7</td>
<td>IO_L03P_7</td>
<td>F3</td>
</tr>
<tr>
<td>7</td>
<td>IO_L03N_7</td>
<td>F4</td>
</tr>
<tr>
<td>7</td>
<td>IO_L02P_7</td>
<td>F5</td>
</tr>
<tr>
<td>7</td>
<td>IO_L02N_7</td>
<td>E4</td>
</tr>
<tr>
<td>7</td>
<td>IO_L01P_7/VRN_7</td>
<td>E2</td>
</tr>
<tr>
<td>7</td>
<td>IO_L01N_7/VRP_7</td>
<td>E3</td>
</tr>
<tr>
<td>0</td>
<td>VCCO_0</td>
<td>F8</td>
</tr>
<tr>
<td>0</td>
<td>VCCO_0</td>
<td>F7</td>
</tr>
<tr>
<td>0</td>
<td>VCCO_0</td>
<td>E8</td>
</tr>
<tr>
<td>1</td>
<td>VCCO_1</td>
<td>F9</td>
</tr>
<tr>
<td>1</td>
<td>VCCO_1</td>
<td>F10</td>
</tr>
<tr>
<td>1</td>
<td>VCCO_1</td>
<td>E9</td>
</tr>
<tr>
<td>2</td>
<td>VCCO_2</td>
<td>H12</td>
</tr>
<tr>
<td>2</td>
<td>VCCO_2</td>
<td>H11</td>
</tr>
<tr>
<td>2</td>
<td>VCCO_2</td>
<td>G11</td>
</tr>
<tr>
<td>3</td>
<td>VCCO_3</td>
<td>K11</td>
</tr>
<tr>
<td>3</td>
<td>VCCO_3</td>
<td>J12</td>
</tr>
<tr>
<td>3</td>
<td>VCCO_3</td>
<td>J11</td>
</tr>
<tr>
<td>4</td>
<td>VCCO_4</td>
<td>M9</td>
</tr>
<tr>
<td>4</td>
<td>VCCO_4</td>
<td>L9</td>
</tr>
</tbody>
</table>
Table 4-3: FG256 — XC2VP2 and XC2VP4 (Continued)

<table>
<thead>
<tr>
<th>Bank</th>
<th>Pin Description</th>
<th>Pin Number</th>
</tr>
</thead>
<tbody>
<tr>
<td>4</td>
<td>VCCO_4</td>
<td>L10</td>
</tr>
<tr>
<td>5</td>
<td>VCCO_5</td>
<td>M8</td>
</tr>
<tr>
<td>5</td>
<td>VCCO_5</td>
<td>L8</td>
</tr>
<tr>
<td>5</td>
<td>VCCO_5</td>
<td>L7</td>
</tr>
<tr>
<td>6</td>
<td>VCCO_6</td>
<td>K6</td>
</tr>
<tr>
<td>6</td>
<td>VCCO_6</td>
<td>J6</td>
</tr>
<tr>
<td>6</td>
<td>VCCO_6</td>
<td>J5</td>
</tr>
<tr>
<td>7</td>
<td>VCCO_7</td>
<td>H6</td>
</tr>
<tr>
<td>7</td>
<td>VCCO_7</td>
<td>H5</td>
</tr>
<tr>
<td>7</td>
<td>VCCO_7</td>
<td>G6</td>
</tr>
<tr>
<td>N/A</td>
<td>CCLK</td>
<td>N15</td>
</tr>
<tr>
<td>N/A</td>
<td>PROG_B</td>
<td>D1</td>
</tr>
<tr>
<td>N/A</td>
<td>DONE</td>
<td>P16</td>
</tr>
<tr>
<td>N/A</td>
<td>M0</td>
<td>N3</td>
</tr>
<tr>
<td>N/A</td>
<td>M1</td>
<td>N2</td>
</tr>
<tr>
<td>N/A</td>
<td>M2</td>
<td>P1</td>
</tr>
<tr>
<td>N/A</td>
<td>TCK</td>
<td>D16</td>
</tr>
<tr>
<td>N/A</td>
<td>TDI</td>
<td>E1</td>
</tr>
<tr>
<td>N/A</td>
<td>TDO</td>
<td>E16</td>
</tr>
<tr>
<td>N/A</td>
<td>TMS</td>
<td>C16</td>
</tr>
<tr>
<td>N/A</td>
<td>PWRDWN_B</td>
<td>N14</td>
</tr>
<tr>
<td>N/A</td>
<td>HSWAP_EN</td>
<td>C1</td>
</tr>
<tr>
<td>N/A</td>
<td>RSVd</td>
<td>D14</td>
</tr>
<tr>
<td>N/A</td>
<td>VBATT</td>
<td>D15</td>
</tr>
<tr>
<td>N/A</td>
<td>DXP</td>
<td>D2</td>
</tr>
<tr>
<td>N/A</td>
<td>DXN</td>
<td>D3</td>
</tr>
<tr>
<td>N/A</td>
<td>AVCCAUXTX6</td>
<td>B5</td>
</tr>
<tr>
<td>N/A</td>
<td>VTTXPAD6</td>
<td>B4</td>
</tr>
<tr>
<td>N/A</td>
<td>TXNPAD6</td>
<td>A4</td>
</tr>
<tr>
<td>N/A</td>
<td>TXPPAD6</td>
<td>A5</td>
</tr>
<tr>
<td>N/A</td>
<td>GNDA6</td>
<td>C6</td>
</tr>
<tr>
<td>N/A</td>
<td>GNDA6</td>
<td>C6</td>
</tr>
<tr>
<td>N/A</td>
<td>RXPPAD6</td>
<td>A6</td>
</tr>
<tr>
<td>N/A</td>
<td>RXNPAD6</td>
<td>A7</td>
</tr>
<tr>
<td>N/A</td>
<td>VTRXPAD6</td>
<td>B6</td>
</tr>
</tbody>
</table>
### Pinout Information

**Table 4-3: FG256 — XC2VP2 and XC2VP4 (Continued)**

<table>
<thead>
<tr>
<th>Bank</th>
<th>Pin Description</th>
<th>Pin Number</th>
</tr>
</thead>
<tbody>
<tr>
<td>N/A</td>
<td>AVCCAUXXRX6</td>
<td>B7</td>
</tr>
<tr>
<td>N/A</td>
<td>AVCCAUXXTX7</td>
<td>B11</td>
</tr>
<tr>
<td>N/A</td>
<td>VTTXPAD7</td>
<td>B10</td>
</tr>
<tr>
<td>N/A</td>
<td>TXNPAD7</td>
<td>A10</td>
</tr>
<tr>
<td>N/A</td>
<td>TXPPAD7</td>
<td>A11</td>
</tr>
<tr>
<td>N/A</td>
<td>GNDA7</td>
<td>C11</td>
</tr>
<tr>
<td>N/A</td>
<td>GNDA7</td>
<td>C11</td>
</tr>
<tr>
<td>N/A</td>
<td>RXPPAD7</td>
<td>A12</td>
</tr>
<tr>
<td>N/A</td>
<td>RXNPAD7</td>
<td>A13</td>
</tr>
<tr>
<td>N/A</td>
<td>VTRXPAD7</td>
<td>B12</td>
</tr>
<tr>
<td>N/A</td>
<td>AVCCAUXXRX7</td>
<td>B13</td>
</tr>
<tr>
<td>N/A</td>
<td>AVCCAUXXRX18</td>
<td>R13</td>
</tr>
<tr>
<td>N/A</td>
<td>VTRXPAD18</td>
<td>R12</td>
</tr>
<tr>
<td>N/A</td>
<td>RXNPAD18</td>
<td>T13</td>
</tr>
<tr>
<td>N/A</td>
<td>RXPPAD18</td>
<td>T12</td>
</tr>
<tr>
<td>N/A</td>
<td>GNDA18</td>
<td>P11</td>
</tr>
<tr>
<td>N/A</td>
<td>GNDA18</td>
<td>P11</td>
</tr>
<tr>
<td>N/A</td>
<td>TXPPAD18</td>
<td>T11</td>
</tr>
<tr>
<td>N/A</td>
<td>TXNPAD18</td>
<td>T10</td>
</tr>
<tr>
<td>N/A</td>
<td>VTTXPAD18</td>
<td>R10</td>
</tr>
<tr>
<td>N/A</td>
<td>AVCCAUXXTX18</td>
<td>R11</td>
</tr>
<tr>
<td>N/A</td>
<td>AVCCAUXXRX19</td>
<td>R7</td>
</tr>
<tr>
<td>N/A</td>
<td>VTRXPAD19</td>
<td>R6</td>
</tr>
<tr>
<td>N/A</td>
<td>RXNPAD19</td>
<td>T7</td>
</tr>
<tr>
<td>N/A</td>
<td>RXPPAD19</td>
<td>T6</td>
</tr>
<tr>
<td>N/A</td>
<td>GNDA19</td>
<td>P6</td>
</tr>
<tr>
<td>N/A</td>
<td>GNDA19</td>
<td>P6</td>
</tr>
<tr>
<td>N/A</td>
<td>TXPPAD19</td>
<td>T5</td>
</tr>
<tr>
<td>N/A</td>
<td>TXNPAD19</td>
<td>T4</td>
</tr>
<tr>
<td>N/A</td>
<td>VTTXPAD19</td>
<td>R4</td>
</tr>
<tr>
<td>N/A</td>
<td>AVCCAUXXTX19</td>
<td>R5</td>
</tr>
<tr>
<td>N/A</td>
<td>VCCINT</td>
<td>N4</td>
</tr>
<tr>
<td>N/A</td>
<td>VCCINT</td>
<td>N13</td>
</tr>
<tr>
<td>N/A</td>
<td>VCCINT</td>
<td>M5</td>
</tr>
<tr>
<td>N/A</td>
<td>VCCINT</td>
<td>M12</td>
</tr>
</tbody>
</table>
### Table 4-3: FG256 — XC2VP2 and XC2VP4 (Continued)

<table>
<thead>
<tr>
<th>Bank</th>
<th>Pin Description</th>
<th>Pin Number</th>
</tr>
</thead>
<tbody>
<tr>
<td>N/A</td>
<td>VCCINT</td>
<td>E5</td>
</tr>
<tr>
<td>N/A</td>
<td>VCCINT</td>
<td>E12</td>
</tr>
<tr>
<td>N/A</td>
<td>VCCINT</td>
<td>D4</td>
</tr>
<tr>
<td>N/A</td>
<td>VCCINT</td>
<td>D13</td>
</tr>
<tr>
<td>N/A</td>
<td>VCCAUX</td>
<td>R16</td>
</tr>
<tr>
<td>N/A</td>
<td>VCCAUX</td>
<td>R1</td>
</tr>
<tr>
<td>N/A</td>
<td>VCCAUX</td>
<td>B16</td>
</tr>
<tr>
<td>N/A</td>
<td>VCCAUX</td>
<td>B1</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>T16</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>T1</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>R2</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>R15</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>L6</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>L11</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>K9</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>K8</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>K7</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>K10</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>J9</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>J8</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>J7</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>J10</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>H9</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>H8</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>H7</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>H10</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>G9</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>G8</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>G7</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>G10</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>F6</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>F11</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>B2</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>B15</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>A16</td>
</tr>
<tr>
<td>N/A</td>
<td>GND</td>
<td>A1</td>
</tr>
</tbody>
</table>
Pinout Diagrams

This section contains pinout diagrams for all Virtex-II Pro package/device combinations:

- **FG256 Fine-Pitch BGA Pinout Diagrams**
  - FG256 Composite Pinout Diagram (XC2VP2, XC2VP4), page 423
  - FG256 Banked Pins (XC2VP2, XC2VP4), page 424
  - FG256 Dedicated/Other Pins (XC2VP2, XC2VP4), page 425

- **FG456 Fine-Pitch BGA Pinout Diagrams**
  - FG456 Composite Pinout Diagram (XC2VP7), page 427
  - FG456 Dedicated/Other Pins (XC2VP7), page 428
  - FG456 Composite Pinout Diagram (XC2VP4), page 429
  - FG456 Banked Pins (XC2VP4, XC2VP7), page 430
  - FG456 Composite Pinout Diagram (XC2VP2), page 431
  - FG456 Banked Pins (XC2VP2), page 432
  - FG456 Dedicated/Other Pins (XC2VP2, XC2VP4), page 433

- **FF672 Flip-Chip Fine-Pitch BGA Pinout Diagrams**
  - FF672 Composite Pinout Diagram (XC2VP7), page 435
  - FF672 Banked Pins (XC2VP7), page 436
  - FF672 Dedicated/Other Pins (XC2VP7), page 437
  - FF672 Composite Pinout Diagram (XC2VP4), page 438
  - FF672 Banked Pins (XC2VP4), page 439
  - FF672 Composite Pinout Diagram (XC2VP2), page 440
  - FF672 Banked Pins (XC2VP2), page 441
  - FF672 Dedicated/Other Pins (XC2VP2, XC2VP4), page 442

- **FF896 Flip-Chip Fine-Pitch BGA Pinout Diagrams**
  - FF896 Composite Pinout Diagram (XC2VP20, XC2VP30), page 443
  - FF896 Banked Pins (XC2VP20, XC2VP30), page 444
  - FF896 Composite Pinout Diagram (XC2VP7), page 445
  - FF896 Banked Pins (XC2VP7), page 446
  - FF896 Dedicated/Other Pins (XC2VP7, XC2VP20, XC2VP30), page 447

- **FF1152 Flip-Chip Fine-Pitch BGA Pinout Diagrams**
  - FF1152 Composite Pinout Diagram (XC2VP50), page 449
  - FF1152 Dedicated/Other Pins (XC2VP50), page 450
  - FF1152 Composite Pinout Diagram (XC2VP40), page 451
  - FF1152 Banked Pins (XC2VP40, XC2VP50), page 452
  - FF1152 Dedicated/Other Pins (XC2VP40), page 453
  - FF1152 Composite Pinout Diagram (XC2VP30), page 454
  - FF1152 Banked Pins (XC2VP30), page 455
  - FF1152 Dedicated/Other Pins (XC2VP30), page 456
  - FF1152 Composite Pinout Diagram (XC2VP20), page 457
  - FF1152 Banked Pins (XC2VP20), page 458
  - FF1152 Dedicated/Other Pins (XC2VP20), page 459
• **FF1148 Flip-Chip Fine-Pitch BGA Pinout Diagrams**
  - FF1148 Composite Pinout Diagram (XC2VP50), page 461
  - FF1148 Banked Pins (XC2VP50), page 462
  - FF1148 Composite Pinout Diagram (XC2VP40), page 463
  - FF1148 Banked Pins (XC2VP40), page 464
  - FF1148 Dedicated/Other Pins (XC2VP40, XC2VP50), page 465

• **FF1517 Flip-Chip Fine-Pitch BGA Pinout Diagrams**
  - FF1517 Composite Pinout Diagram (XC2VP70), page 467
  - FF1517 Banked Pins (XC2VP70), page 468
  - FF1517 Composite Pinout Diagram (XC2VP50), page 469
  - FF1517 Banked Pins (XC2VP50), page 470
  - FF1517 Dedicated/Other Pins (XC2VP50, XC2VP70), page 471
  - FF1517 Composite Pinout Diagram (XC2VP40), page 472
  - FF1517 Banked Pins (XC2VP40), page 473
  - FF1517 Dedicated/Other Pins (XC2VP40), page 474

• **FF1704 Flip-Chip Fine-Pitch BGA Pinout Diagrams**
  - FF1704 Composite Pinout Diagram (XC2VP100, XC2VP125), page 475
  - FF1704 Banked Pins (XC2VP100, XC2VP125), page 476
  - FF1704 Composite Pinout Diagram (XC2VP70), page 477
  - FF1704 Banked Pins (XC2VP70), page 478
  - FF1704 Dedicated/Other Pins (XC2VP70, XC2VP100, XC2VP125), page 479

• **FF1696 Flip-Chip Fine-Pitch BGA Pinout Diagrams**
  - FF1696 Composite Pinout Diagram (XC2VP125), page 481
  - FF1696 Banked Pins (XC2VP125), page 482
  - FF1696 Composite Pinout Diagram (XC2VP100), page 483
  - FF1696 Banked Pins (XC2VP100), page 484
  - FF1696 Dedicated/Other Pins (XC2VP100, XC2VP125), page 485
Pinout Diagrams

FG256 Fine-Pitch BGA Pinout Diagrams

FG256 Composite Pinout Diagram (XC2VP2, XC2VP4)

Figure 4-1: FG256 Composite Pinout Diagram (XC2VP2, XC2VP4)
FG256 Banked Pins (XC2VP2, XC2VP4)

Figure 4-2: FG256 Banked Pins (XC2VP2, XC2VP4)
Figure 4-3: FG256 Dedicated/Other Pins (XC2VP2, XC2VP4)
This page intentionally left blank.
Figure 4-4: FG456 Composite Pinout Diagram (XC2VP7)
Chapter 4: PCB Design Considerations

FG456 Dedicated/Other Pins (XC2VP7)

Figure 4-5: FG456 Dedicated/Other Pins (XC2VP7)
Figure 4-6: FG456 Composite Pinout Diagram (XC2VP4)
FG456 Banked Pins (XC2VP4, XC2VP7)

Figure 4-7: FG456 Banked Pins (XC2VP4, XC2VP7)
Figure 4-8: FG456 Composite Pinout Diagram (XC2VP2)
Chapter 4: PCB Design Considerations

FG456 Banked Pins (XC2VP2)

Figure 4-9: FG456 Banked Pins (XC2VP2)
Figure 4-10: FG456 Dedicated/Other Pins (XC2VP2, XC2VP4)
This page intentionally left blank.
FF672 Composite Pinout Diagram (XC2VP7)

Figure 4-11: FF672 Flip-Chip Fine-Pitch BGA Composite Pinout Diagram
**Chapter 4: PCB Design Considerations**

**FF672 Banked Pins (XC2VP7)**

**Figure 4-12: FF672 Banked Pins (XC2VP7)**

*Callouts for max number of I/Os per bank include dual-purpose pins shown in table, right.*

<table>
<thead>
<tr>
<th>User I/O Pins</th>
<th>Dedicated Pins</th>
<th>Other Pins</th>
</tr>
</thead>
<tbody>
<tr>
<td>□ IO_LXXY_#</td>
<td></td>
<td>□ VCCO</td>
</tr>
<tr>
<td>□ Dual-Purpose Pins:</td>
<td></td>
<td>□ NO CONNECT</td>
</tr>
<tr>
<td>□ DIN/D0-D7</td>
<td></td>
<td></td>
</tr>
<tr>
<td>□ CS_B</td>
<td></td>
<td></td>
</tr>
<tr>
<td>□ RDWR_B</td>
<td></td>
<td></td>
</tr>
<tr>
<td>□ BUSY/DOUT</td>
<td></td>
<td></td>
</tr>
<tr>
<td>□ INIT_B</td>
<td></td>
<td></td>
</tr>
<tr>
<td>□ GCLKx (P)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>□ GCLKx (S)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>□ VRP</td>
<td></td>
<td></td>
</tr>
<tr>
<td>□ VRN</td>
<td></td>
<td></td>
</tr>
<tr>
<td>□ VREF</td>
<td></td>
<td></td>
</tr>
<tr>
<td>□ No Pair</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
## FF672 Dedicated/Other Pins (XC2VP7)

### FF672 (XC2VP7) - Top View

![FF672 Dedicated Pins Diagram](image)

### Table: FF672 Dedicated/Other Pins

<table>
<thead>
<tr>
<th>Dedicated Pins</th>
<th>Other Pins</th>
</tr>
</thead>
<tbody>
<tr>
<td>CCLK</td>
<td>DXN</td>
</tr>
<tr>
<td>PROG_B</td>
<td>DXP</td>
</tr>
<tr>
<td>DONE</td>
<td>VBPAT_T</td>
</tr>
<tr>
<td>M2, M1, M0</td>
<td>VCCAUXTX</td>
</tr>
<tr>
<td>HSWAP_EN</td>
<td>VTXPAD</td>
</tr>
<tr>
<td>TCK</td>
<td>GND</td>
</tr>
<tr>
<td>TDI</td>
<td>NO CONNECT</td>
</tr>
<tr>
<td>TDO</td>
<td>TXN_PAD</td>
</tr>
<tr>
<td>TMS</td>
<td>TXP_PAD</td>
</tr>
<tr>
<td>PWRDWN_B</td>
<td>RXN_PAD</td>
</tr>
</tbody>
</table>

*Figure 4-13: FF672 Dedicated Pins Diagram*
Figure 4-14: FF672 Composite Pinout Diagram (XC2VP4)
FF672 Banked Pins (XC2VP4)

Figure 4-15: **FF672 Banked Pins (XC2VP4)**
Figure 4-16: FF672 Composite Pinout Diagram (XC2VP2)
Figure 4-17: FF672 Banked Pins (XC2VP2)
Figure 4-18: FF672 Dedicated/Other Pins (XC2VP2)
FF896 Flip-Chip Fine-Pitch BGA Pinout Diagrams

FF896 Composite Pinout Diagram (XC2VP20, XC2VP30)

Figure 4-19: FF896 Composite Pinout Diagram (XC2VP20, XC2VP30)
Figure 4-20: FF896 Banked Pins (XC2VP20, XC2VP30)
FF896 Composite Pinout Diagram (XC2VP7)

**Figure 4-21:** FF896 Composite Pinout Diagram (XC2VP7)
**Chapter 4: PCB Design Considerations**

**FF896 Banked Pins (XC2VP7)**

![FF896 Banked Pins (XC2VP7) - Top View](image_url)

<table>
<thead>
<tr>
<th>User I/O Pins</th>
<th>Dedicated Pins</th>
<th>Other Pins</th>
</tr>
</thead>
<tbody>
<tr>
<td>- IO_LXXY_#</td>
<td>- VCCO</td>
<td>- NO CONNECT</td>
</tr>
<tr>
<td>- Dual-Purpose Pins:</td>
<td></td>
<td></td>
</tr>
<tr>
<td>- DIN/D0-D7</td>
<td></td>
<td></td>
</tr>
<tr>
<td>- CS_B</td>
<td></td>
<td></td>
</tr>
<tr>
<td>- RDWR_B</td>
<td></td>
<td></td>
</tr>
<tr>
<td>- BUSY/DOUT</td>
<td></td>
<td></td>
</tr>
<tr>
<td>- INIT_B</td>
<td></td>
<td></td>
</tr>
<tr>
<td>- GCLKx (P)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>- GCLKx (S)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>- VRP</td>
<td></td>
<td></td>
</tr>
<tr>
<td>- VRN</td>
<td></td>
<td></td>
</tr>
<tr>
<td>- VREF</td>
<td></td>
<td></td>
</tr>
<tr>
<td>- No Pair</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

* Callouts for max number of I/Os per bank include dual-purpose pins shown in table, right.

**Figure 4-22: FF896 Banked Pins (XC2VP7)**
FF896 Dedicated/Other Pins (XC2VP7, XC2VP20, XC2VP30)

**Figure 4-23:** FF896 Dedicated/Other Pins (XC2VP7, XC2VP20, XC2VP30)
FF1152 Flip-Chip Fine-Pitch BGA Pinout Diagrams

FF1152 Composite Pinout Diagram (XC2VP50)

Figure 4-24: FF1152 Composite Pinout Diagram (XC2VP50)
Figure 4-25: FF1152 Dedicated/Other Pins (XC2VP50)
Figure 4-26: FF1152 Composite Pinout Diagram (XC2VP40)
**Figure 4-27: FF1152 Banked Pins (XC2VP40, XC2VP50)**

**FF1152 (XC2VP50) - Top View**

- Bank 1 - 69 Max User I/Os*
- Bank 0 - 69 Max User I/Os*
- Bank 2 - 69 Max User I/Os*
- Bank 6 - 69 Max User I/Os*
- Bank 7 - 104 Max User I/Os*
- Bank 3 - 104 Max User I/Os*
- Bank 4 - 69 Max User I/Os*
- Bank 5 - 69 Max User I/Os*

---

**User I/O Pins**

- IO_LXXY_#
- Dual-Purpose Pins:
  - DIN/D0-D7
  - CS_B
  - RDWR_B
  - BUSY/DOUT
  - INIT_B
  - GCLKx (P)
  - GCLKx (S)
  - VRP
  - VRN
  - VREF
  - No Pair

**Dedicated Pins**

- VCCO

**Other Pins**

- NO CONNECT

---

* Callouts for max number of I/Os per bank include dual-purpose pins shown in table, right.
Figure 4-28: FF1152 Dedicated/Other Pins (XC2VP40)
**Figure 4-29: FF1152 Composite Pinout Diagram (XC2VP30)**

*Callouts for max number of I/Os per bank include dual-purpose pins shown in table, right.*

<table>
<thead>
<tr>
<th>User I/O Pins</th>
<th>Dedicated Pins</th>
<th>Other Pins</th>
</tr>
</thead>
<tbody>
<tr>
<td>IO_LXXY_#</td>
<td>CCLK</td>
<td>DXN</td>
</tr>
<tr>
<td>DIN/D0-D7</td>
<td>PROG_B</td>
<td>DXP</td>
</tr>
<tr>
<td>CS_B</td>
<td>DONE</td>
<td>VBATT</td>
</tr>
<tr>
<td>RDWR_B</td>
<td>M2, M1, M0</td>
<td>RSVD</td>
</tr>
<tr>
<td>BUSY/DOUT</td>
<td>HSWAP_EN</td>
<td>VCCO</td>
</tr>
<tr>
<td>INIT_B</td>
<td>TCK</td>
<td>VCCAUX</td>
</tr>
<tr>
<td>GCLKx (P)</td>
<td>TDI</td>
<td>CCINT</td>
</tr>
<tr>
<td>GCLKx (S)</td>
<td>TDO</td>
<td>GND</td>
</tr>
<tr>
<td>GVRP</td>
<td>TMS</td>
<td>NO CONNECT</td>
</tr>
<tr>
<td>VRN</td>
<td>PWRDWN_B</td>
<td></td>
</tr>
<tr>
<td>VREF</td>
<td></td>
<td></td>
</tr>
<tr>
<td>No Pair</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

* Bank 1 - 57 Max User I/Os*  
* Bank 0 - 57 Max User I/Os*  
* Bank 2 - 104 Max User I/Os*  
* Bank 7 - 104 Max User I/Os*  
* Bank 3 - 104 Max User I/Os*  
* Bank 6 - 104 Max User I/Os*  
* Bank 4 - 104 Max User I/Os*  
* Bank 5 - 104 Max User I/Os*  

*Callouts for max number of I/Os per bank include dual-purpose pins shown in table, right.*
Figure 4-30: FF1152 Banked Pins (XC2VP30)
Figure 4-31: FF1152 Dedicated/Other Pins (XC2VP30)
Figure 4-32: FF1152 Composite Pinout Diagram (XC2VP20)
FF1152 Banked Pins (XC2VP20)

**Figure 4-33: FF1152 Banked Pins (XC2VP20)**

*Callouts for max number of I/Os per bank include dual-purpose pins shown in table, right.*

**User I/O Pins**

- IO_LXXY_#
- Dual-Purpose Pins:
  - DIN/D0-D7
  - CS_B
  - RDWR_B
  - BUSY/DOUT
  - INIT_B
  - GCLKx (P)
  - GCLKx (S)
  - VRP
  - VRN
  - VREF
  - No Pair

<table>
<thead>
<tr>
<th>Dedicated Pins</th>
<th>Other Pins</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>VCCO</td>
</tr>
<tr>
<td></td>
<td>NO CONNECT</td>
</tr>
</tbody>
</table>
Figure 4-34: FF1152 Dedicated/Other Pins (XC2VP20)
This page intentionally left blank.
FF1148 Composite Pinout Diagram (XC2VP50)

Figure 4-35: FF1148 Composite Pinout Diagram (XC2VP50)
FF1148 Banked Pins (XC2VP50)

**Figure 4-36: FF1148 Banked Pins (XC2VP50)**
Figure 4-37: FF1148 Composite Pinout Diagram (XC2VP40)
FF1148 Banked Pins (XC2VP40)

**Figure 4-38: FF1148 Banked Pins (XC2VP40)**
FF1148 Dedicated/Other Pins (XC2VP40, XC2VP50)

Figure 4-39: FF1148 Dedicated/Other Pins (XC2VP40, XC2VP50)
This page intentionally left blank.
Figure 4-40: FF1517 Composite Pinout Diagram (XC2VP70)
FF1517 Banked Pins (XC2VP70)

Figure 4-41: FF1517 Banked Pins (XC2VP70)
Figure 4-42: FF1517 Composite Pinout Diagram (XC2VP50)
Chapter 4: PCB Design Considerations

FF1517 Banked Pins (XC2VP50)

**Figure 4-43: FF1517 Banked Pins (XC2VP50)**

* Callouts for max number of I/Os per bank include dual-purpose pins shown in table, right.

<table>
<thead>
<tr>
<th>User I/O Pins</th>
<th>Dedicated Pins</th>
<th>Other Pins</th>
</tr>
</thead>
<tbody>
<tr>
<td>○ IOLXXY_#</td>
<td></td>
<td>VCCO</td>
</tr>
<tr>
<td>Dual-Purpose PIns:</td>
<td></td>
<td>NO CONNECT</td>
</tr>
<tr>
<td>○ DIN/DO-D7</td>
<td></td>
<td></td>
</tr>
<tr>
<td>● CS_B</td>
<td></td>
<td></td>
</tr>
<tr>
<td>● RDWR_B</td>
<td></td>
<td></td>
</tr>
<tr>
<td>● BUSY/DOUT</td>
<td></td>
<td></td>
</tr>
<tr>
<td>● INIT_B</td>
<td></td>
<td></td>
</tr>
<tr>
<td>● GCLKx (P)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>● GCLKx (S)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>○ VRP</td>
<td></td>
<td></td>
</tr>
<tr>
<td>○ VRN</td>
<td></td>
<td></td>
</tr>
<tr>
<td>● VREF</td>
<td></td>
<td></td>
</tr>
<tr>
<td>● No Pair</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Bank 1 - 81 Max User I/Os*
Bank 0 - 81 Max User I/Os*
Bank 2 - 132 Max User I/Os*
Bank 3 - 132 Max User I/Os*
Bank 4 - 81 Max User I/Os*
Bank 5 - 81 Max User I/Os*
Bank 6 - 132 Max User I/Os*
Bank 7 - 132 Max User I/Os*
Figure 4-44: FF1517 Dedicated/Other Pins (XC2VP50, XC2VP70)
Chapter 4: PCB Design Considerations

FF1517 Composite Pinout Diagram (XC2VP40)

Figure 4-45: FF1517 Composite Pinout Diagram (XC2VP40)
FF1517 Banked Pins (XC2VP40)

**FF1517 (XC2VP40) - Top View**

Bank 1 - 69 Max User I/Os*

Bank 0 - 69 Max User I/Os*

Bank 2
132 Max User I/Os*

Bank 3
132 Max User I/Os*

Bank 4 - 69 Max User I/Os*

Bank 5 - 69 Max User I/Os*

Bank 6
132 Max User I/Os*

Bank 7
132 Max User I/Os*

* Callouts for max number of I/Os per bank include dual-purpose pins shown in table, right.

**User I/O Pins**
- IO_LXXY_#
- Dual-Purpose Pins:
  - DIN/DO-D7
  - CS_B
  - RDWR_B
  - BUSY/DOUT
  - INIT_B
  - GCLKx (P)
  - GCLKx (S)
  - VCCO
  - VRP
  - VRN
  - VREF
  - No Pair

**Dedicated Pins**

**Other Pins**
- VCCO
- NO CONNECT

Figure 4-46: FF1517 Banked Pins (XC2VP40)
Figure 4-47: FF1517 Dedicated/Other Pins (XC2VP40)
Figure 4-48: FF1704 Composite Pinout Diagram (XC2VP100, XC2VP125)
Figure 4-49: FF1704 Banked Pins (XC2VP100, XC2VP125)
Figure 4-50: FF1704 Composite Pinout Diagram (XC2VP70)
FF1704 Banked Pins (XC2VP70)

Figure 4-51: FF1704 Banked Pins (XC2VP70)
Figure 4-52: FF1704 Dedicated/Other Pins (XC2VP70, XC2VP100, XC2VP125)
FF1696 Composite Pinout Diagram (XC2VP125)

**User I/O Pins**
- IO_LXXY_#
- Dual-Purpose Pins: DIN/D0-D7, CS_B, RDWR_B, BUSY/DOUT, INIT_B, GCLKx (P), GCLKx (S), VRRP, VRN, VREF, No Pair

**Dedicated Pins**
- CCLK, PROG_B, DONE, HSWARE_EN, TCK, M2, M1, M0, TDI, TDO, TMS, PWDRDN_B

**Other Pins**
- DXN, DXP, VBATT, RSVD, VCCO, VCCAUX, VCCINT, GND, NO CONNECT, AVCCAUDTX, AVCCAUDRX, VTRX, VTX, RXTX, RXRX, TXTX, TXRX

* Callouts for max number of I/Os per bank include dual-purpose pins shown in table, right.

Figure 4-53: FF1696 Composite Pinout Diagram (XC2VP125)
FF1696 Banked Pins (XC2VP125)

Figure 4-54: FF1696 Banked Pins (XC2VP125)
**FF1696 Composite Pinout Diagram (XC2VP100)**

**Figure 4-55:** FF1696 Composite Pinout Diagram (XC2VP100)

- **User I/O Pins:**
  - IO_LXXY_#
  - DIN/D0-D7
  - CS_B
  - RDWR_B
  - BUSY/DOUT
  - INIT_B
  - GCLKx (P)
  - GCLKx (S)
  - VRP
  - VRN
  - VREF
  - No Pair

- **Dedicated Pins:**
  - CCLK
  - PROG_B
  - DONE
  - M2, M1, M0
  - HSWAP_EN
  - TCK
  - TDI
  - TDO
  - TMS
  - PWDRDW_B

- **Other Pins:**
  - DXN
  - DXP
  - VBATT
  - RSVD
  - SVD
  - GND
  - NO CONNECT
  - AVCCAUXRX
  - VTXPADD
  - AVCCAUXTX
  - VTTXPADD
  - GND
  - RXNPA
  - RXPPAD
  - TXPADD
  - TXNPC
Figure 4-56: FF1696 Banked Pins (XC2VP100)
Figure 4-57: FF1696 Dedicated/Other Pins (XC2VP100, XC2VP125)
Package Specifications

This section contains specifications for the following Virtex-II Pro packages:

- FG256 Fine-Pitch BGA Package (1.00 mm Pitch), page 488
- FG456 Fine-Pitch BGA Package (1.00 mm Pitch), page 489
- FF672 Flip-Chip Fine-Pitch BGA Package (1.00 mm Pitch), page 490
- FF896 Flip-Chip Fine-Pitch BGA Package (1.00 mm Pitch), page 491
- FF1152 Flip-Chip Fine-Pitch BGA Package (1.00 mm Pitch), page 492
- FF1148 Flip-Chip Fine-Pitch BGA Package (1.00 mm Pitch), page 493
- FF1517 Flip-Chip Fine-Pitch BGA Package (1.00 mm Pitch), page 494
- FF1704 Flip-Chip Fine-Pitch BGA Package (1.00 mm Pitch), page 495
- FF1696 Flip-Chip Fine-Pitch BGA Package (1.00 mm Pitch), page 496
FG256 Fine-Pitch BGA Package (1.00 mm Pitch)

Figure 4-58: FG256 Fine-Pitch BGA Package

NOTES:
2. SYMBOL ‘M’ IS THE BALL MATRIX SIZE
3. NOMINAL DIMENSION IS TYPICALLY 1.60–1.73 mm
4. CONFORMS TO JEDEC MS-034-AAF-1

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>MILLIMETERS</th>
<th>NOTE</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td>0.40 – 0.50</td>
<td>3</td>
</tr>
<tr>
<td>A1</td>
<td>0.50 – 0.60</td>
<td></td>
</tr>
<tr>
<td>D/E</td>
<td>17.00 BSC</td>
<td></td>
</tr>
<tr>
<td>D/E:</td>
<td>15.00 REF</td>
<td></td>
</tr>
<tr>
<td>e</td>
<td>1.00 BSC</td>
<td></td>
</tr>
<tr>
<td>φb</td>
<td>0.50 – 0.60</td>
<td></td>
</tr>
<tr>
<td>φa</td>
<td>0.20</td>
<td></td>
</tr>
<tr>
<td>ccc</td>
<td>0.35</td>
<td></td>
</tr>
<tr>
<td>ddd</td>
<td>0.30</td>
<td></td>
</tr>
<tr>
<td>eee</td>
<td>0.10</td>
<td></td>
</tr>
<tr>
<td>M</td>
<td>16</td>
<td></td>
</tr>
</tbody>
</table>

Figure 4-58: FG256 Fine-Pitch BGA Package
Figure 4-59: FG456 Fine-Pitch BGA Package
FF672 Flip-Chip Fine-Pitch BGA Package (1.00 mm Pitch)

Figure 4-60: FF672 Flip-Chip Fine-Pitch BGA Package

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>MILLIMETERS</th>
<th>NOTE</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td>2.45</td>
<td></td>
</tr>
<tr>
<td>A1</td>
<td>0.40</td>
<td>0.50</td>
</tr>
<tr>
<td>A2</td>
<td></td>
<td>2.15</td>
</tr>
<tr>
<td>D/E</td>
<td>27.00 BASIC</td>
<td></td>
</tr>
<tr>
<td>D/E1</td>
<td>25.00 REF</td>
<td></td>
</tr>
<tr>
<td>e</td>
<td>1.00 BASIC</td>
<td></td>
</tr>
<tr>
<td>φb</td>
<td>0.50</td>
<td>0.60</td>
</tr>
<tr>
<td>φb1</td>
<td></td>
<td>0.70</td>
</tr>
<tr>
<td>φb2</td>
<td></td>
<td>0.20</td>
</tr>
<tr>
<td>φb3</td>
<td></td>
<td>0.35</td>
</tr>
<tr>
<td>φb4</td>
<td></td>
<td>0.30</td>
</tr>
<tr>
<td>φb5</td>
<td></td>
<td>0.10</td>
</tr>
<tr>
<td>M</td>
<td>26</td>
<td></td>
</tr>
</tbody>
</table>

NOTES:
1. ALL DIMENSIONS AND TOLERANCES CONFORM TO ANSI Y14.5M-1994
2. SYMBOL 'M' IS THE BALL MATRIX SIZE.
3. CONFORMS TO JEDEC MS-034-AAL-1 (DEPOPULATED)
FF896 Flip-Chip Fine-Pitch BGA Package (1.00 mm Pitch)

Figure 4-61: FF896 Flip-Chip Fine-Pitch BGA Package

NOTES:
1. ALL DIMENSIONS AND TOLERANCES CONFORM TO ANSI Y14.5M-1994
2. SYMBOL 'M' IS THE BALL MATRIX SIZE.
3. CONFORMS TO JEDEC MS-034-AAN-1 (DEPOPULATED)
FF1152 Flip-Chip Fine-Pitch BGA Package (1.00 mm Pitch)

Figure 4-62: FF1152 Flip-Chip Fine-Pitch BGA Package

NOTES:
1. ALL DIMENSIONS AND TOLERANCES CONFORM TO ANSI Y14.5M-1994
2. SYMBOL ‘M’ IS THE BALL MATRIX SIZE.
3. CONFORMS TO JEDEC MS–034–AAR–1 (DEPOPULATED)
**FF1148 Flip-Chip Fine-Pitch BGA Package (1.00 mm Pitch)**

### Package Specifications

**Figure 4-63:** FF1148 Flip-Chip Fine-Pitch BGA Package

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>MILLIMETERS</th>
<th>NOTE</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td>MIN. 3.20</td>
<td>3.40</td>
</tr>
<tr>
<td></td>
<td>NOM. 0.40</td>
<td>0.50</td>
</tr>
<tr>
<td></td>
<td>MAX. 0.60</td>
<td></td>
</tr>
<tr>
<td>A₁</td>
<td></td>
<td></td>
</tr>
<tr>
<td>A₂</td>
<td></td>
<td></td>
</tr>
<tr>
<td>D/E</td>
<td>35.00 BASIC</td>
<td></td>
</tr>
<tr>
<td>D/E₁</td>
<td>33.00 REF</td>
<td></td>
</tr>
<tr>
<td>e</td>
<td>1.00 BASIC</td>
<td></td>
</tr>
<tr>
<td>øb</td>
<td>MIN. 0.50</td>
<td>0.60</td>
</tr>
<tr>
<td></td>
<td>NOM. 0.60</td>
<td>0.70</td>
</tr>
<tr>
<td>a₀₀</td>
<td>0.10</td>
<td></td>
</tr>
<tr>
<td>cccc</td>
<td></td>
<td>0.35</td>
</tr>
<tr>
<td>ddd</td>
<td></td>
<td>0.30</td>
</tr>
<tr>
<td>eee</td>
<td></td>
<td>0.10</td>
</tr>
<tr>
<td>M</td>
<td>34</td>
<td>2</td>
</tr>
</tbody>
</table>

**NOTES:**
1. ALL DIMENSIONS AND TOLERANCES CONFORM TO ANSI Y14.5M–1994
2. SYMBOL 'M' IS THE BALL MATRIX SIZE.
3. CONFORMS TO JEDEC MS–034–AAR–1 (DEPOPULATED)
FF1517 Flip-Chip Fine-Pitch BGA Package (1.00 mm Pitch)

Figure 4-64: FF1517 Flip-Chip Fine-Pitch BGA Package
FF1704 Flip-Chip Fine-Pitch BGA Package (1.00 mm Pitch)

Figure 4-65: FF1704 Flip-Chip Fine-Pitch BGA Package

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>MILLIMETERS</th>
<th>NOTE</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td>3.20 3.45</td>
<td></td>
</tr>
<tr>
<td>A1</td>
<td>0.40 0.50 0.60</td>
<td></td>
</tr>
<tr>
<td>A2</td>
<td>2.85</td>
<td></td>
</tr>
<tr>
<td>D/E</td>
<td>42.50 BASIC</td>
<td></td>
</tr>
<tr>
<td>Dy/E1</td>
<td>41.00 REF</td>
<td></td>
</tr>
<tr>
<td>e</td>
<td>1.00 BASIC</td>
<td></td>
</tr>
<tr>
<td>phi</td>
<td>0.50 0.60 0.70</td>
<td></td>
</tr>
<tr>
<td>aco</td>
<td>0.20</td>
<td></td>
</tr>
<tr>
<td>blop</td>
<td>0.25</td>
<td></td>
</tr>
<tr>
<td>add</td>
<td>0.25</td>
<td></td>
</tr>
<tr>
<td>eee</td>
<td>0.10</td>
<td></td>
</tr>
<tr>
<td>M</td>
<td>42 2</td>
<td></td>
</tr>
</tbody>
</table>

NOTES:

1. ALL DIMENSIONS AND TOLERANCES CONFORM TO ASME Y14.5M–1994
2. SYMBOL "M" IS THE PIN MATRIX SIZE.
3. CONFORMS TO JEDEC MS-034-AAV-1 (DEPOPULATED)
FF1696 Flip-Chip Fine-Pitch BGA Package (1.00 mm Pitch)

**Figure 4-66:** FF1696 Flip-Chip Fine-Pitch BGA Package

**Table:**

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>MILLIMETERS</th>
<th>NOTE</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td>3.20</td>
<td></td>
</tr>
<tr>
<td>A₁</td>
<td>0.40</td>
<td></td>
</tr>
<tr>
<td>A₂</td>
<td>2.85</td>
<td></td>
</tr>
<tr>
<td>D₁/E₁</td>
<td>42.50 BASIC</td>
<td></td>
</tr>
<tr>
<td>D₁/E₂</td>
<td>41.00 REF</td>
<td></td>
</tr>
<tr>
<td>e</td>
<td>1.00 BASIC</td>
<td></td>
</tr>
<tr>
<td>φ₀</td>
<td>0.50</td>
<td></td>
</tr>
<tr>
<td>θ₁</td>
<td>0.20</td>
<td></td>
</tr>
<tr>
<td>θ₂</td>
<td>0.25</td>
<td></td>
</tr>
<tr>
<td>M</td>
<td>42</td>
<td>2</td>
</tr>
</tbody>
</table>

**NOTES:**

1. ALL DIMENSIONS AND TOLERANCES CONFORM TO ASME Y14.5M-1994
2. SYMBOL "M" IS THE PIN MATRIX SIZE.
3. CONFORMS TO JEDEC MS-034-A0V-1 (DEPOPULATED)
Flip-Chip Packages

As silicon devices become more integrated with smaller feature sizes as well as increased functionality and performance, packaging technology is also evolving to take advantage of these silicon advancements. Flip-chip packaging is the latest packaging option introduced by Xilinx to meet the demand for high I/O count and high performance required by today’s advanced applications.

Flip-chip packaging interconnect technology replaces peripheral bond pads of traditional wire-bond interconnect technology with area array interconnect at the die/substrate interface.

The area array pads contain wettable metallization for solders (either eutectic or high-lead), where a controlled amount of solder is deposited either by plating or screen-printing. These parts are then reflowed to yield bumped dies with relatively uniform solder bumps spread over the surface of the device. Unlike traditional packaging in which the die is attached to the substrate face up and the connection is made by using wire, the bumped die in a flip-chip package is flipped over and placed face down, with the conductive bumps connecting directly to the matching metal pads on the ceramic or organic laminate substrate. The solder material at molten stage is self-aligning and produces good joints even if the chip is placed offset on the substrate.

Flip-chip packages are assembled on high-density, multi-layer ceramic or organic laminate substrates. Since flip-chip bump pads are in area array configuration, very fine lines and geometry on the substrates are required to be able to successfully route the signals from the die to the periphery of the substrates. Multi-layer build-up structures offer this layout flexibility on flip-chip packages, and they provide improvements in power distribution and signal transmission characteristics.

Advantages of Flip-Chip Technology

Flip-chip interconnections in combination with the advanced multi-layer laminated substrates provide superior performance over traditional wire-bond packaging. Benefits include:

- Easy access to core power/ground and shorter interconnects, resulting in better electrical performance
- Better noise control since the inductance of flip-chip interconnect is lower
- Excellent thermal performance due to direct heatsinking to backside of the die
- Higher I/O density since bond pads are in area array format
- Smaller size
Chapter 4: PCB Design Considerations

Thermal Data

Thermal Considerations

The Virtex-II Pro device is a feature-rich FPGA product based on the high-performance Virtex-II architecture. The product incorporates numerous features such as multiple RocketIO™ Multi-Gigabit Transceivers (MGTs), one or more embedded IBM PowerPC processors, high-speed SelectI/O™ technology supporting a variety of I/O standards, on-board digitally controlled impedance (DCI) technology, and much more. In fully configured designs that engage all these features at high clock rates, power consumption can add up quickly.

Unlike the features of ASICs or even of microprocessors, the combination of Virtex-II Pro features that will be utilized in an application are not known ahead of time. Therefore, as in previous FPGA devices, it remains challenging to predict the power requirements and resulting thermal management needs of a Virtex-II Pro device in a given package. These devices, therefore, do not come with a preset thermal solution. The end user’s conditions will determine what solutions will be most appropriate. In consideration of the high heat-generating potential of the Virtex-II Pro devices, package offerings are tailored to include medium and high power capable options that allow external thermal management to meet the application’s requirements.

Table 4-4 shows thermal resistance parameters for Virtex-II Pro packages. Estimated power consumption capability is given, as well. These values were derived using some typical thermal management assumptions as stated in the table. Table 4-4 provides only an example, and is not intended as a maximum power dissipation specification.

Table 4-4: Thermal Data for Virtex-II Pro Packages

<table>
<thead>
<tr>
<th>Package</th>
<th>Lead Pitch (mm)</th>
<th>Junction-to-Ambient Theta-JA Range, in Air (°C/Watt)</th>
<th>Junction-to-Case Theta-JC Range, Cold Plate (°C/Watt)</th>
<th>Junction-to-Board Psi-JB (&quot;Theta-JB&quot;) Typical (°C/Watt)</th>
<th>Max Power, Bare Pkg (Watts)</th>
<th>TA = 50 °C, TJMAX = 100 °C</th>
<th>Power With Heatsink (Watts)</th>
<th>Theta-SA = 1.5 °C/Watt Theta-CS = 0.1 °C/Watt TA = 50 °C, TJ = 100 °C</th>
</tr>
</thead>
<tbody>
<tr>
<td>FG256, 24L PCB, 17x17</td>
<td>1.0</td>
<td>24 - 28</td>
<td>3.0 - 5.0</td>
<td>14.0</td>
<td>1.7</td>
<td>N/A (1)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FG456, 4L PCB, 23x23</td>
<td>1.0</td>
<td>18 - 22</td>
<td>2.0 - 2.5</td>
<td>10.0</td>
<td>2.5</td>
<td>N/A (1)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FF672, 27x27 Flip-Chip</td>
<td>1.0</td>
<td>14 - 16</td>
<td>1.5</td>
<td>6.5</td>
<td>3.3</td>
<td>16</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FF896, 31x31 Flip-Chip</td>
<td>1.0</td>
<td>10 - 12</td>
<td>1.1</td>
<td>3.7</td>
<td>4.5</td>
<td>21</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FF1152, 35x35 Flip-Chip</td>
<td>1.0</td>
<td>10 - 12</td>
<td>1.1</td>
<td>3.7</td>
<td>4.5</td>
<td>21</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FF1148, 35x35 Flip-Chip</td>
<td>1.0</td>
<td>10 - 12</td>
<td>1.1</td>
<td>3.7</td>
<td>4.5</td>
<td>21</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FF1517, 40x40 Flip-Chip</td>
<td>1.0</td>
<td>10 - 12</td>
<td>1.1</td>
<td>3.7</td>
<td>4.5</td>
<td>21</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FF1704, 42.5x42.5 Flip-Chip</td>
<td>1.0</td>
<td>10 - 12</td>
<td>1.1</td>
<td>3.7</td>
<td>4.5</td>
<td>21</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FF1696, 42.5x42.5 Flip-Chip</td>
<td>1.0</td>
<td>10 - 12</td>
<td>1.1</td>
<td>3.7</td>
<td>4.5</td>
<td>21</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

θJA (Theta-JA): Thermal resistance, junction-to-ambient (Xilinx-supplied)
θJC (Theta-JC): Thermal resistance, junction-to-case (use with ratio of heat through the top)
ΨJB (Psi-JB, or "Theta-JB"): Thermal resistance in still air, junction-to-board
θSA (Theta-SA): Thermal resistance, heatsink (manufacturer-supplied)
θCS (Theta-CS): Thermal resistance, heatsink adhesive (manufacturer-supplied)

Notes:
1. The heat sink used in this example is not mechanically compatible with the FG256 and FG456 packages.

Virtex-II Pro packages can be grouped into three broad performance categories: low, medium, and high, based on their power handling capabilities. All of the packages can use external thermal enhancements, which can range from simple airflow to schemes that can include passive as well as active heatsinks. This is particularly true for high-performance
flip-chip packages where system designers have the option to further enhance the packages to handle in excess of 20 watts, with arrangements that take system physical constraints into consideration. Table 4-5 shows simple but incremental power management schemes that can be brought to bear on flip-chip packages.

**Thermal Management Options**

The following are thermal management options to consider:

- For moderate power dissipation (2 to 6 watts), the use of passive heatsinks and heatspreaders attached with thermally conductive double-sided tapes or retainers can offer quick thermal solutions.

- The use of lightweight finned external passive heatsinks can be effective for dissipating up to 10 watts. The more efficient external heatsinks tend to be tall and heavy. To help protect component joints from bulky heatsink-induced stresses, the use of spring loaded pins or clips that transfer the mounting stress to a circuit board is advisable. The diagonals of some of these heatsinks can be designed with extensions to allow direct connections to the board.

- Flip-chip packages: All flip-chip packages are thermally enhanced BGAs with die facing down. They are offered with exposed metal heatsink at the top. These high-end thermal packages lend themselves to the application of external heatsinks (passive or active) for further heat removal efficiency. Again, precaution should be taken to prevent component damage when a bulky heatsink is attached.

- Active heatsinks can include a simple heatsink incorporating a mini fan or even a Peltier Thermoelectric Cooler (TECs) with a fan to blow away any heat generated. Any considerations to apply TEC in heat management should require consultation with experts in using the device, since these devices can be reversed and cause damage to the components. Also, condensation can be an issue.

- Outside the package itself, the board on which the package sits can have a significant impact on thermal performance. Board designs can be implemented to take advantage of a board's ability to spread heat. The effect of the board is dependent on its size and how it conducts heat. Board size, the level of copper traces on it, and the number of buried copper planes all lower the junction-to-ambient thermal resistance for packages mounted on the board.

The junction-to-board thermal resistance for Virtex-II Pro packages are given in Table 4-4. A standard JEDEC type board was used for obtaining the data. Users need to be aware that a direct heat path to the board from a component also exposes the component to the effect of other heat sources - particularly if the board is not cooled effectively. An otherwise cooler component might be heated by other heat contributing components on the board.

<table>
<thead>
<tr>
<th>Power</th>
<th>Technique</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Low End</td>
<td>Bare package with moderate air</td>
<td>Bare package. Package can be used with moderate airflow within a system.</td>
</tr>
<tr>
<td>(1 - 6 watts)</td>
<td>8 - 12 °C/Watt</td>
<td></td>
</tr>
<tr>
<td>Mid Range</td>
<td>Passive heatsink with air</td>
<td>Package is used with various forms of passive heatsinks and heat spreader techniques.</td>
</tr>
<tr>
<td>(4 - 10 watts)</td>
<td>5 - 10 °C/Watt</td>
<td></td>
</tr>
<tr>
<td>High End</td>
<td>Active heatsink</td>
<td>Package is used with active heatsinks, TEC, and board-level heat spreader techniques</td>
</tr>
<tr>
<td>(8 - 25 watts)</td>
<td>2 - 3 °C/Watt or better</td>
<td></td>
</tr>
</tbody>
</table>
Printed Circuit Board Considerations

Layout Considerations

The PC board is no longer just a means to hold ICs in place. At today’s high clock rates and fast signal transitions, the PC board performs a vital function in feeding stable supply voltages to the IC and in maintaining signal integrity between devices.

VCC and Ground Planes

Since CMOS power consumption is dynamic, it is a non-trivial task to assure stable supply voltages at the device pins and to minimize ground differentials. A multi-layer PC board is a must, with four layers for the simplest circuits, 6 to 12 layers for typical boards. Ground and VCC must each be distributed in complete layers with few holes. Slots in these layers would cause an unacceptable inductive voltage drop, when the supply current changes at a rate of 1 A/ns, or even faster. Besides an uninterrupted ground plane, Virtex-II Pro devices require one plane for VCCINT (1.5V) plus one plane for VCCAUX (2.5V). VCCO can be distributed on wide sections of split plane layers. Note that signal traces on adjacent layers should not be routed across these plane splits.

Beyond low resistance and inductance, ground and VCC planes combined can also provide a small degree of VCC decoupling. The capacitance between two planes is ~180 pF/inch² or ~28 pF/cm², assuming 5mil (0.125 mm) spacing with FR4 epoxy.

VCC Decoupling

Fast changing ICC transitions must be supplied by local decoupling capacitors, placed very closely to the VCC device pins or balls. These capacitors must have sufficient capacitance to supply ICC for a few nanoseconds, and must have low intrinsic resistance and inductance. X7R or NPO ceramic surface-mounted capacitors of 0.01 to 0.1 µF, one per VCC device pin, are appropriate. 0.1 µF can supply 1A for 2 ns with a 20 mV voltage droop.

\[
1A \times 2 \text{ ns} = 2 \text{ nanocoulomb} = 100 \text{ nF} \times 0.02V
\]

Low impedance at >100 MHz is important. Some capacitance variation with temperature is acceptable. A series of values of decoupling capacitors are needed in order to supply transient current to the device over all frequency ranges. The highest frequency capacitors should be in the range of 300 pF to 1 nF. The smallest capacitors are the first-line source for ICC, and they must be placed very close to the VCC pins. An inch of copper plane represents an inductance of several nanohenries, defeating the purpose of the decoupling capacitor. Therefore, the highest frequency (smallest value) capacitors should be mounted within 0.4 inches (1 cm) of the VCC and ground pin pair that it is decoupling. On large full-array BGA packages like the FF1152 and FF1517, following the decoupling guidelines presents implementation challenges. Note that the power and ground balls on these packages are grouped in banks. A subset of the initial line of high-frequency decoupling capacitors should be mounted directly opposite the component on the reverse side of the board and within the apparent boundary of the component. At least one and typically two 0.1 µF chipcaps per bank should be used. The balance of the high-frequency bypass requirements can be implemented outside the periphery on these full-array packages. Backing up this local decoupling is one tantalum capacitor of 10 µF to 100 µF, able to supply multiple amperes for about 100 ns.

Finally, each board needs a power-supply decoupling electrolytic capacitor of 1000 µF to 10,000 µF, able to supply even more current for a portion of the supply switching period. As described below, larger capacitors inevitably have higher series resistance and inductance, which is the reason for the above-mentioned hierarchy of supply decoupling. As a general rule, multiple capacitors in parallel always offer lower resistance and inductance than any single capacitor.

Bypass capacitors must have vias (at least two per pad) abutting the pads, or vias in the pads, to provide the lowest inductance connection.
Decoupling Capacitors

The ideal decoupling capacitor would present a short circuit to ground for all AC signals. A real capacitor combines a given amount of capacitance with unavoidable parasitics, a small series resistance, and inductance. At low frequencies, the composite impedance is capacitive: that is, it decreases with increasing frequency. At high frequencies, it is inductive and increases with frequency, making the decoupling ineffective. In between, there is the LC resonant frequency, where the capacitor looks like a small resistor. This is the range where it is most effective.

Different technologies provide different trade-offs between desirable features like small size and high capacitance, and undesirable features like series resistance and inductance. Electrolytic and tantalum capacitors offer the largest capacitance in a given physical size, but also have the highest inductance. This makes them useful for decoupling low frequencies and storing large amounts of charge, but useless for high frequency decoupling. Surface-mount ceramic capacitors, on the other hand, offer the lowest inductance and the best high-frequency performance, but offer only a small amount of capacitance, usually less than a microfarad.

Figure 4-67 shows the frequency-dependent impedance and resistance of a typical electrolytic capacitor of 1500 µF, while Figure 4-68 and Figure 4-69 show the equivalent data for ceramic bypass capacitors of 33,000 pF and 3,300 pF, respectively. Note that the resonant frequency for the small ceramic bypass capacitor at 100 MHz is 10,000 times higher than the resonance frequency of the large electrolytic capacitor at 10 KHz. For more technical information on decoupling capacitors, see the manufacturers’ websites.
Transmission Line Reflections and Terminations

A PC board trace must be analyzed as a transmission line. Its series resistance and parallel conductance can generally be ignored, but series inductance and parallel capacitance per unit length are important parameters. Any signal transition (rising or falling edge) travels along the trace at a speed determined by the incremental inductance and capacitance.

For an outer-layer trace (air on one side), the propagation delay is 140 ps/inch, or 55 ps/cm. For an inner-layer trace (FR4 with $\varepsilon=4.5$ on both sides), the propagation delay is 180 ps/inch, or 70 ps/cm.

The voltage-to-current ratio at any point along the transmission line is called the characteristic impedance $Z_0$. A field solver, which is available in most signal integrity simulation software, may be used to determine the impedance of a given trace geometry.
As a first order approximation, it is determined by w/d, the ratio of trace width w to the distance d above the ground or VCC plane.

For an outer layer trace (microstrip),
- \( Z_0 = 50\Omega \) when \( w = 2d \) (e.g., \( w = 12 \text{ mil}, d = 6 \text{ mil} \)),
- \( Z_0 = 75\Omega \) when \( w = d \) (e.g., both 6 mil = 0.15 mm).

For an inner layer trace between two ground or VCC planes (stripline),
- \( Z_0 = 50\Omega \) when \( w = 0.6\times d \) (e.g., \( w = 5 \text{ mil}, d = 8 \text{ mil} \)),
- \( Z_0 = 75\Omega \) when \( w = 0.25\times d \) (impractical).

Most signal traces fall into the range of 40 to 80 \( \Omega \).

A slow transition treats a short narrow trace as a lumped capacitance of about 2 pF/inch (0.8 pF/cm). However, if the trace is so long or the signal transition so fast that the potential echo from the far end arrives after the end of the transition, then the trace must be analyzed as a transmission line.

In this case, the driver sees the trace not as a lumped capacitance, but rather as a pure resistance of \( Z_0 \). The signal transition then travels along the trace at the speed mentioned above. At any trace-impedance discontinuity all or part of the signal is reflected back to the origin. If the far end is resistively terminated with \( R = Z_0 \), then there is no reflection. If, however, the end is open, or loaded with only a CMOS input, then the transition doubles in amplitude, and this new wave travels back to the driver, where it may be reflected again, resulting in ringing. Such ringing has a serious impact on signal integrity, reduces noise margins, and can lead to malfunction, especially if an asynchronous signal or a clock signal crosses the input threshold voltage unpredictably. Two alternate ways to avoid reflections and ensure signal integrity are parallel termination and series termination.

**Parallel Termination**

Reflections from the far end of the transmission line are avoided if the far end is loaded with a resistor equal to \( Z_0 \). A popular variation uses two resistors, one to VCC, one to ground, as the Thevenin equivalent of \( Z_0 \). This reduces the load current for one signal level, while increasing it for the other. Parallel termination inherently has some dc power consumption. DCI on-chip termination may be used to realize parallel termination schemes.

See Figure 4-70.
Chapter 4: PCB Design Considerations

Series Termination

While parallel termination eliminates reflections, series termination relies on the reflection from the far end to achieve a full-amplitude signal. For series termination, the driver impedance is adjusted to equal $Z_0$, thus driving a half-amplitude signal onto the transmission line. At the unterminated far end, the reflection creates a full-amplitude signal, which then travels back to the driver where it is absorbed, since the output impedance equals $Z_0$. See Figure 4-71.

Series termination dissipates no dc power, but the half-amplitude round-trip delay signal means that there must be no additional loads along the line. Series termination is ideal (and only meaningful) for single-source-single-destination interconnects. DCI on-chip termination may be used to realize series termination schemes through the use of controlled impedance drivers.

DCI On-Chip Termination

Virtex-II Pro devices offer digitally controlled output impedance drivers and digitally-controlled input termination, thus eliminating the need for any external termination resistors. This feature is extremely valuable with high pin-count, high density packages. These PC board considerations apply to all modern systems with fast current and voltage transitions, irrespective of the actual clock frequency. The designer of relatively slow systems is more likely caught off-guard by the inherent speed of modern CMOS ICs, where $\text{di/dt}$ is measured in $\text{A/ns}$, $\text{dV/dt}$ is measured in $\text{V/ns}$, and input flip-flops can react to 1 ns pulses, that are invisible on mid-range oscilloscopes. Powerful tools like HyperLynx and other signal integrity analysis tools can be used to analyze signal integrity on the PC board and can often be amortized by one eliminated board respin.

JTAG Configuration and Test Signals

Poor signal integrity and limitations of devices in a JTAG scan chain can reduce the maximum JTAG test clock (TCK) rate and reliability of JTAG-based configuration and test procedures. The JTAG TCK and test mode (TMS) signals must be buffered, distributed, and routed with the same care as any clock signal especially for long JTAG scan chains. The devices in a JTAG scan chain should be ordered such that the connections from the TDO of one device to the TDI of the next device are minimized. When high-speed JTAG-based configuration for the Virtex-II Pro devices is required, devices with lower-specified maximum TCK rates should be placed in a separate JTAG scan chain.

Crosstalk

Crosstalk can happen when two signals are routed closely together. Current through one of the traces creates a magnetic field that induces current on the neighboring trace, or the voltage on the trace couples capacitively to its neighbor. Crosstalk can be accurately modeled with signal integrity software. Two easy-to-remember rules of thumb are:

- Crosstalk falls off with the square of increasing distance between the traces.
- Crosstalk also falls off with the square of decreasing distance to a ground plane.

![Figure 4-71: Series Termination](ug002_c4_44_111400)
Printed Circuit Board Considerations

where

\[ \text{Peak Crosstalk Voltage} = \frac{\Delta V}{1 + \left(\frac{D}{H}\right)^2} \]

\( \Delta V \) is the voltage swing

\( D \) is the distance between traces (center to center)

\( H \) is the spacing above the ground plane

**Example:**

3.3V swing, and two stripline traces 5 mils apart and 5 mils above the ground plane.

\[ \text{Peak Crosstalk Voltage} = \frac{3.3V}{1 + \left(\frac{0.005}{0.005}\right)^2} = 1.65V \]

This can cause a false transition on the neighboring trace. Separating the trace by an additional 5 mils is significantly better:

\[ \text{Peak Crosstalk Voltage} = \frac{3.3V}{1 + \left(\frac{0.01}{0.005}\right)^2} = 0.66V \]

**Decoupling of VREF Pins**

VREF pins must each have a bypass capacitor to ensure no noise is coupled onto the reference. Signal traces must be kept at least three spaces from the reference trace on either side to prevent crosstalk coupling.

**Signal Routing to and from Package Pins**

Signal escaping (traces leaving the pin/ball area) can be quite difficult for the large FG and flip-chip packages. The number of signal layers required to escape all the pins depends on the PCB design rules. The thinner the traces, the more signals per layer can be routed, and the fewer layers are needed. The thinner traces have higher characteristic impedance, so choose an impedance plan that makes sense, and then be consistent. Traces from 40\( \Omega \) to 80\( \Omega \) are common.

If only one signal can be escaped between two pads, only two rows of pins can be escaped per layer. For FG packages (1.0mm pitch) one signal of width 5 mils (0.13mm) can be escaped between two pads, assuming a space constraint equal to the trace width. For a discussion of signal routing specific to Virtex-II Pro devices, see www.xilinx.com for currently available application notes.

As packages are able to handle more I/Os with a minimum increase in size, the signal integrity of those signals must be considered, regardless of clock frequency. Especially with the largest packages, precise PCB layer stackup is required. Parameters such as board material, trace width, pad type, and stackup must be defined based on simulation, and the fabrication drawings must be marked “Precise Layer Stackup,” and the stackup must be specified. A number of board-level signal integrity simulators exist. Careful attention to PCB design rules creates a robust design with low EMI and high signal reliability.
Board Routability Guidelines

Board-Level BGA Routing Challenges

Xilinx ball grid array (BGA) wire-bond and flip-chip packages contain a matrix of solder balls (see Figure 4-72). These packages are made of multilayer BT substrates. Signal balls are in a perimeter format. Power and ground pins are grouped together appropriately.

The number of layers required for effective routing of these packages is dictated by the layout of balls in each package. If several other technologies and components are already present on the board, the system cost is factored with every added board layer. The intent of a board designer is to optimize the number of layers required to route these packages, considering both cost and performance. This section provides guidelines for minimizing required board layers for routing BGA products using standard PCB technologies (5 mil wide lines and spaces or 6 mil wide lines and spaces).

For high performance and other system needs, designers can use premium technologies with finer lines/spaces on the board. The pin assignment and pin grouping scheme in BGA packages enables efficient routing of the board with an optimum number of required board layers.

Figure 4-72: Fine-Pitch BGA Pin Assignments

![Fine-Pitch BGA Pin Assignments](image_url)
Board Routing Strategy

The diameter of a land pad on the component side is provided by Xilinx. This information is required prior to the start of board layout when designing the board pads to match component-side land geometry. Typical values for these land pads are described in Figure 4-73 and summarized in Table 4-6.

![Diagram of Board Routing Strategy](image)

Non-Solder-Mask-Defined Land Patterns or Land-Defined Land Patterns are recommended for all packages.

Figure 4-73: Suggested Board Layout of Soldered Pads for BGA Packages

Table 4-6: Summary of Typical Land Pad Values (mm)

<table>
<thead>
<tr>
<th>Land Pad Characteristics</th>
<th>FG256</th>
<th>FG456</th>
<th>FF672</th>
<th>FF896</th>
<th>FF1152</th>
<th>FF1148</th>
<th>FF1517</th>
<th>FF1704</th>
<th>FF1696</th>
</tr>
</thead>
<tbody>
<tr>
<td>Component Land Pad Diameter (SMD)(^{(4)})</td>
<td>0.45</td>
<td>0.45</td>
<td>0.48</td>
<td>0.48</td>
<td>0.48</td>
<td>0.48</td>
<td>0.48</td>
<td>0.48</td>
<td>0.48</td>
</tr>
<tr>
<td>Solder Land (L) Diameter</td>
<td>0.40</td>
<td>0.40</td>
<td>0.45</td>
<td>0.45</td>
<td>0.45</td>
<td>0.45</td>
<td>0.45</td>
<td>0.45</td>
<td>0.45</td>
</tr>
<tr>
<td>Opening in Solder Mask (M) Diameter</td>
<td>0.50</td>
<td>0.50</td>
<td>0.55</td>
<td>0.55</td>
<td>0.55</td>
<td>0.55</td>
<td>0.55</td>
<td>0.55</td>
<td>0.55</td>
</tr>
<tr>
<td>Solder (Ball) Land Pitch (e)</td>
<td>1.00</td>
<td>1.00</td>
<td>1.00</td>
<td>1.00</td>
<td>1.00</td>
<td>1.00</td>
<td>1.00</td>
<td>1.00</td>
<td>1.00</td>
</tr>
<tr>
<td>Line Width Between Via and Land (w)</td>
<td>0.130</td>
<td>0.130</td>
<td>0.130</td>
<td>0.130</td>
<td>0.130</td>
<td>0.130</td>
<td>0.130</td>
<td>0.130</td>
<td>0.130</td>
</tr>
<tr>
<td>Distance Between Via and Land (D)</td>
<td>0.70</td>
<td>0.70</td>
<td>0.70</td>
<td>0.70</td>
<td>0.70</td>
<td>0.70</td>
<td>0.70</td>
<td>0.70</td>
<td>0.70</td>
</tr>
<tr>
<td>Via Land (VL) Diameter</td>
<td>0.61</td>
<td>0.61</td>
<td>0.61</td>
<td>0.61</td>
<td>0.61</td>
<td>0.61</td>
<td>0.61</td>
<td>0.61</td>
<td>0.61</td>
</tr>
<tr>
<td>Through Hole (VH), Diameter</td>
<td>0.300</td>
<td>0.300</td>
<td>0.300</td>
<td>0.300</td>
<td>0.300</td>
<td>0.300</td>
<td>0.300</td>
<td>0.300</td>
<td>0.300</td>
</tr>
<tr>
<td>Pad Array</td>
<td>Full</td>
<td>Full</td>
<td>Full</td>
<td>Full</td>
<td>Full</td>
<td>Full</td>
<td>Full</td>
<td>Full</td>
<td>Full</td>
</tr>
<tr>
<td>Matrix or External Row</td>
<td>16 x 16</td>
<td>22 x 22</td>
<td>26 x 26</td>
<td>30 x 30</td>
<td>34 x 34</td>
<td>34 x 34</td>
<td>39 x 39</td>
<td>42 x 42</td>
<td>42 x 42</td>
</tr>
<tr>
<td>Periphery Rows</td>
<td>-</td>
<td>7(^{(3)})</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

Notes:
1. Dimensions in millimeters.
2. 3 x 3 matrix for illustration only, one land pad shown with via connection.
3. FG456 package has solder balls in the center in addition to the periphery rows of balls.
4. Component land pad diameter refers to the pad opening on the component side (solder-mask defined).
For Xilinx BGA packages, NSMD (Non Solder Mask Defined) pads on the board are suggested. This allows a clearance between the land metal (diameter L) and the solder mask opening (diameter M) as shown in Figure 4-73. The space between the NSMD pad and the solder mask, and the actual signal trace widths depends on the capability of the PCB vendor. The cost of the PCB is higher when the line width and spaces are smaller.

Selection of the pad types and pad sizes determines the available space between adjacent balls for signal escape. Based on PCB capability, the number of lines that can share the available space is described in Figure 4-74. Based on geometrical considerations, if one signal escapes between adjacent balls, then two signal rows can be routed on a single metal layer. This is illustrated in Figure 4-74, as routing with one line/channel, either at 6 mil lines and spaces or 5 mil lines and spaces. The blocked nature of multi-gigabit transceiver (MGT) at the top edge prevents a direct implementation of one line/channel arrangement in layer 1. Using this suggested routing scheme, a minimum of eight PCB layers are required to route up to 10 signal rows in a package.

These Virtex-II Pro BGA packages may incorporate up to 16 MGT channels per package. The balls that make up these channels are grouped within the two outer rows of top and bottom edges. This outer row arrangement allows easy escape and pairing of signals. Accommodation of any filtering schemes off the chip can be accomplished in close proximity as well.

A slightly lower trace width than that employed on the top and bottom external or exposed traces can be used by the inner signal rows routed in internal layers. Depending on the signal being handled, the practice of “necking down” a trace in the critical space between the BGA balls is allowable. Changes in width over very short distances can cause small impedance changes. Validate these issues with the board vendor and signal integrity engineers responsible for design. It is also suggested to implement the MGT signals in stripline arrangement.

**Figure 4-74:** FF672 PC Board Layout/Land Pattern

<table>
<thead>
<tr>
<th>PCB DESIGN RULE (1.0 mm BALL PITCH)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Trace Width/Spacing (mils)</td>
</tr>
<tr>
<td>-------------------------------</td>
</tr>
<tr>
<td>5/5</td>
</tr>
</tbody>
</table>

**Legend:**
- I/O
- GND Plane
- PWR
- VCCINT
- VINT
- 27 x 27 mm, 1.0 mm Fine Pitch BGA

Detail "A"
Figure 4-74 describes a board-level layout strategy for a Xilinx 1.0 mm pitch FF672 package, which incorporates four MGT channels at the top edge. Detail A in Figure 4-74 describes the opening geometry for the land pad and the solder mask. Routing with 5 mil lines/trace allows one signal per channel (between the balls). For successful routing, eight-row-deep signal traces require six to eight PCB layers. Figure 4-75 shows the suggested schematic of layers for the eight-layer routing scheme. By using a premium board technology such as Microvia Technology—allowing up to 4 mil lines and spaces—efficient routing with a reduced number of board layers is made possible. A grouping scheme for power, ground, control, and I/O pins may also enable efficient routing.

<table>
<thead>
<tr>
<th>Signal (S1)</th>
<th>L - 1</th>
</tr>
</thead>
<tbody>
<tr>
<td>Power/Gnd</td>
<td>L - 2</td>
</tr>
<tr>
<td>Signal (S2)</td>
<td>L - 3</td>
</tr>
<tr>
<td>Signal (S3 – MGT)</td>
<td>L - 4</td>
</tr>
<tr>
<td>Power/Gnd</td>
<td>L - 5</td>
</tr>
<tr>
<td>Signal (S4)</td>
<td>L - 6</td>
</tr>
<tr>
<td>Power/Gnd</td>
<td>L - 7</td>
</tr>
<tr>
<td>Signal (S5)</td>
<td>L - 8</td>
</tr>
</tbody>
</table>

Figure 4-75: Eight-Layer Routing Scheme

Figure 4-76 and Figure 4-77 show examples of suggested layer-by-layer board escape routing strategy used to implement MGT and LVDS pairs for two of the Virtex-II Pro packages, the wire-bond FG456 and the flip-chip FF672. Complete suggested layer-by-layer board escape routing for each Virtex-II Pro package can be found in the Virtex-II Pro section of the www.xilinx.com website. These drawings assume a standard PCB technology of 5 mil wide lines and spaces. More details are contained in XAPP157, which is available on the web at www.xilinx.com/apps/xappsumm.htm#xapp157, as is a full-color (PDF) version of this document.
Chapter 4: PCB Design Considerations

Figure 4-76: FG456 Routing with LVDS Pairs
Figure 4-77: FF672 Routing with LVDS Pairs
XPower

XPower is the first graphic power-analysis software available for programmable logic design. Earlier than ever in the design flow you can analyze total device power, power per net, routed, or partially routed or unrouted designs. You can also receive graphical or ASCII-based reports, all driven from a comprehensive graphic interface, or use a command-line driven batch-mode execution.

XPower supports Virtex-II Pro and Virtex-II advanced FPGA devices and the XPLA3 family of CPLD devices, offering the broadest device support available in programmable power estimation.

XPower also supports the importing of simulation data from ModelSim™ VCD files, greatly reducing the time spent setting up net activity, and increasing overall estimation accuracy.

XPower uses device knowledge and design data to project device power and by-net power utilization. This is a significant advance from the static estimation pages most logic providers offer their customers, and it is a leap forward in providing logic designers with accurate power dissipation information.

Features include:

- Support for Virtex-II Pro, Virtex-II, Virtex-E, Virtex, and Spartan-II FPGAs in ISE 4.1i
- XPLA3 device support through ISE WebPACK 4.1i
- VCD simulation file import for ModelSim™
- Windows 98 and NT, Windows ME and Windows 2000, and Solaris support
- Graphic and/or ASCII report formats
- Menu-driven or batch-mode execution
- Device data read directly from Xilinx layout files
- Save and recall setup data
- Recognize small voltage variations on VCC

More details are available under the Xpower link on the www.xilinx.com website.

IBIS Models

The need for higher system performance leads to faster output transitions. Signals with fast transitions cannot be considered purely digital. It is therefore important to understand their analog behavior by signal integrity analysis.

To simulate the signal integrity of printed circuit boards (PCB) accurately and solve design problems before the PCB is fabricated, models of the I/O characteristics are required. SPICE models were traditionally used for this purpose, however, a manufacturer's SPICE models contain proprietary circuit-level information. Therefore, there was a need for a model type which does not give details of the circuit topology, or process parameters. One such standard is the I/O Buffer Information Specification (IBIS) format originally suggested by Intel.

In the early 1990's, the IBIS Open Forum was formed and the first IBIS specification was written to promote tool independent I/O models for system signal integrity analysis. IBIS is now the ANSI/EIA-656 and IEC 62014-1 standard. IBIS accurately describes the signal behavior of the interconnections without disclosing the actual technology and circuitry used to implement the I/O. The standard is basically a black-box approach to protect proprietary information.
Using IBIS Models

IBIS models can be used by designers for system-level analysis of signal integrity issues, such as ringing, ground bounce, cross talk, and predicting RFI/EMI. Complete designs can be simulated and evaluated before going through the expensive and time-consuming process of producing prototype PCBs. This type of pre-layout simulation can considerably reduce the development cost and time to market, while increasing the reliability of the I/O operation.

IBIS models consist of look-up tables that predict the I/V characteristics and dV/dt of integrated circuit inputs and outputs when combined with PCB traces, cables and passive components. The data is extracted for the typical case, minimum case (weak transistors, low VCC, hot temperatures) and maximum case (strong transistors, high VCC, cold temperatures).

IBIS models have a limitation in that they do not contain internal delays. IBIS models contain package parasitic information for simulation of ground bounce. However, not all simulators are able to use this data to simulate ground bounce. Simulation results may not agree with measurement results due to package, die, PCB trace and ground plane modeling inaccuracies. Similarly, because simultaneous switching outputs (SSOs) are also difficult to model, only a first approximation is provided to the designer.

IBIS Generation

IBIS models are generated either from SPICE simulations or from actual device measurements. A SPICE netlist of the I/O buffer is required to produce V/I and dV/dt simulation curve data. The SPICE simulation data is then converted to an IBIS format/syntax file.

IBIS models that are derived from measurement data do not have process corner information, unlike IBIS models that are derived from SPICE simulation data. It is only practical to measure a few parts, and it is therefore impossible to represent the extremes of production by such a method.

Advantages of IBIS

Using IBIS models has a great advantage to the user in that simulation speed is significantly increased over SPICE, while accuracy is only slightly decreased. Non-convergence, which can be a problem with SPICE models and simulators, is eliminated in IBIS simulation. Virtually all EDA vendors presently support IBIS models and ease of use of these IBIS simulators is generally very good. IBIS models for most devices are freely available over the Internet, making it easy to simulate several different manufacturers devices on the same board.

IBIS File Structure

An IBIS file contains two sections, the header and the model data for each component. One IBIS file can describe several devices. The following is the contents list in a typical IBIS file:

- IBIS Version
- File Name
- File Revision
- Component
- Package R/L/C
- Pin name, model, R/L/C
- Model (i.e., 3-state)
- Temperature Range (typical, minimum, and maximum)
- Voltage Range (typical, minimum, and maximum)
- Pull-Up Reference
- Pull-Down Reference
- Power Clamp Reference
- Ground Clamp Reference
- I/V Tables for:
  - Pull-Up
  - Pull-Down
  - Power Clamp
  - Ground Clamp
- Rise and Fall dV/dt for minimum, typical, and maximum conditions (driving 50Ω)
- Package Model (optional) <package_number>.pkg with RLC sections.

**IBIS I/V and dV/dt Curves**

A digital buffer can be measured in receive (3-state) mode and drive mode. IBIS I/V curves are based on the data of both these modes. The transition between modes is achieved by phasing in/out the difference between the driver and the receiver models, while keeping the receiver model constantly in the circuit.

The I/V curve range required by the IBIS specification is \(-V_{CC}\) to \(2xV_{CC}\). This wide voltage range exists because the theoretical maximum overshoot due to a full reflection is twice the signal swing. The ground clamp I/V curve must be specified over the range \(-V_{CC}\) to \(V_{CC}\), and the power clamp I/V curve must be specified from \(V_{CC}\) to \(2xV_{CC}\).

The three supported conditions for the IBIS buffer models are typical values (required), minimum values (optional), and maximum values (optional). For CMOS buffers, the minimum condition is defined as high temperature and low supply voltage, and the maximum condition is defined as low temperature and high supply voltage.

An IBIS model of a digital buffer has four I/V curves:

- The pull-down I/V curve contains the mode data for the driver driving low. The origin of the curve is at 0V for CMOS buffers.
- The pull-up I/V curve contains the mode data for the driver driving high. The origin of the curve is at the supply voltage (\(V_{CC}\) or \(V_{DD}\)).
- The ground clamp I/V curve contains receive (3-state) mode data, with the origin of the curve at 0V for CMOS buffers.
- The power clamp I/V curve contains receive (3-state) mode data, with the origin of the curve at the supply voltage (\(V_{CC}\) or \(V_{DD}\)). For 3.3V buffers that are 5V tolerant, the power clamp is referenced to 5V while the pull-up is referenced to 3.3V.

**Ramp and dV/dt Curves**

The Ramp keyword contains information on how fast the pull-up and pull-down transistors turn on/off. The dV/dt curves give the same information, while including the effects of die capacitance (\(C_{comp}\)). \(C_{comp}\) is the total die capacitance as seen at the die pad, excluding the package capacitance.

dV/dt curves describe the transient characteristics of a buffer more accurately than ramps. A minimum of four dV/dt curves are required to describe a CMOS buffer: pull-down ON, pull-up OFF, pull-down OFF, and pull-up ON. dV/dt curves incorporate the clock-to-out delay, and the length of the dV/dt curve corresponds to the clock speed at which the buffer is used. Each dV/dt curve has \(t = 0\), where the pulse crosses the input threshold.
Xilinx IBIS Package Parasitic Modelling

Xilinx IBIS modeling previously used a simple RCL model for the pin and bond wire parasitics. Due to the fast rise and fall times of many of the supported I/O standards, it was deemed necessary to improve the package parasitic modeling. The latest IBIS 3.2 specification has a complex parasitic package model, which incorporates a transmission line and lumped RCL model. Unfortunately, IBIS 3.2 is still not widely supported by simulators.

For these reasons, the old lumped package parasitic parameters have been removed from the latest models, and the user should now manually add an external transmission line. A 65Ω ideal transmission line, with the delay set at 25 ps to 100 ps, is recommended. This works in conjunction with a revised lumped model (included inside the IBIS model). For critical applications, both extremes (25 ps and 100 ps) should be checked. However, for most I/O applications this difference is very small.

IBIS Simulations

The circuit shown in Figure 4-78 models a Virtex-II Pro LVCMOS_18F driver and receiver, connected by a 6-inch 50Ω circuit board trace. The rise and fall simulation results show that there is a large amount of overshoot and undershoot, which is actually limited by the IOB clamp diodes.

Figure 4-78: Unterminated Example
By adding a series termination resistor to the driver output, the overshoot and undershoot can be effectively controlled. The simulation results in Figure 4-79 show that by adding a 25Ω termination there is minimal overshoot and undershoot.

![Figure 4-79: Series Termination Example](UG012_c4_115_1111901)

An alternative is to use a DCI source impedance controlled driver. The results shown in Figure 4-80 show the waveforms from an LVDCI_18 driver, which has virtually no overshoot or undershoot.

![Figure 4-80: DCI Driver Example](UG012_c4_116_1111901)

**IBIS Simulators**

Several different IBIS simulators are available today, and each simulator provides different results. An overshoot or undershoot of ±10% of the measured result is tolerable. Differences between the model and measurements occur because not all parameters are modeled. Simulators for IBIS models are provided by Cadence, Avanti Corporation, Hyperlynx, Mentor, Microsim, Intusoft, Veribest, and Viewlogic.
Xilinx IBIS Advantages

Xilinx provides preliminary IBIS files before working silicon has been verified (before tape out), as well as updated versions of IBIS files after the ICs are verified. Preliminary IBIS files are generated from SPICE models before working silicon has been verified. After the IC (device) is verified, appropriate changes are made to the existing IBIS files. These IBIS files are available at the following web site:

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

ANSI/EIA IBIS Official Website

http://www.eigroup.org/ibis/ibis.htm

BSDL and Boundary Scan Models

Boundary scan is a technique that is used to improve the testability of ICs. With Virtex-II Pro devices, registers are placed on I/Os that are connected together as a long shift register. Each register can be used to either save or force the state of the I/O. There are additional registers for accessing test modes.

The most common application for boundary scan is testing for continuity of the IC to the board. Some packages make visual inspection of solder joints impossible, e.g. BGA. The large number of I/Os available requires the use of such packages, and also increases the importance of testing. A large number of I/Os also means a long scan chain.

Test software is available to support testing with boundary scan. The software requires a description of the boundary scan implementation of the IC. The IEEE 1149.1 specification provides a language description for Boundary Scan Description Language (BSDL). Boundary scan test software accepts BSDL descriptions.

The IEEE 1149.1 spec also defines a 4 to 5 pin interface known as the JTAG interface. IEEE 1532 is a capability extension of IEEE 1149.1.

BSDL Files

Preliminary BSDL files are provided from the IC Design Process. Final BSDL files have been verified by an external third party test and verification vendor. Table 4-7 lists the Virtex-II Pro BSDL file names.

Table 4-7: Virtex-II Pro BSDL File Names

<table>
<thead>
<tr>
<th>XC2VP2_FG256.BSD</th>
<th>XC2VP20_FF896.BSD</th>
<th>XC2VP50_FF1517.BSD</th>
</tr>
</thead>
<tbody>
<tr>
<td>XC2VP2_FG456.BSD</td>
<td>XC2VP20_FF152.BSD</td>
<td>XC2VP70_FF1517.BSD</td>
</tr>
<tr>
<td>XC2VP2_FF672.BSD</td>
<td>XC2VP30_FF896.BSD</td>
<td>XC2VP70_FF1704.BSD</td>
</tr>
<tr>
<td>XC2VP4_FG256.BSD</td>
<td>XC2VP30_FF152.BSD</td>
<td>XC2VP100_FF1704.BSD</td>
</tr>
<tr>
<td>XC2VP4_FG456.BSD</td>
<td>XC2VP40_FF152.BSD</td>
<td>XC2VP100_FF1696.BSD</td>
</tr>
<tr>
<td>XC2VP4_FF672.BSD</td>
<td>XC2VP40_FF1148.BSD</td>
<td>XC2VP125_FF1704.BSD</td>
</tr>
<tr>
<td>XC2VP7_FG456.BSD</td>
<td>XC2VP40_FF1517.BSD</td>
<td>XC2VP125_FF1696.BSD</td>
</tr>
<tr>
<td>XC2VP7_FF672.BSD</td>
<td>XC2VP50_FF1152.BSD</td>
<td>XC2VP125_FF1696.BSD</td>
</tr>
<tr>
<td>XC2VP7_FF896.BSD</td>
<td>XC2VP50_FF1148.BSD</td>
<td></td>
</tr>
</tbody>
</table>
Using BitGen

BitGen produces a bitstream for Xilinx device configuration. After the design has been completely routed, it is necessary to configure the device so that it can execute the desired function. The Xilinx bitstream necessary to configure the device is generated with BitGen. BitGen takes a fully routed NCD (Circuit Description) file as its input and produces a configuration bitstream—a binary file with a .bit extension.

The BIT file contains all of the configuration information from the NCD file defining the internal logic and interconnections of the FPGA, plus device-specific information from other files associated with the target device. The binary data in the BIT file can then be downloaded into the FPGA memory cells, or it can be used to create a PROM file (see Figure A-1).
Appendix A: BitGen and PROMGen Switches and Options

BitGen Syntax

The following syntax creates a bitstream from your NCD file.

```
bitgen [options] infile[.ncd] [outfile] [pcf_file]
```

- **options** is one or more of the options listed in BitGen Options, page 521.
- **Infile** is the name of the NCD design for which you want to create the bitstream. You can specify only one design file, and it must be the first file specified on the command line.
- **Outfile** is the name of the output file. If you do not specify an output file name, BitGen creates one in the same directory as the input file. If you specify -l on the command line, the extension is .ll (see -l command line option). If you specify -m (see -m command line option), the extension is .msk. If you specify -b, the extension is .rbt. Otherwise the extension is .bit. If you do not specify an extension, BitGen appends one according to the aforementioned rules. If you do include an extension, it must also conform to the rules.
- **Pcf_file** is the name of a physical constraints (PCF) file. BitGen uses this file to determine which nets in the design are critical for tiedown, which is not available for Virtex families.

BitGen automatically reads the .pcf file by default. If the physical constraints file is the second file specified on the command line, it must have a .pcf extension. If it is the third file specified, the extension is optional; .pcf is assumed. If a .pcf file name is specified, it must exist, otherwise the input design name with a .pcf extension is read if that file exists.

A report file containing all BitGen’s output is automatically created under the same directory as the output file. The report file has the same root name as the output file with a .bgn extension.

BitGen Files

This section describes input files that BitGen requires and output files that BitGen generates.

**Input Files**

Input to BitGen consists of the following files.

- NCD file—a physical description of the design mapped, placed and routed in the target device. The NCD file must be fully routed.
- PCF—an optional user-modifiable ASCII Physical Constraints File. If you specify a PCF file on the BitGen command line, BitGen uses this file to determine which nets in the design are critical for tiedown (not used for Virtex families).

**Output Files**

Output from BitGen consists of the following files.

- BIT file—a binary file with a .bit extension. The BIT file contains all of the configuration information from the NCD file defining the internal logic and interconnections of the FPGA, plus device-specific information from other files associated with the target device. The binary data in the BIT file can then be downloaded into the FPGA memory cells, or it can be used to create a PROM file (see Using PROMGen, page 525).
- RBT file—an optional “rawbits” file with an .rbt extension. The rawbits file is ASCII ones and zeros representing the data in the bitstream file. If you enter a -b option on the BitGen command line, an RBT file is produced in addition to the binary BIT file (see -b (Create Rawbits File), page 521).
- LL file—an optional ASCII logic allocation file with a .ll extension. The logic allocation file indicates the bitstream position of latches, flip-flops, and IOB inputs and outputs. A .ll file is produced if you enter a -l option on the BitGen command line (-l (Create a
Using BitGen

Logic Allocation File), page 525).

- MSK file—an optional mask file with an .msk extension. This file is used to compare relevant bit locations for executing a readback of configuration data contained in an operating FPGA. A MSK file is produced if you enter a -m option on the BitGen command line (see -m (Generate a Mask File), page 525).

- BGN file—a report file containing information about the BitGen run.

- DRC file—a Design Rule Check (DRC) file for the design. A DRC runs and the DRC file is produced unless you enter a -d option on the BitGen command line (see -d (Do Not Run DRC), page 521).

BitGen Options

Following is a description of command line options and how they affect BitGen behavior.

-b (Create Rawbits File)

Create a “rawbits” (file_name.rbt) file. The rawbits file consists of ASCII ones and zeros representing the data in the bitstream file.

If you are using a microprocessor to configure a single FPGA, you can include the rawbits file in the source code as a text file to represent the configuration data. The sequence of characters in the rawbits file is the same as the sequence of bits written into the FPGA.

-d (Do Not Run DRC)

Do not run DRC (Design Rule Check). Without the -d option, BitGen runs a DRC and saves the DRC results in two output files: the BitGen report file (file_name.bgn) and the DRC file (file_name.drc). If you enter the -d option, no DRC information appears in the report file and no DRC file is produced.

Running DRC before a bitstream is produced detects any errors that could cause the FPGA to malfunction. If DRC does not detect any errors, BitGen produces a bitstream file (unless you use the -j option described in the -j (No BIT File), page 525).

-f (Execute Commands File)

-f command_file

The -f option executes the command line arguments in the specified command_file.

-g (Set Configuration)

-g option:setting

The -g option specifies the startup timing and other bitstream options for Xilinx FPGAs. The settings for the -g option depend on the design’s architecture. These options have the following syntax.

Compress

Enable bitstream compression using multiple frame writes (MFW).

Readback

This allows the user to perform Readback by the creating the necessary bitstream (.rbb file).

CRC

Virtex-II allows the user to enable or disable the CRC checking. If CRC checking is disabled, a CBC (Constant Bit Check) is used instead.

Settings: Enable, Disable
Default: Enable
Appendix A: BitGen and PROMGen Switches and Options

**DebugBitstream**
This option creates a modified bitstream which loads each frame individually, and places an LOUT write after each, for debugging purposes. This option should be used only in Master or Slave Serial downloads.
Settings: Yes, No
Default: No

**ConfigRate**
Virtex-II devices use an internal oscillator to generate CCLK when configuring in Master SelectMAP or Master Serial modes. This option sets the CCLK rate in MHz.
Settings: 4,5,6,7,8,10,13,15,20,26,30,34,41,45,51,55,60,130
Default: 4

**StartupClk**
The last few cycles of configuration is called the startup sequence. The startup sequence can be clocked by CCLK signal, a User clock (connected to the STARTUP block), or TCK (the JTAG clock).
Settings: CCLK, UserClk, JTAGClk
Default: CCLK

**PowerdownStatus**
This options allows the user to choose whether the DONE pin is used as the PowerDown pin after configuration.
Settings: Enable, Disable
Default: Enable

**DCMShutdown**
If the DCMShutdown option is enabled, the DCM resets if the SHUTDOWN and AGHIGH commands are performed.
Settings: Enable, Disable
Default: Disable

**CclkPin**
This option selects an internal pullup on the CCLK pin.
Settings: Pullnone, Pullup
Default: Pullup

**DonePin**
This option selects an internal pullup on the DONE pin.
Settings: Pullnone, Pullup
Default: Pullup

**M0Pin**
This option selects an internal pullup or pulldown on the M0 (Mode 0) pin.
Settings: Pullnone, Pullup, Pulldown
Default: Pullup

**M1Pin**
This option selects an internal pullup or pulldown on the M1 (Mode 1) pin.
Settings: Pullnone, Pullup, Pulldown
Default: Pullup
M2Pin
This option selects an internal pullup or pulldown on the M2 (Mode 2) pin.
Settings: Pullnone, Pullup, Pulldown
Default: Pullup

ProgPin
This option selects an internal pullup on the PROGRAM pin.
Settings: Pullnone, Pullup
Default: Pullup

TckPin
This option selects an internal pullup or pulldown on the TCK (JTAG Clock) pin.
Settings: Pullnone, Pullup, Pulldown
Default: Pullup

TdiPin
This option selects an internal pullup or pulldown on the TDI (JTAG Input) pin.
Settings: Pullnone, Pullup, Pulldown
Default: Pullup

TdoPin
This option selects an internal pullup or pulldown on the TDO (JTAG Output) pin.
Settings: Pullnone, Pullup, Pulldown
Default: Pullup

TmsPin
This option selects an internal pullup or pulldown on the TMS (JTAG Mode Select) pin.
Settings: Pullnone, Pullup, Pulldown
Default: Pullup

UnusedPin
This option selects an internal pullup or pulldown on all unused I/Os.
Settings: Pullnone, Pullup, Pulldown
Default: Pulldown

GWE_cycle
Selects the startup phase that asserts the internal write enable to flip-flops, LUT RAMs, shift registers, and BRAMs. Before the startup phase both BRAM writing and reading are disabled. The Done setting asserts GWE when the DoneIn signal is high. DoneIn is either the value of the DONE pin or a delayed version if DonePipe=Yes. The Keep setting is used to keep the current value of the GWE signal.
Settings: 1, 2, 3, 4, 5, 6, Done, Keep
Default: 6

GTS_cycle
Selects the startup phase that releases the internal 3-state control to the I/O buffers. The Done setting releases GTSA when the DoneIn signal is high. DoneIn is either the value of the DONE pin or a delayed version if DonePipe=Yes. The Keep setting is used to keep the current value of the GTS signal.
Settings: 1, 2, 3, 4, 5, 6, Done, Keep
Default: 5
Appendix A: BitGen and PROMGen Switches and Options

LCK_cycle
Selects the startup phase to wait until DCM locks are asserted.
Settings: 0, 1, 2, 3, 4, 5, 6, NoWait
Default: NoWait

MATCH_cycle
Selects the startup phase to wait until DCI locks are asserted.
Settings: 0, 1, 2, 3, 4, 5, 6, NoWait, Auto
Default: Auto

DONE_cycle
Selects the startup phase that activates the FPGA DONE signal. DONE is delayed when DonePipe=Yes.
Settings: 1, 2, 3, 4, 5, 6
Default: 4

Persist
This option is needed for Readback and Partial Reconfiguration using the configuration pins. If Persist=Yes, all the configuration pins used retain their function. Which configuration pins are persisted is determined by the mode pin settings. If a serial mode is chosen, the persisted pins would be INIT, DOUT, and DIN. If a SelectMAP mode is chosen, the persisted pins would be INIT, BUSY, D0-D7, CS, and WRITE.
Settings: Yes, No
Default: No

DriveDone
This option actively drives the DONE pin high as opposed to an open-drain driver. Take care when setting DriveDone=Yes in daisy-chain applications.
Settings: Yes, No
Default: No

DonePipe
This option is intended for use with FPGAs being set up in a high-speed daisy-chain configuration. When set to Yes, the FPGA waits on the DONE pin, and waits for the first StartupClk edge before moving to the Done state.
Settings: Yes, No
Default: No

Security
This option selects the level of bitstream security. Selecting Level 1 disables Readback, and selecting Level 2 disables Readback and reconfiguration.
Settings: Level1, Level2, None
Default: None

UserID
The user can enter up to an 8-digit hexadecimal code (32-bit value) in the UserID register. You can use the register to identify implementation or design revisions.
Settings: <any 8-digit hex string>
Default: 0xFFFFFFFF
Using PROMGen

-h or -help (Command Usage)

-\texttt{h architecture}
Displays a usage message for BitGen. The usage message displays all available options for BitGen operating on the specified \textit{architecture}.

-j (No BIT File)
Do not create a bitstream file (.bit file). This option is generally used when you want to generate a report without producing a bitstream. For example, if you wanted to run DRC without producing a bitstream file, you would use the -j option.

Note: The .msk or .rtb files might still be created.

-l (Create a Logic Allocation File)
This option creates an ASCII logic allocation file (\textit{design.ll}) for the selected design. The logic allocation file indicates the bitstream position of latches, flip-flops, and IOB inputs and outputs.

In some applications, you may want to observe the contents of the FPGA internal registers at different times. The file created by the -l option helps you identify which bits in the current bitstream represent outputs of flip-flops and latches. Bits are referenced by frame and bit number within the frame.

The Hardware Debugger uses the \textit{design.ll} file to locate signal values inside a readback bitstream.

-m (Generate a Mask File)
Creates a mask file. This file is used to compare relevant bit locations for executing a readback of configuration data contained in an operating FPGA.

-w (Overwrite Existing Output File)
Enables you to overwrite an existing BIT, LL, MSK, or RBT output file.

Using PROMGen

The PROMGen program is compatible with the following families.

- Virtex/Virtex-E/Virtex-II/Virtex-II Pro

PROMGen formats a BitGen-generated configuration bitstream (BIT) file into a PROM format file (Figure A-2).

The PROM file contains configuration data for the FPGA device. PROMGen converts a BIT file into one of three PROM formats: MCS-86 (Intel), EXORMAX (Motorola), or TEKHEX (Tektronix). It can also generate a Hex file format.
There are two functionally equivalent versions of PROMGen. There is a stand-alone version you can access from an operating system prompt. You can also access an interactive version, called the PROM File Formatter, from inside the Design Manager for Alliance or the Project Manager in Foundation. This chapter describes the stand-alone version; the interactive version is described in the PROM File Formatter Guide.

You can also use PROMGen to concatenate bitstream files to daisy-chain FPGAs.

Note: If the destination PROM is one of the Xilinx Serial PROMs, you are using a Xilinx PROM Programmer, and the FPGAs are not being daisy-chained, it is not necessary to make a PROM file. See the Hardware User Guide for more information about daisy-chained designs.

**PROMGen Syntax**

Use the following syntax to start PROMGen from the operating system prompt:

```
promgen [options]
```

*Options* can be any number of the options listed in PROMGen Options, page 527. Separate multiple options with spaces.

**PROMGen Files**

This section describes the PROMGen input and output files.

**Input Files**

The input to PROMGEN consists of BIT files—one or more bitstream files. BIT files contain configuration data for an FPGA design.

**Output Files**

Output from PROMGEN consists of the following files.

- PROM files—The file or files containing the PROM configuration information. Depending on the PROM file format used by the PROM programmer, you can output a TEK, MCS, or EXO file. If you are using a microprocessor to configure your devices, you can output a HEX file, containing a hexadecimal representation of the bitstream.
- PRM file—The PRM file is a PROM image file. It contains a memory map of the
output PROM file. The file has a .prm extension.

**Bit Swapping in PROM Files**

PROMGen produces a PROM file in which the bits within a byte are swapped compared to the bits in the input BIT file. Bit swapping (also called “bit mirroring”) reverses the bits within each byte, as shown in Figure A-3.

In a bitstream contained in a BIT file, the Least Significant Bit (LSB) is always on the left side of a byte. But when a PROM programmer or a microprocessor reads a data byte, it identifies the LSB on the right side of the byte. In order for the PROM programmer or microprocessor to read the bitstream correctly, the bits in each byte must first be swapped so they are read in the correct order.

In this release of the Xilinx Development System, the bits are swapped for all of the PROM formats: MCS, EXO, and TEK. For a HEX file output, bit swapping is on by default, but it can be turned off by entering a -b PROMGen option that is available only for HEX file format.

**PROMGen Options**

This section describes the options that are available for the PROMGen command.

- **b (Disable Bit Swapping—HEX Format Only)**
  
  This option only applies if the -p option specifies a HEX file for the output of PROMGen. By default (no -b option), bits in the HEX file are swapped compared to bits in the input BIT files. If you enter a -b option, the bits are not swapped. Bit swapping is described in Bit Swapping in PROM Files, page 527.

- **c (Checksum)**
  
  promgen -c
  
  The -c option generates a checksum value appearing in the .prm file. This value should match the checksum in the prom programmer. Use this option to verify that correct data was programmed into the prom.

- **d (Load Downward)**
  
  promgen -d hexaddress0 filename filename...
  
  This option loads one or more BIT files from the starting address in a downward direction. Specifying several files after this option causes the files to be concatenated in a daisy-chain. You can specify multiple -d options to load files at different addresses. You must specify this option immediately before the input bitstream file.

  The multiple file syntax is as follows:
Appendix A: BitGen and PROMGen Switches and Options

promgen -d hexaddress0 filename filename...

The multiple -d options syntax is as follows:

promgen -d hexaddress1 filename -d hexaddress2 filename...

-f (Execute Commands File)

-f command_file

The -f option executes the command line arguments in the specified command_file.

-h (Command Help)

This option displays help that describes the PROMGen options.

-l option (Disable Length Count)

promgen -l

The -l option disables the length counter in the FPGA bitstream. It is valid only for 4000EX, 4000XL, 4000XLA, 4000XV, and SpartanXL Devices. Use this option when chaining together bitstreams exceeding the 24 bit limit imposed by the length counter.

-n (Add BIT Files)

-n file1[.bit] file2[.bit]...

This option loads one or more BIT files up or down from the next available address following the previous load. The first -n option must follow a -u or -d option because -n does not establish a direction. Files specified with this option are not daisy-chained to previous files. Files are loaded in the direction established by the nearest prior -u, -d, or -n option.

The following syntax shows how to specify multiple files. When you specify multiple files, PROMGen daisy-chains the files.

promgen -d hexaddress file0 -n file1 file2...

The following syntax when using multiple -n options prevents the files from being daisy-chained:

promgen -d hexaddress file0 -n file1 -n file2...

-o (Output File Name)

-o file1[.ext] file2[.ext]...

This option specifies the output file name of a PROM if it is different from the default. If you do not specify an output file name, the PROM file has the same name as the first BIT file loaded.

ext is the extension for the applicable PROM format.

Multiple file names may be specified to split the information into multiple files. If only one name is supplied for split PROM files (by you or by default), the output PROM files are named file.#.ext, where file is the base name, # is 0, 1, etc., and ext is the extension for the applicable PROM format.

promgen -d hexaddress file0 -o filename

-p (PROM Format)

-p {mcs | exo | tek | hex}

This option sets the PROM format to one of the following: MCS (Intel MCS86), EXO (Motorola EXORMAX), TEK (Tektronix TEKHEX). The option may also produce a HEX file, which is a hexadecimal representation of the configuration bitstream used for microprocessor downloads. If specified, the -p option must precede any -u, -d, or -n options. The default format is MCS.
Using PROMGen

-\r (Load PROM File)

\r promfile

This option reads an existing PROM file as input instead of a BIT file. All of the PROMGen output options may be used, so the -r option can be used for splitting an existing PROM file into multiple PROM files or for converting an existing PROM file to another format.

-s (PROM Size)

-s promsize1 promsize2...

This option sets the PROM size in kilobytes. The PROM size must be a power of 2. The default value is 64 kilobytes. The -s option must precede any -u, -d, or -n options.

Multiple promsize entries for the -s option indicates the PROM will be split into multiple PROM files.

Note: PROMGen PROM sizes are specified in bytes. The Programmable Logic Data Book specifies PROM sizes in bits for Xilinx serial PROMs (see -x option).

-u (Load Upward)

-u hexaddress0 filename1 filename2...

This option loads one or more BIT files from the starting address in an upward direction. When you specify several files after this option, PROMGen concatenates the files in a daisy-chain. You can load files at different addresses by specifying multiple -u options.

This option must be specified immediately before the input bitstream file.

-x (Specify Xilinx PROM)

-x xilinx_prom1 xilinx_prom2...

The -x option specifies one or more Xilinx serial PROMs for which the PROM files are targeted. Use this option instead of the -s option if you know the Xilinx PROMs to use.

Multiple xilinx_prom entries for the -x option indicates the PROM will be split into multiple PROM files.

Examples

To load the file test.bit up from address 0x0000 in MCS format, enter the following information at the command line.

\promgen -u 0 test

To daisy-chain the files test1.bit and test2.bit up from address 0x0000 and the files test3.bit and test4.bit from address 0x4000 while using a 32K PROM and the Motorola EXORmax format, enter the following information at the command line.

\promgen -s 32 -p exo -u 00 test1 test2 -u 4000 test3 test4

To load the file test.bit into the PROM programmer in a downward direction starting at address 0x4000, using a Xilinx XC1718D PROM, enter the following information at the command line.

\promgen -x xc1718d -d 0x400 test

To specify a PROM file name that is different from the default file name enter the following information at the command line.

\promgen options filename -o newfilename
Appendix B

XC18V00 Series PROMs

This appendix contains package specifications for the XC18V00 Series of In-System Programmable Configuration PROMs, as well as the XC18V00 Series product specification (DS026). The latest version of this information is available online (at www.xilinx.com).

PROM Package Specifications

This section contains specifications for the following Virtex-II packages:

- PC20-84 Specification
- SO20 Specification
- VQ44 Specification
Appendix B: XC18V00 Series PROMs

PC20-84 Specification

NOTES:
2. DIMENSIONS ‘D1’ AND ‘E1’ DO NOT INCLUDE MOLD FLASH OR PROTRUSIONS. MOLD FLASH OR PROTRUSIONS SHALL NOT EXCEED .010 PER SIDE.
3. ‘N’ IS NUMBER OF TERMINALS.
4. CONFORM TO JEDEC MD-047
5. TOP OF PACKAGE MAY BE SMALLER THAN BOTTOM BY .010”.

20, 28, 44, 68 and 84–PIN PLCC (PC20 THRU PC84)

Figure B-1: PC20-84 Specification
PROM Package Specifications

SO20 Specification

**Figure B-2:** SO20 Specification

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>MIN.</th>
<th>NOM.</th>
<th>MAX.</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td>.097</td>
<td>.101</td>
<td>.104</td>
</tr>
<tr>
<td>A₁</td>
<td>.005</td>
<td>.009</td>
<td>.0115</td>
</tr>
<tr>
<td>A₂</td>
<td>.090</td>
<td>.092</td>
<td>.094</td>
</tr>
<tr>
<td>B</td>
<td>.014</td>
<td>.016</td>
<td>.019</td>
</tr>
<tr>
<td>C</td>
<td>.0091</td>
<td>.010</td>
<td>.0125</td>
</tr>
<tr>
<td>D</td>
<td>.500</td>
<td>.505</td>
<td>.510</td>
</tr>
<tr>
<td>E</td>
<td>.292</td>
<td>.296</td>
<td>.299</td>
</tr>
<tr>
<td>e</td>
<td>.050</td>
<td>BSC</td>
<td></td>
</tr>
<tr>
<td>H</td>
<td>.400</td>
<td>.406</td>
<td>.410</td>
</tr>
<tr>
<td>h</td>
<td>-.010</td>
<td>--</td>
<td>.029</td>
</tr>
<tr>
<td>L</td>
<td>.024</td>
<td>.032</td>
<td>.040</td>
</tr>
<tr>
<td>Q</td>
<td>0°</td>
<td>5°</td>
<td>8°</td>
</tr>
</tbody>
</table>

**NOTES:**

2. DIMENSION "D" DOES NOT INCLUDE MOLD PROTRUSION. ALLOWABLE MOLD PROTRUSION SHALL NOT EXCEED .006" PER SIDE.
3. DIMENSION "E" DOES NOT INCLUDE MOLD PROTRUSION. ALLOWABLE MOLD PROTRUSION SHALL NOT EXCEED .010" PER SIDE.
4. LEAD FINISH: SOLDER PLATE
5. CONFORMS TO JEDEC MS-013-AC
Appendix B: XC18V00 Series PROMs

VQ44 Specification

![VQ44 Specification Diagram]

Figure B-3: VQ44 Specification

<table>
<thead>
<tr>
<th></th>
<th>MILLIMETERS</th>
<th>MILLIMETERS</th>
<th>MILLIMETERS</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>MIN.</td>
<td>NOM.</td>
<td>MAX.</td>
</tr>
<tr>
<td>A</td>
<td>1.20</td>
<td>1.20</td>
<td>1.20</td>
</tr>
<tr>
<td>A1</td>
<td>0.05</td>
<td>0.05</td>
<td>0.05</td>
</tr>
<tr>
<td>A2</td>
<td>0.95</td>
<td>1.00</td>
<td>1.05</td>
</tr>
<tr>
<td>D/E</td>
<td>12.00 BSC</td>
<td>12.00 BSC</td>
<td>12.00 BSC</td>
</tr>
<tr>
<td>D/E</td>
<td>10.00 BSC</td>
<td>10.00 BSC</td>
<td>10.00 BSC</td>
</tr>
<tr>
<td>b</td>
<td>0.30</td>
<td>0.37</td>
<td>0.45</td>
</tr>
<tr>
<td>c</td>
<td>0.09</td>
<td>0.20</td>
<td>0.20</td>
</tr>
<tr>
<td>e</td>
<td>0.80 BSC</td>
<td>0.80 BSC</td>
<td>0.80 BSC</td>
</tr>
<tr>
<td>L</td>
<td>0.45</td>
<td>0.60</td>
<td>0.75</td>
</tr>
<tr>
<td>ccc</td>
<td>0.10</td>
<td>0.10</td>
<td>0.10</td>
</tr>
<tr>
<td>ddd</td>
<td>0.20</td>
<td>0.20</td>
<td>0.20</td>
</tr>
<tr>
<td>N</td>
<td>44</td>
<td>64</td>
<td>100</td>
</tr>
</tbody>
</table>

Ref. JEDEC MS-026-ACB

NOTES:
2. DIMENSIONS D1 AND E1 DO NOT INCLUDE MOLD PROTRUSION. ALLOWABLE MOLD PROTRUSION SHALL NOT EXCEED 0.25mm PER SIDE.
3. THE TOP OF PACKAGE MAY BE SMALLER THAN THE BOTTOM OF PACKAGE BY 0.15mm.

44, 64, 100-PIN PLASTIC VERY THIN QFP (VQ44, VQ64, VQ100)

UG002_app_04_111600
© 2001, 2002 Xilinx, Inc. All rights reserved. All Xilinx trademarks, registered trademarks, patents, and further disclaimers are as listed at http://www.xilinx.com/legal.htm. All other trademarks and registered trademarks are the property of their respective owners. All specifications are subject to change without notice.

NOTICE OF DISCLAIMER: Xilinx is providing this design, code, or information "as is." By providing the design, code, or information as one possible implementation of this feature, application, or standard, Xilinx makes no representation that this implementation is free from any claims of infringement. You are responsible for obtaining any rights you may require for your implementation. Xilinx expressly disclaims any warranty whatsoever with respect to the adequacy of the implementation, including but not limited to any warranties or representations that this implementation is free from claims of infringement and any implied warranties of merchantability or fitness for a particular purpose.
Pinout and Pin Description

Pins not listed are "no connects."

Table 1: Pin Names and Descriptions

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Boundary Scan Order</th>
<th>Function</th>
<th>Pin Description</th>
<th>44-pin VQFP</th>
<th>44-pin PLCC</th>
<th>20-pin SOIC and PLCC</th>
</tr>
</thead>
<tbody>
<tr>
<td>D0</td>
<td>4</td>
<td>DATA OUT</td>
<td>D0 is the DATA output pin to provide data for configuring an FPGA in serial mode.</td>
<td>40</td>
<td>2</td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>3</td>
<td>OUTPUT ENABLE</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>D1</td>
<td>6</td>
<td>DATA OUT</td>
<td>D0-D7 are the output pins to provide parallel data for configuring a Xilinx FPGA in Slave-Parallel/SelectMap mode.</td>
<td>29</td>
<td>35</td>
<td>16</td>
</tr>
<tr>
<td></td>
<td>5</td>
<td>OUTPUT ENABLE</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>D2</td>
<td>2</td>
<td>DATA OUT</td>
<td></td>
<td>42</td>
<td>4</td>
<td>2</td>
</tr>
<tr>
<td></td>
<td>1</td>
<td>OUTPUT ENABLE</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>D3</td>
<td>8</td>
<td>DATA OUT</td>
<td></td>
<td>27</td>
<td>33</td>
<td>15</td>
</tr>
<tr>
<td></td>
<td>7</td>
<td>OUTPUT ENABLE</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>D4</td>
<td>24</td>
<td>DATA OUT</td>
<td></td>
<td>9</td>
<td>15</td>
<td>7(1)</td>
</tr>
<tr>
<td></td>
<td>23</td>
<td>OUTPUT ENABLE</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>D5</td>
<td>10</td>
<td>DATA OUT</td>
<td></td>
<td>25</td>
<td>31</td>
<td>14</td>
</tr>
<tr>
<td></td>
<td>9</td>
<td>OUTPUT ENABLE</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>D6</td>
<td>17</td>
<td>DATA OUT</td>
<td></td>
<td>14</td>
<td>20</td>
<td>9</td>
</tr>
<tr>
<td></td>
<td>16</td>
<td>OUTPUT ENABLE</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>D7</td>
<td>14</td>
<td>DATA OUT</td>
<td></td>
<td>19</td>
<td>25</td>
<td>12</td>
</tr>
<tr>
<td></td>
<td>13</td>
<td>OUTPUT ENABLE</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
Table 1: Pin Names and Descriptions (Continued)

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Boundary Scan Order</th>
<th>Function</th>
<th>Pin Description</th>
<th>44-pin VQFP</th>
<th>44-pin PLCC</th>
<th>20-pin SOIC and PLCC</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLK</td>
<td>0</td>
<td>DATA IN</td>
<td>Each rising edge on the CLK input increments the internal address counter if both CE is Low and OE/RESET is High.</td>
<td>43</td>
<td>5</td>
<td>3</td>
</tr>
<tr>
<td>OE/RESET</td>
<td>20</td>
<td>DATA IN</td>
<td>When Low, this input holds the address counter reset and the DATA output is in a high-impedance state. This is a bidirectional open-drain pin that is held Low while the PROM is reset. Polarity is NOT programmable.</td>
<td>13</td>
<td>19</td>
<td>8</td>
</tr>
<tr>
<td></td>
<td>19</td>
<td>DATA OUT</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>18</td>
<td>OUTPUT ENABLE</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CE</td>
<td>15</td>
<td>DATA IN</td>
<td>When CE is High, the device is put into low-power standby mode, the address counter is reset, and the DATA pins are put in a high-impedance state.</td>
<td>15</td>
<td>21</td>
<td>10</td>
</tr>
<tr>
<td>CF</td>
<td>22</td>
<td>DATA OUT</td>
<td>Allows JTAG CONFIG instruction to initiate FPGA configuration without powering down FPGA. This is an open-drain output that is pulsed Low by the JTAG CONFIG command.</td>
<td>10</td>
<td>16</td>
<td>7(1)</td>
</tr>
<tr>
<td></td>
<td>21</td>
<td>OUTPUT ENABLE</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CEO</td>
<td>12</td>
<td>DATA OUT</td>
<td>Chip Enable Output (CEO) is connected to the CE input of the next PROM in the chain. This output is Low when CE is Low and OE/RESET input is High, AND the internal address counter has been incremented beyond its Terminal Count (TC) value. CEO returns to High when OE/RESET goes Low or CE goes High.</td>
<td>21</td>
<td>27</td>
<td>13</td>
</tr>
<tr>
<td></td>
<td>11</td>
<td>OUTPUT ENABLE</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>GND</td>
<td></td>
<td></td>
<td>GND is the ground connection.</td>
<td>6, 18, 28 &amp; 41</td>
<td>3, 12, 24 &amp; 34</td>
<td>11</td>
</tr>
<tr>
<td>TMS</td>
<td></td>
<td>MODE SELECT</td>
<td>The state of TMS on the rising edge of TCK determines the state transitions at the Test Access Port (TAP) controller. TMS has an internal 50K ohm resistive pull-up on it to provide a logic “1” to the device if the pin is not driven.</td>
<td>5</td>
<td>11</td>
<td>5</td>
</tr>
<tr>
<td>TCK</td>
<td></td>
<td>CLOCK</td>
<td>This pin is the JTAG test clock. It sequences the TAP controller and all the JTAG test and programming electronics.</td>
<td>7</td>
<td>13</td>
<td>6</td>
</tr>
<tr>
<td>TDI</td>
<td></td>
<td>DATA IN</td>
<td>This pin is the serial input to all JTAG instruction and data registers. TDI has an internal 50K ohm resistive pull-up on it to provide a logic “1” to the system if the pin is not driven.</td>
<td>3</td>
<td>9</td>
<td>4</td>
</tr>
<tr>
<td>TDO</td>
<td></td>
<td>DATA OUT</td>
<td>This pin is the serial output for all JTAG instruction and data registers. TDO has an internal 50K ohm resistive pull-up on it to provide a logic “1” to the system if the pin is not driven.</td>
<td>31</td>
<td>37</td>
<td>17</td>
</tr>
<tr>
<td>VCC</td>
<td></td>
<td></td>
<td>Positive 3.3V supply voltage for internal logic and input buffers.</td>
<td>17, 35 &amp; 38</td>
<td>23, 41 &amp; 44</td>
<td>18 &amp; 20</td>
</tr>
</tbody>
</table>
Table 1: Pin Names and Descriptions (Continued)

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Boundary Scan Order</th>
<th>Function</th>
<th>Pin Description</th>
<th>44-pin VQFP</th>
<th>44-pin PLCC</th>
<th>20-pin SOIC and PLCC</th>
</tr>
</thead>
<tbody>
<tr>
<td>( V_{CCO} )</td>
<td></td>
<td>Positive 3.3V or 2.5V supply voltage connected to the output voltage drivers.</td>
<td>8, 16, 26 &amp; 36</td>
<td>14, 22, 32 &amp; 42</td>
<td>19</td>
<td></td>
</tr>
<tr>
<td>NC</td>
<td></td>
<td>No connects.</td>
<td>1, 2, 4, 11, 12, 20, 22, 23, 24, 30, 32, 33, 34, 37, 39, 44</td>
<td>1, 6, 7, 8, 10, 17, 18, 26, 28, 29, 30, 36, 38, 39, 40, 43</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Notes:
1. By default, pin 7 is the D4 pin in the 20-pin packages. However, CF -> D4 programming option can be set to override the default and route the CF function to pin 7 in the Serial mode.

Pinout Diagrams
# Xilinx FPGAs and Compatible PROMs

Table 2 provides a list of Xilinx FPGAs and compatible PROMs.

<table>
<thead>
<tr>
<th>Device</th>
<th>Configuration Bits</th>
<th>XC18V00 Solution</th>
</tr>
</thead>
<tbody>
<tr>
<td>XC2VP2</td>
<td>1,305,440</td>
<td>XC18V02</td>
</tr>
<tr>
<td>XC2VP4</td>
<td>3,006,560</td>
<td>XC18V04</td>
</tr>
<tr>
<td>XC2VP7</td>
<td>4,485,472</td>
<td>XC18V04 + XCV18V512</td>
</tr>
<tr>
<td>XC2VP20</td>
<td>8,214,624</td>
<td>2 of XC18V04</td>
</tr>
<tr>
<td>XC2VP30</td>
<td>11,364,608</td>
<td>3 of XC18V04</td>
</tr>
<tr>
<td>XC2VP40</td>
<td>15,563,264</td>
<td>4 of XC18V04</td>
</tr>
<tr>
<td>XC2VP50</td>
<td>19,021,472</td>
<td>5 of XC18V04</td>
</tr>
<tr>
<td>XC2VP70</td>
<td>25,604,096</td>
<td>6 of XC18V04 + XCV18V512</td>
</tr>
<tr>
<td>XC2VP100</td>
<td>33,645,312</td>
<td>8 of XC18V04 + XCV18V526</td>
</tr>
<tr>
<td>XC2VP125</td>
<td>42,782,208</td>
<td>10 of XC18V04 + XCV18V01</td>
</tr>
<tr>
<td>XC2V40</td>
<td>360,096</td>
<td>XCV18V512</td>
</tr>
<tr>
<td>XC2V80</td>
<td>635,296</td>
<td>XCV18V01</td>
</tr>
<tr>
<td>XC2V250</td>
<td>1,697,184</td>
<td>XCV18V02</td>
</tr>
<tr>
<td>XC2V500</td>
<td>2,761,888</td>
<td>XCV18V04</td>
</tr>
<tr>
<td>XC2V1000</td>
<td>4,082,592</td>
<td>XCV18V04</td>
</tr>
<tr>
<td>XC2V1500</td>
<td>5,659,296</td>
<td>XCV18V04 + XCV18V02</td>
</tr>
</tbody>
</table>

*See pin descriptions.*
In-System Programmable PROMs can be programmed individually, or two or more can be daisy-chained together and programmed in-system via the standard 4-pin JTAG protocol as shown in Figure 2. In-system programming offers quick and efficient design iterations and eliminates unnecessary package handling or socketing of devices. The Xilinx development system provides the programming sequence using either Xilinx iMPACT software and a download cable, a third-party JTAG development system, a JTAG-compatible board tester, or a simple microprocessor interface that emulates the JTAG instruction sequence. The iMPACT software also outputs serial vector format (SVF) files for use with any tools that accept SVF format and with automatic test equipment.

All outputs are held in a high-impedance state or held at clamp levels during in-system programming.

**OE/RESET**

The ISP programming algorithm requires issuance of a reset that causes OE to go Low.

**External Programming**

Xilinx reprogrammable PROMs can also be programmed by the Xilinx HW-130 or a third-party device programmer. This provides the added flexibility of using pre-programmed devices with an in-system programmable option for future enhancements and design changes.

**Reliability and Endurance**

Xilinx in-system programmable products provide a guaranteed endurance level of 20,000 in-system program/erase cycles and a minimum data retention of 20 years. Each device meets all functional, performance, and data retention specifications within this endurance limit.

**Design Security**

The Xilinx in-system programmable PROM devices incorporate advanced data security features to fully protect the programming data against unauthorized reading via JTAG. Table 3 shows the security setting available.

The read security bit can be set by the user to prevent the internal programming pattern from being read or copied via JTAG. When set, it allows device erase. Erasing the entire device is the only way to reset the read security bit.

**Table 3: Data Security Options**

<table>
<thead>
<tr>
<th>Default = Reset</th>
<th>Set</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read Allowed</td>
<td>Read Inhibited via JTAG</td>
</tr>
<tr>
<td>Program/Erase Allowed</td>
<td>Program/Erase Allowed</td>
</tr>
<tr>
<td>Verify Allowed</td>
<td>Verify Inhibited</td>
</tr>
</tbody>
</table>

**Capacity**

<table>
<thead>
<tr>
<th>Devices</th>
<th>Configuration Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>XC18V04</td>
<td>4,194,304</td>
</tr>
<tr>
<td>XC18V02</td>
<td>2,097,152</td>
</tr>
<tr>
<td>XC18V01</td>
<td>1,048,576</td>
</tr>
<tr>
<td>XC18V512</td>
<td>524,288</td>
</tr>
<tr>
<td>XC18V256</td>
<td>262,144</td>
</tr>
</tbody>
</table>

**Table 2: Xilinx FPGAs and Compatible PROMs**

<table>
<thead>
<tr>
<th>Device</th>
<th>Configuration Bits</th>
<th>XC18V00 Solution</th>
</tr>
</thead>
<tbody>
<tr>
<td>XCV405E</td>
<td>3,430,400</td>
<td>XC18V04</td>
</tr>
<tr>
<td>XCV600E</td>
<td>3,961,632</td>
<td>XC18V04</td>
</tr>
<tr>
<td>XCV812E</td>
<td>6,519,648</td>
<td>2 of XC18V04</td>
</tr>
<tr>
<td>XCV1000E</td>
<td>6,587,520</td>
<td>2 of XC18V04</td>
</tr>
<tr>
<td>XCV1600E</td>
<td>8,308,992</td>
<td>2 of XC18V04</td>
</tr>
<tr>
<td>XCV2000E</td>
<td>10,159,648</td>
<td>3 of XC18V04</td>
</tr>
<tr>
<td>XCV2600E</td>
<td>12,922,336</td>
<td>4 of XC18V04</td>
</tr>
<tr>
<td>XCV3200E</td>
<td>16,283,712</td>
<td>4 of XC18V04</td>
</tr>
<tr>
<td>XC2S15</td>
<td>197,696</td>
<td>XC18V256</td>
</tr>
<tr>
<td>XC2S30</td>
<td>336,768</td>
<td>XC18V512</td>
</tr>
<tr>
<td>XC2S50</td>
<td>559,200</td>
<td>XC18V01</td>
</tr>
<tr>
<td>XC2S100</td>
<td>781,216</td>
<td>XC18V01</td>
</tr>
<tr>
<td>XC2S150</td>
<td>1,040,096</td>
<td>XC18V01</td>
</tr>
<tr>
<td>XC2S200</td>
<td>1,335,840</td>
<td>XC18V02</td>
</tr>
<tr>
<td>XC2S50E</td>
<td>630,048</td>
<td>XC18V01</td>
</tr>
<tr>
<td>XC2S100E</td>
<td>863,840</td>
<td>XC18V01</td>
</tr>
<tr>
<td>XC2S150E</td>
<td>1,134,496</td>
<td>XC18V02</td>
</tr>
<tr>
<td>XC2S200E</td>
<td>1,442,016</td>
<td>XC18V02</td>
</tr>
<tr>
<td>XC2S300E</td>
<td>1,875,648</td>
<td>XC18V02</td>
</tr>
</tbody>
</table>
IEEE 1149.1 Boundary-Scan (JTAG)

The XC18V00 family is fully compliant with the IEEE Std. 1149.1 Boundary-Scan, also known as JTAG. A Test Access Port (TAP) and registers are provided to support all required boundary scan instructions, as well as many of the optional instructions specified by IEEE Std. 1149.1. In addition, the JTAG interface is used to implement in-system programming (ISP) to facilitate configuration, erasure, and verification operations on the XC18V00 device.

Table 4 lists the required and optional boundary-scan instructions supported in the XC18V00. Refer to the IEEE Std. 1149.1 specification for a complete description of boundary-scan architecture and the required and optional instructions.

Instruction Register

The Instruction Register (IR) for the XC18V00 is eight bits wide and is connected between TDI and TDO during an instruction scan sequence. In preparation for an instruction scan sequence, the instruction register is parallel loaded with a fixed instruction capture pattern. This pattern is shifted out onto TDO (LSB first), while an instruction is shifted into the instruction register from TDI. The detailed composition of the instruction capture pattern is illustrated in Figure 3.

The ISP Status field, IR(4), contains logic “1” if the device is currently in ISP mode; otherwise, it contains logic “0”. The Security field, IR(3), contains logic “1” if the device has been programmed with the security option turned on; otherwise, it contains logic “0”.

Table 4: Boundary Scan Instructions

<table>
<thead>
<tr>
<th>Boundary-Scan Command</th>
<th>Binary Code [7:0]</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Required Instructions</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>BYPASS</td>
<td>11111111</td>
<td>Enables BYPASS</td>
</tr>
<tr>
<td>SAMPLE/ PRELOAD</td>
<td>00000001</td>
<td>Enables boundary-scan SAMPLE/PRELOAD operation</td>
</tr>
<tr>
<td>EXTEST</td>
<td>00000000</td>
<td>Enables boundary-scan EXTEST operation</td>
</tr>
<tr>
<td><strong>Optional Instructions</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLAMP</td>
<td>11111010</td>
<td>Enables boundary-scan CLAMP operation</td>
</tr>
<tr>
<td>HIGHZ</td>
<td>11111100</td>
<td>all outputs in high-impedance state simultaneously</td>
</tr>
<tr>
<td>IDCODE</td>
<td>11111110</td>
<td>Enables shifting out 32-bit IDCODE</td>
</tr>
<tr>
<td>USERCODE</td>
<td>11111101</td>
<td>Enables shifting out 32-bit USERCODE</td>
</tr>
<tr>
<td><strong>XC18V00 Specific Instructions</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CONFIG</td>
<td>11101110</td>
<td>Initiates FPGA configuration by pulsing CF pin Low</td>
</tr>
</tbody>
</table>

Figure 2: In-System Programming Operation (a) Solder Device to PCB and (b) Program Using Download Cable
Boundary Scan Register

The boundary-scan register is used to control and observe the state of the device pins during the EXTEST, SAMPLE/PRELOAD, and CLAMP instructions. Each output pin on the XC18V00 has two register stages that contribute to the boundary-scan register, while each input pin only has one register stage.

For each output pin, the register stage nearest to TDI controls and observes the output state, and the second stage closest to TDO controls and observes the High-Z enable state of the pin.

For each input pin, the register stage controls and observes the input state of the pin.

Identification Registers

The IDCODE is a fixed, vendor-assigned value that is used to electrically identify the manufacturer and type of the device being addressed. The IDCODE register is 32 bits wide. The IDCODE register can be shifted out for examination by using the IDCODE instruction. The IDCODE is available to any other system component via JTAG.

The IDCODE register has the following binary format:

\[ vvvv:ffff:aaaa:aaaa:cccc:cccc:ccc1 \]

where

- \( v \) = the die version number
- \( f \) = the family code (50h for XC18V00 family)
- \( a \) = the ISP PROM product ID (26h for the XC18V04)
- \( c \) = the company code (49h for Xilinx)

**Note:** The LSB of the IDCODE register is always read as logic “1” as defined by IEEE Std. 1149.1.

Table 5 lists the IDCODE register values for the XC18V00 devices.

<table>
<thead>
<tr>
<th>ISP-PROM</th>
<th>IDCODE</th>
</tr>
</thead>
<tbody>
<tr>
<td>XC18V01</td>
<td>05024093h</td>
</tr>
<tr>
<td>XC18V02</td>
<td>05025093h</td>
</tr>
<tr>
<td>XC18V04</td>
<td>05026093h</td>
</tr>
<tr>
<td>XC18V256</td>
<td>05022093h</td>
</tr>
<tr>
<td>XC18V512</td>
<td>05023093h</td>
</tr>
</tbody>
</table>

The USERCODE instruction gives access to a 32-bit user programmable scratch pad typically used to supply information about the device’s programmed contents. By using the USERCODE instruction, a user-programmable identification code can be shifted out for examination. This code is loaded into the USERCODE register during programming of the XC18V00 device. If the device is blank or was not loaded during programming, the USERCODE register contains FFFFFFFFh.

**XC18V00 TAP Characteristics**

The XC18V00 family performs both in-system programming and IEEE 1149.1 boundary-scan (JTAG) testing via a single 4-wire Test Access Port (TAP). This simplifies system designs and allows standard Automatic Test Equipment to perform both functions. The AC characteristics of the XC18V00 TAP are described as follows.

**TAP Timing**

Figure 4 shows the timing relationships of the TAP signals. These TAP timing characteristics are identical for both boundary-scan and ISP operations.
TAP AC Parameters

Table 6 shows the timing parameters for the TAP waveforms shown in Figure 4.

### Table 6: Test Access Port Timing Parameters

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCKMIN1</td>
<td>TCK minimum clock period</td>
<td>100</td>
<td>-</td>
<td>ns</td>
</tr>
<tr>
<td>TCKMIN2</td>
<td>TCK minimum clock period, Bypass Mode</td>
<td>50</td>
<td>-</td>
<td>ns</td>
</tr>
<tr>
<td>TMSS</td>
<td>TMS setup time</td>
<td>10</td>
<td>-</td>
<td>ns</td>
</tr>
<tr>
<td>TMSH</td>
<td>TMS hold time</td>
<td>25</td>
<td>-</td>
<td>ns</td>
</tr>
<tr>
<td>TDIS</td>
<td>TDI setup time</td>
<td>10</td>
<td>-</td>
<td>ns</td>
</tr>
<tr>
<td>TDIH</td>
<td>TDI hold time</td>
<td>25</td>
<td>-</td>
<td>ns</td>
</tr>
<tr>
<td>TDOV</td>
<td>TDO valid delay</td>
<td>-</td>
<td>25</td>
<td>ns</td>
</tr>
</tbody>
</table>

Connecting Configuration PROMs

Connecting the FPGA device with the configuration PROM (see Figure 5 and Figure 6).

- The DATA output(s) of the PROM(s) drives the Din input of the lead FPGA device.
- The Master FPGA CCLK output drives the CLK input(s) of the PROM(s) (in Master-Serial and Master-SelectMAP modes only).
- The CEO output of a PROM drives the CE input of the next PROM in a daisy chain (if any).
- The OE/RESET pins of all PROMs are connected to the INIT pins of all FPGA devices. This connection assures that the PROM address counter is reset before the start of any (re)configuration, even when a reconfiguration is initiated by a VCC glitch.
- The PROM CE input can be driven from the DONE pin. The CE input of the first (or only) PROM can be driven by the DONE output of all target FPGA devices, provided that DONE is not permanently grounded. CE can also be permanently tied Low, but this keeps the DATA output active and causes an unnecessary supply current of 10 mA maximum.
- Slave-Parallel/SelectMap mode is similar to slave serial mode. The DATA is clocked out of the PROM one byte per CCLK instead of one bit per CCLK cycle. See FPGA data sheets for special configuration requirements.

Initiating FPGA Configuration

The XC18V00 devices incorporate a pin named CF that is controllable through the JTAG CONFIG instruction. Executing the CONFIG instruction through JTAG pulses the CF low for 300-500 ns, which resets the FPGA and initiates configuration.

The CF pin must be connected to the PROGRAM pin on the FPGA(s) to use this feature.
The iMPACT software can also issue a JTAG CONFIG command to initiate FPGA configuration through the “Load FPGA” setting.

The 20-pin packages do not have a dedicated CF pin. For 20-pin packages, the CF --> D4 setting can be used to route the CF pin function to pin 7 only if the parallel output mode is not used.

Selecting Configuration Modes

The XC18V00 accommodates serial and parallel methods of configuration. The configuration modes are selectable through a user control register in the XC18V00 device. This control register is accessible through JTAG, and is set using the “Parallel mode” setting on the Xilinx iMPACT software. Serial output is the default configuration mode.

Master Serial Mode Summary

The I/O and logic functions of the Configurable Logic Block (CLB) and their associated interconnections are established by a configuration program. The program is loaded either automatically upon power up, or on command, depending on the state of the three FPGA mode pins. In Master Serial mode, the FPGA automatically loads the configuration program from an external memory. Xilinx PROMs are designed to accommodate the Master Serial mode.

Upon power-up or reconfiguration, an FPGA enters the Master Serial mode whenever all three of the FPGA mode-select pins are Low (M0=0, M1=0, M2=0). Data is read from the PROM sequentially on a single data line. Synchronization is provided by the rising edge of the temporary signal CCLK, which is generated by the FPGA during configuration.

Master Serial Mode provides a simple configuration interface. Only a serial data line, a clock line, and two control lines are required to configure an FPGA. Data from the PROM is read sequentially, accessed via the internal address and bit counters which are incremented on every valid rising edge of CCLK. If the user-programmable, dual-function DIN pin on the FPGA is used only for configuration, it must still be held at a defined level during normal operation. The Xilinx FPGA families take care of this automatically with an on-chip pull-up resistor.

Cascading Configuration PROMs

For multiple FPGAs configured as a serial daisy-chain, or a single FPGA requiring larger configuration memories in a serial or SelectMAP configuration mode, cascaded PROMs provide additional memory (Figure 5). Multiple XC18V00 devices can be concatenated by using the CEO output to drive the CE input of the downstream device. The clock inputs and the data outputs of all XC18V00 devices in the chain are interconnected. After the last data from the first PROM is read, the next clock signal to the PROM asserts its CEO output Low and drives its DATA line to a high-impedance state. The second PROM recognizes the Low level on its CE input and enables its DATA output. See Figure 7.

After configuration is complete, address counters of all cascaded PROMs are reset if the PROM OE/RESET pin goes Low or CE goes High.
Figure 5: Configuring Multiple Devices in Master/Slave Serial Mode

Figure 6: Configuring Multiple Virtex-II Devices with Identical Patterns in Master/Slave or Serial/SelectMAP Modes
Figure 7: (a) Master Serial Mode (b) Virtex/Virtex-E/Virtex-II Pro SelectMAP Mode (c) Spartan-II/Spartan-IIE Slave-Parallel Mode (dotted lines indicate optional connection)
Reset Activation

On power up, OE/RESET is held low until the XC18V00 is active (1 ms). OE/RESET is connected to an external resistor to pull OE/RESET HIGH releasing the FPGA INIT and allowing configuration to begin. If the power drops below 2.0V, the PROM resets. OE/RESET polarity is not programmable. See Figure 8 for power-up requirements.

Standby Mode

The PROM enters a low-power standby mode whenever CE is asserted High. The address is reset. The output remains in a high-impedance state regardless of the state of the OE input. JTAG pins TMS, TDI and TDO can be in a high-impedance state or High.

5V Tolerant I/Os

The I/Os on each re-programmable PROM are fully 5V tolerant even through the core power supply is 3.3V. This allows 5V CMOS signals to connect directly to the PROM inputs without damage. In addition, the 3.3V VCC power supply can be applied before or after 5V signals are applied to the I/Os. In mixed 5V/3.3V/2.5V systems, the user pins, the core power supply (VCC), and the output power supply (VCCO) can have power applied in any order. This makes the PROM devices immune to power supply sequencing issues.

Customer Control Bits

The XC18V00 PROMs have various control bits accessible by the customer. These can be set after the array has been programmed using “Skip User Array” in Xilinx iMPACT software. See Table 7.

![Figure 8: VCC Power-Up Requirements](image)

### Table 7: Truth Table for PROM Control Inputs

<table>
<thead>
<tr>
<th>Control Inputs</th>
<th>Internal Address</th>
<th>Outputs</th>
</tr>
</thead>
<tbody>
<tr>
<td>OE/RESET</td>
<td>CE</td>
<td>DATA</td>
</tr>
<tr>
<td>High</td>
<td>Low</td>
<td>If address ≤ TC(1): increment</td>
</tr>
<tr>
<td></td>
<td>Low</td>
<td>If address &gt; TC(1): don’t change</td>
</tr>
<tr>
<td>Low</td>
<td>Low</td>
<td>Held reset</td>
</tr>
<tr>
<td>High</td>
<td>High</td>
<td>Held reset</td>
</tr>
<tr>
<td>Low</td>
<td>High</td>
<td>Held reset</td>
</tr>
</tbody>
</table>

Notes:

1. TC = Terminal Count = highest address value. TC + 1 = address 0.
## Absolute Maximum Ratings\(^{(1,2)}\)

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Description</th>
<th>Value</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>(V_{CC})</td>
<td>Supply voltage relative to GND</td>
<td>–0.5 to +4.0</td>
<td>V</td>
</tr>
<tr>
<td>(V_{IN})</td>
<td>Input voltage with respect to GND</td>
<td>–0.5 to +5.5</td>
<td>V</td>
</tr>
<tr>
<td>(V_{TS})</td>
<td>Voltage applied to High-Z output</td>
<td>–0.5 to +5.5</td>
<td>V</td>
</tr>
<tr>
<td>(T_{STG})</td>
<td>Storage temperature (ambient)</td>
<td>–65 to +150</td>
<td>°C</td>
</tr>
<tr>
<td>(T_{SOL})</td>
<td>Maximum soldering temperature (10s @ 1/16 in.)</td>
<td>+260</td>
<td>°C</td>
</tr>
<tr>
<td>(T_{J})</td>
<td>Junction temperature</td>
<td>+150</td>
<td>°C</td>
</tr>
</tbody>
</table>

**Notes:**
1. Maximum DC undershoot below GND must be limited to either 0.5V or 10 mA, whichever is easier to achieve. During transitions, the device pins can undershoot to –2.0V or overshoot to +7.0V, provided this over- or undershoot lasts less than 10 ns and with the forcing current being limited to 200 mA.
2. Stresses beyond those listed under Absolute Maximum Ratings might cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those listed under Operating Conditions is not implied. Exposure to Absolute Maximum Ratings conditions for extended periods of time might affect device reliability.

## Recommended Operating Conditions

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>(V_{CCINT})</td>
<td>Internal voltage supply ((T_A = 0°C) to +70°C)</td>
<td>Commercial</td>
<td>3.0</td>
<td>3.6</td>
</tr>
<tr>
<td>(V_{CCO})</td>
<td>Supply voltage for output drivers for 3.3V operation</td>
<td>3.0</td>
<td>3.6</td>
<td>V</td>
</tr>
<tr>
<td>(V_{IL})</td>
<td>Low-level input voltage</td>
<td>0</td>
<td>0.8</td>
<td>V</td>
</tr>
<tr>
<td>(V_{IH})</td>
<td>High-level input voltage</td>
<td>2.0</td>
<td>5.5</td>
<td>V</td>
</tr>
<tr>
<td>(V_O)</td>
<td>Output voltage</td>
<td>0</td>
<td>(V_{CCO})</td>
<td>V</td>
</tr>
<tr>
<td>(T_{VCC})</td>
<td>(V_{CC}) rise time from 0V to nominal voltage(^{(1)})</td>
<td>1</td>
<td>50</td>
<td>ms</td>
</tr>
</tbody>
</table>

**Notes:**
1. At power up, the device requires the \(V_{CC}\) power supply to monotonically rise from 0V to nominal voltage within the specified \(V_{CC}\) rise time. If the power supply cannot meet this requirement, then the device might not perform power-on-reset properly. See Figure 8.

## Quality and Reliability Characteristics

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Description</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>(T_{DR})</td>
<td>Data retention</td>
<td>20</td>
<td>-</td>
<td>Years</td>
</tr>
<tr>
<td>(N_{PE})</td>
<td>Program/erase cycles (Endurance)</td>
<td>20,000</td>
<td>-</td>
<td>Cycles</td>
</tr>
<tr>
<td>(V_{ESD})</td>
<td>Electrostatic discharge (ESD)</td>
<td>2,000</td>
<td>-</td>
<td>Volts</td>
</tr>
</tbody>
</table>

## DC Characteristics Over Operating Conditions

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Test Conditions</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>(V_{OH})</td>
<td>High-level output voltage for 3.3V outputs (I_{OH} = –4) mA</td>
<td></td>
<td>2.4</td>
<td>-</td>
<td>V</td>
</tr>
<tr>
<td>(V_{OH})</td>
<td>High-level output voltage for 2.5V outputs (I_{OH} = –500) (\mu)A</td>
<td>90% (V_{CCO})</td>
<td>-</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>Symbol</td>
<td>Parameter</td>
<td>Test Conditions</td>
<td>Min</td>
<td>Max</td>
<td>Units</td>
</tr>
<tr>
<td>--------</td>
<td>-----------</td>
<td>----------------</td>
<td>-----</td>
<td>-----</td>
<td>-------</td>
</tr>
<tr>
<td>( V_{OL} )</td>
<td>Low-level output voltage for 3.3V outputs</td>
<td>( I_{OL} = 8 ) mA</td>
<td>-</td>
<td>0.4</td>
<td>V</td>
</tr>
<tr>
<td>( V_{OL} )</td>
<td>Low-level output voltage for 2.5V outputs</td>
<td>( I_{OL} = 500 ) µA</td>
<td>-</td>
<td>0.4</td>
<td>V</td>
</tr>
<tr>
<td>( I_{CC} )</td>
<td>Supply current, active mode</td>
<td>25 MHz</td>
<td>-</td>
<td>25</td>
<td>mA</td>
</tr>
<tr>
<td>( I_{CCS} )</td>
<td>Supply current, standby mode</td>
<td></td>
<td>-</td>
<td>10</td>
<td>mA</td>
</tr>
<tr>
<td>( I_{ILJ} )</td>
<td>JTAG pins TMS, TDI, and TDO</td>
<td>( V_{CC} = \text{MAX} ), ( V_{IN} = \text{GND} )</td>
<td>-100</td>
<td>-</td>
<td>µA</td>
</tr>
<tr>
<td>( I_{IL} )</td>
<td>Input leakage current</td>
<td>( V_{CC} = \text{Max} ), ( V_{IN} = \text{GND} ) or ( V_{CC} )</td>
<td>-10</td>
<td>10</td>
<td>µA</td>
</tr>
<tr>
<td>( I_{IH} )</td>
<td>Input and output High-Z leakage current</td>
<td>( V_{CC} = \text{Max} ), ( V_{IN} = \text{GND} ) or ( V_{CC} )</td>
<td>-10</td>
<td>10</td>
<td>µA</td>
</tr>
<tr>
<td>( C_{IN} ) and ( C_{OUT} )</td>
<td>Input and output capacitance</td>
<td>( V_{IN} = \text{GND} ), ( f = 1.0 ) MHz</td>
<td>-</td>
<td>10</td>
<td>pF</td>
</tr>
</tbody>
</table>
**AC Characteristics Over Operating Conditions**
for XC18V04 and XC18V02

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Description</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>$T_{OE}$</td>
<td>OE/RESET to data delay</td>
<td>-</td>
<td>10</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{CE}$</td>
<td>CE to data delay</td>
<td>-</td>
<td>20</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{CAC}$</td>
<td>CLK to data delay</td>
<td>-</td>
<td>20</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{OH}$</td>
<td>Data hold from CE, OE/RESET, or CLK</td>
<td>0</td>
<td>-</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{DF}$</td>
<td>CE or OE/RESET to data float delay (2)</td>
<td>-</td>
<td>25</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{CYC}$</td>
<td>Clock periods</td>
<td>50</td>
<td>-</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{LC}$</td>
<td>CLK Low time (3)</td>
<td>10</td>
<td>-</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{HC}$</td>
<td>CLK High time (3)</td>
<td>10</td>
<td>-</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{SCE}$</td>
<td>CE setup time to CLK (guarantees proper counting) (3)</td>
<td>25</td>
<td>-</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{HCE}$</td>
<td>CE High time (guarantees counters are reset)</td>
<td>20</td>
<td>-</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{HOE}$</td>
<td>OE/RESET hold time (guarantees counters are reset)</td>
<td>25</td>
<td>-</td>
<td>ns</td>
</tr>
</tbody>
</table>

**Notes:**
1. AC test load = 50 pF.
2. Float delays are measured with 5 pF AC loads. Transition is measured at ±200 mV from steady state active levels.
3. Guaranteed by design, not tested.
4. All AC parameters are measured with $V_{IL} = 0.0V$ and $V_{IH} = 3.0V$.
5. If $T_{HCE}$ High < 2 $\mu$s, $T_{CE} = 2$ $\mu$s.
6. If $T_{HCE}$ Low < 2 $\mu$s, $T_{OE} = 2$ $\mu$s.
AC Characteristics Over Operating Conditions for XC18V01, XC18V512, and XC18V256

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Description</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>$T_{OE}$</td>
<td>OE/RESET to data delay</td>
<td>-</td>
<td>10</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{CE}$</td>
<td>$\overline{CE}$ to data delay</td>
<td>-</td>
<td>15</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{CAC}$</td>
<td>CLK to data delay</td>
<td>-</td>
<td>15</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{OH}$</td>
<td>Data hold from $\overline{CE}$, OE/RESET, or CLK</td>
<td>0</td>
<td>-</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{DF}$</td>
<td>$\overline{CE}$ or OE/RESET to data float delay(2)</td>
<td>-</td>
<td>25</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{CYC}$</td>
<td>Clock periods</td>
<td>30</td>
<td>-</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{LC}$</td>
<td>CLK Low time(3)</td>
<td>10</td>
<td>-</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{HC}$</td>
<td>CLK High time(3)</td>
<td>10</td>
<td>-</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{SCE}$</td>
<td>$\overline{CE}$ setup time to CLK (guarantees proper counting)(3)</td>
<td>20</td>
<td>-</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{HCE}$</td>
<td>$\overline{CE}$ High time (guarantees counters are reset)</td>
<td>20</td>
<td>-</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{HOE}$</td>
<td>OE/RESET hold time (guarantees counters are reset)</td>
<td>20</td>
<td>-</td>
<td>ns</td>
</tr>
</tbody>
</table>

Notes:
1. AC test load = 50 pF.
2. Float delays are measured with 5 pF AC loads. Transition is measured at ±200 mV from steady state active levels.
3. Guaranteed by design, not tested.
4. All AC parameters are measured with $V_{IL} = 0.0V$ and $V_{IH} = 3.0V$.
5. If $T_{HCE}$ High < 2 µs, $T_{CE} = 2$ µs.
6. If $T_{HOE}$ High < 2 µs, $T_{OE} = 2$ µs.
### AC Characteristics Over Operating Conditions

**When Cascading for XC18V04 and XC18V02**

#### Symbol Description

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Description</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>$T_{CDF}$</td>
<td>CLK to data float delay$^{(2,3)}$</td>
<td>-</td>
<td>25</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{OKE}$</td>
<td>CLK to CEO delay$^{(3)}$</td>
<td>-</td>
<td>20</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{OCE}$</td>
<td>CE to CEO delay$^{(3)}$</td>
<td>-</td>
<td>20</td>
<td>ns</td>
</tr>
<tr>
<td>$T_{OEE}$</td>
<td>OE/RESET to CEO delay$^{(3)}$</td>
<td>-</td>
<td>20</td>
<td>ns</td>
</tr>
</tbody>
</table>

#### Notes:

1. AC test load = 50 pF.
2. Float delays are measured with 5 pF AC loads. Transition is measured at ±200 mV from steady state active levels.
3. Guaranteed by design, not tested.
4. All AC parameters are measured with $V_{IL} = 0.0V$ and $V_{IH} = 3.0V$. 

---

[Diagram showing the timing relationship between various signals like CLK, DATA, CE, and OE/RESET, with annotations for $T_{CDF}$, $T_{OKE}$, $T_{OCE}$, and $T_{OEE}$ delays.]
AC Characteristics Over Operating Conditions
When Cascading for XC18V01, XC18V512, and XC18V256

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Description</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>( T_{CDF} )</td>
<td>CLK to data float delay(^{(2,3)})</td>
<td>-</td>
<td>25</td>
<td>ns</td>
</tr>
<tr>
<td>( T_{OCK} )</td>
<td>CLK to ( \overline{CE} ) delay(^{(3)})</td>
<td>-</td>
<td>20</td>
<td>ns</td>
</tr>
<tr>
<td>( T_{OCE} )</td>
<td>CE to ( \overline{CEO} ) delay(^{(3)})</td>
<td>-</td>
<td>20</td>
<td>ns</td>
</tr>
<tr>
<td>( T_{OEE} )</td>
<td>OE/RESET to ( \overline{CEO} ) delay(^{(3)})</td>
<td>-</td>
<td>20</td>
<td>ns</td>
</tr>
</tbody>
</table>

Notes:
1. AC test load = 50 pF.
2. Float delays are measured with 5 pF AC loads. Transition is measured at ±200 mV from steady state active levels.
3. Guaranteed by design, not tested.
4. All AC parameters are measured with \( V_{IL} = 0.0V \) and \( V_{IH} = 3.0V \).
### Ordering Information

<table>
<thead>
<tr>
<th>Device Number</th>
<th>Package Type</th>
<th>Operating Range/Processing</th>
</tr>
</thead>
<tbody>
<tr>
<td>XC18V04VQ44C</td>
<td>VQ44 = 44-pin Plastic Quad Flat Package</td>
<td>C = Commercial (T_A = 0°C to +70°C)</td>
</tr>
<tr>
<td>XC18V04PC44C</td>
<td>PC44 = 44-pin Plastic Chip Carrier(1)</td>
<td>I = Industrial (T_A = −40°C to +85°C)</td>
</tr>
<tr>
<td>XC18V04VQ44I</td>
<td>VQ44 = 44-pin Plastic Quad Flat Package</td>
<td></td>
</tr>
<tr>
<td>XC18V04PC44I</td>
<td>PC44 = 44-pin Plastic Leaded Chip Carrier(2)</td>
<td></td>
</tr>
</tbody>
</table>

Notes:
1. XC18V04 and XC18V02 only.
2. XC18V01, XC18V512, and XC18V256 only.

### Valid Ordering Combinations

<table>
<thead>
<tr>
<th>Device Number</th>
<th>Package Type</th>
<th>Operating Range/Processing</th>
</tr>
</thead>
<tbody>
<tr>
<td>XC18V04VQ44C</td>
<td>VQ44 = 44-pin Plastic Quad Flat Package</td>
<td>C = Commercial (T_A = 0°C to +70°C)</td>
</tr>
<tr>
<td>XC18V04PC44C</td>
<td>PC44 = 44-pin Plastic Chip Carrier(1)</td>
<td>I = Industrial (T_A = −40°C to +85°C)</td>
</tr>
<tr>
<td>XC18V04VQ44I</td>
<td>VQ44 = 44-pin Plastic Quad Flat Package</td>
<td></td>
</tr>
<tr>
<td>XC18V04PC44I</td>
<td>PC44 = 44-pin Plastic Leaded Chip Carrier(2)</td>
<td></td>
</tr>
</tbody>
</table>

### Marking Information

#### 44-pin Package

<table>
<thead>
<tr>
<th>Device Number</th>
<th>Package Type</th>
<th>Operating Range/Processing</th>
</tr>
</thead>
<tbody>
<tr>
<td>XC18V04VQ44C</td>
<td>VQ44 = 44-pin Plastic Quad Flat Package</td>
<td>C = Commercial (T_A = 0°C to +70°C)</td>
</tr>
<tr>
<td>XC18V04PC44C</td>
<td>PC44 = 44-pin Plastic Chip Carrier(1)</td>
<td>I = Industrial (T_A = −40°C to +85°C)</td>
</tr>
<tr>
<td>XC18V04VQ44I</td>
<td>VQ44 = 44-pin Plastic Quad Flat Package</td>
<td></td>
</tr>
<tr>
<td>XC18V04PC44I</td>
<td>PC44 = 44-pin Plastic Leaded Chip Carrier(2)</td>
<td></td>
</tr>
</tbody>
</table>

Notes:
1. XC18V02 and XC18V04 Only.

#### 20-pin Package(1)

Due to the small size of the commercial serial PROM packages, the complete ordering part number cannot be marked on the package. The XC prefix is deleted and the package code is simplified. Device marking is as follows:

<table>
<thead>
<tr>
<th>Device Number</th>
<th>Package Type</th>
<th>Operating Range/Processing</th>
</tr>
</thead>
<tbody>
<tr>
<td>18V01SC</td>
<td>S = 20-pin Small-Outline Package</td>
<td>C = Commercial (T_A = 0°C to +70°C)</td>
</tr>
<tr>
<td>18V01SC</td>
<td>J = 20-pin Plastic Leaded Chip Carrier</td>
<td>I = Industrial (T_A = −40°C to +85°C)</td>
</tr>
</tbody>
</table>

Notes:
1. XC18V01, XC18V512, and XC18V256 only.
## Revision History

The following table shows the revision history for this document.

<table>
<thead>
<tr>
<th>Date</th>
<th>Version</th>
<th>Revision Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>2/9/99</td>
<td>1.0</td>
<td>First publication of this early access specification</td>
</tr>
<tr>
<td>8/23/99</td>
<td>1.1</td>
<td>Edited text, changed marking, added CF and parallel load</td>
</tr>
<tr>
<td>9/1/99</td>
<td>1.2</td>
<td>Corrected JTAG order, Security and Endurance data.</td>
</tr>
<tr>
<td>9/16/99</td>
<td>1.3</td>
<td>Corrected SelectMAP diagram, control inputs, reset polarity. Added JTAG and CF description, 256 Kbit and 128 Kbit devices.</td>
</tr>
<tr>
<td>01/20/00</td>
<td>2.0</td>
<td>Added Q44 Package, changed XC18xx to XC18Vxx</td>
</tr>
<tr>
<td>02/18/00</td>
<td>2.1</td>
<td>Updated JTAG configuration, AC and DC characteristics</td>
</tr>
<tr>
<td>04/04/00</td>
<td>2.2</td>
<td>Removed stand alone resistor on INIT pin in Figure 5. Added Virtex-E and EM parts to FPGA table.</td>
</tr>
<tr>
<td>06/29/00</td>
<td>2.3</td>
<td>Removed XC18V128 and updated format. Added AC characteristics for XC18V01, XC18V512, and XC18V256 densities.</td>
</tr>
<tr>
<td>11/13/00</td>
<td>2.4</td>
<td>Features: changed 264 MHz to 264 Mb/s at 33 MHz; AC Spec.: T_{SCE} units to ns, T_{HCE} CE High time units to µs. Removed Standby Mode statement: “The lower power standby modes available on some XC18V00 devices are set by the user in the programming software”. Changed 10,000 cycles endurance to 20,000 cycles.</td>
</tr>
<tr>
<td>01/15/01</td>
<td>2.5</td>
<td>Updated Figures 5 and 6, added 4.7 resistors. Identification registers: changes ISP PROM product ID from 06h to 26h.</td>
</tr>
<tr>
<td>04/04/01</td>
<td>2.6</td>
<td>Updated Figure 6, Virtex SelectMAP mode; added XC2V products to Compatible PROM table; changed Endurance from 10,000 cycles, 10 years to 20,000, 20 years;</td>
</tr>
<tr>
<td>04/30/01</td>
<td>2.7</td>
<td>Updated Figure 6: removed Virtex-E in Note 2, fixed SelectMAP mode connections. Under AC Characteristics Over Operating Conditions for XC18V04 and XC18V02, changed T_{SCE} from 25 ms to 25 ns.</td>
</tr>
<tr>
<td>06/11/01</td>
<td>2.8</td>
<td>AC Characteristics Over Operating Conditions for XC18V01, XC18V512, and XC18V256. Changed Min values for T_{SCE} from 20 ms to 20 ns and for T_{HCE} from 2 ms to 2 µs.</td>
</tr>
<tr>
<td>09/28/01</td>
<td>2.9</td>
<td>Changed the boundary scan order for the CEO pin in Table 1, updated the configuration bits values in the table under Xilinx FPGAs and Compatible PROMs, and added information to the Recommended Operating Conditions table.</td>
</tr>
<tr>
<td>11/12/01</td>
<td>3.0</td>
<td>Updated for Spartan-IIE FPGA family.</td>
</tr>
<tr>
<td>12/06/01</td>
<td>3.1</td>
<td>Changed Figure 7(c).</td>
</tr>
<tr>
<td>02/27/02</td>
<td>3.2</td>
<td>Updated Table 2 and Figure 6 for the Virtex-II Pro family of devices.</td>
</tr>
<tr>
<td>03/15/02</td>
<td>3.3</td>
<td>Updated Xilinx software and modified Figure 6 and Figure 7.</td>
</tr>
<tr>
<td>03/27/02</td>
<td>3.4</td>
<td>Made changes to pages 1-3, 5, 7-11, 13, 14, and 18. Added new Figure 8 and Figure 9.</td>
</tr>
<tr>
<td>06/14/02</td>
<td>3.5</td>
<td>Made additions and changes to Table 2.</td>
</tr>
<tr>
<td>07/24/02</td>
<td>3.6</td>
<td>Changed last bullet under Connecting Configuration PROMs, page 543.</td>
</tr>
<tr>
<td>09/06/02</td>
<td>3.7</td>
<td>Multiple minor changes throughout, plus the addition of Pinout Diagrams, page 538 and the deletion of Figure 9.</td>
</tr>
</tbody>
</table>
Glossary

AC Coupling
Method of interfacing drivers and receivers through a series capacitor. Often used when the differential swing between drivers and receivers is compatible, but common mode voltages of driver and receiver are not. Requires that a minimum data frequency be established based on the RC time constant, necessitating a run length limit.

Addressing Modes
Techniques used by software or hardware in calculating an address.

ALU (Arithmetic and Logic Unit)
The part of a processor that performs integer addition, subtraction, multiplication, division and other Boolean logic instructions.

AQL (Acceptable Quality Level)
The relative number of devices, expressed in parts-per-million (ppm), that might not meet specification or might be defective. Typical values are around 10 ppm.

ASIC (Application-Specific Integrated Circuit)
An integrated circuit designed to perform a particular function by defining the interconnection of a set of basic circuit building blocks drawn from a library provided by the circuit manufacturer.

Assembler
A software development tool that translates assembly language programs into machine instructions that the processor can decode and execute.

Assembly Language
A human-readable form of a processor's instruction set. Most processor-specific functions are written in assembly language.

Asynchronous
Logic that is not synchronized by a clock. Asynchronous designs can be faster than synchronous ones, but are more sensitive to parametric changes, and are thus less robust.
Glossary

ATM (Asynchronous Transfer Mode)

A very-high-speed (megahertz to gigahertz) connection-oriented bit-serial protocol for transmitting data and real-time voice and video in fixed-length packets (48-byte payload, 5-byte header).

Attenuation

Reduction in amplitude of a signal.

Back Annotation

Automatically attaching timing values to the entered design format after the design has been placed and routed in a field-programmable gate array (FPGA).

BER (Bit Error Rate)

A measurement of the number of errors detected at a receiver in a given length of time, sometimes specified as a percentage of received bits; sometimes specified in exponential form (10E-8 to indicate 1 bit error in 10E-8 bits).

BERT (Bit Error Rate Test, Bit Error Rate Tester)

A test or an instrument used to determine the Bit Error Rate (BER) of a device or system under test. It is generally made up of a test pattern generator, receiver, and analyzer.

Big Endian

A representation of a multi-byte value that has the most significant byte of any multi-byte data field stored at the lowest memory address. Also see Little Endian.

BIST (Built-In Self Test)

The technique of designing circuits with additional logic that can be used to test proper operation of the primary (functional) logic.

Bitstream

The bitstream is a binary representation of an implemented FPGA design. The bitstream is generated by Xilinx bit generation tools (BitGen and Makebits) and is denoted with the .bit extension. For information on creating BIT files, refer to the Hardware Debugger Reference/User Guide.

Block RAM

An 18 Kb block of random access memory (RAM) inside the Virtex-II Pro device. Dual-port and synchronous operation are desirable.

Block SelectRAM

Fully-synchronous, dual-port memories in the Virtex-II Pro FPGAs. Each of these memories contain 18 x 1024 (18,432) bits. The organization of each memory is configurable. Block SelectRAM resources complement smaller, distributed, LUT-based SelectRAM resources.

Book “E”

A Motorola and IBM jointly written architectural definition and instruction set for embedded PowerPC implementations.
Boot ROMs

The program used to bring up a computer or system that is stored in Read Only Memory.

Boundary Scan Interface

One of the configuration interfaces on the Virtex device. This is a bit-serial interface. The Boundary Scan interface is also known as the JTAG port. Also see SelectMAP Interface.

Breakpoint

A location in a program at which execution is to be stopped and control of the processor switched to the debugger. Mechanisms for creating and removing breakpoints are provided by most debugging tools.

BSP (Board Support Package)

The purpose of the BSP is to isolate the user design from hardware making it easier to write new applications and to port applications from other environments.

BSP consists of a set of software modules that offer interface to peripheral devices and low-level processor core functions for user software or C library. For example, these functions include hardware initialization, boot monitor access, drivers for all the available resources and features on board.

Cache

A small block of high-speed memory located between the processor and main memory. Cache stores frequently used data and instructions. Cache improves system performance by reducing the need to access the system's slower main memory.

Cache Block

See Cache Line.

Cache Line

A portion of a cache array that contains a copy of contiguous system-memory addresses. Cache lines in PPC405 are 32 bytes long and aligned on a 32 byte address.

Cache Set

See Congruence Class.

Capture Data

The flip-flop and pad data saved from the logic cells and I/O blocks into the bitstream for readback. Use the CAPTURE_VIRTEX primitive in your HDL code to specify the trigger and clock for the capture operation.

CCLK (Configuration Clock)

During configuration, the configuration clock (CCLK) is an output in Master modes or in the Asynchronous Peripheral mode but is an input in Slave, Synchronous Peripheral, Express, and SelectMAP/Slave Serial modes. After configuration, CCLK has a weak pull-up and can be selected as the readback clock.

CDR (Clock/Data Recovery)

Feature of most high-speed serial transcievers. At the receiver, a clock is generated based on the timing of data transitions. In this way, a clock signal is derived from the data.
Channel Bonding

Feature of multi-channel high-speed transceivers. Allows multiple channels to be used together, offering a greater aggregate bandwidth.

Chirp

Bit sequence which is transmitted by a high-speed transciever when it is not in use. The chirp is usually a repeating pattern of IDLE characters. The purpose of the chirp is to keep clock recovery circuits aligned and active while the link is not transmitting data.

CISC (Complex Instruction Set Computer)

The architecture of a processor family. CISC processors generally feature variable-length instructions, multiple addressing formats, and contain only a small number of general-purpose registers. Intel's 80x86 family is the quintessential example of CISC.

CLB (Configurable Logic Block)

Xilinx-specific name for a block of logic surrounded by routing resources. The functional elements for constructing logic circuits. The Virtex-II Pro CLB is made up of four slices, and each slice contains two Logic Cells.

CML (Current Mode Logic)

A differential I/O standard used in high-speed serial channels. Voltage swing is typically from 450 mV to 1200 mV.

Coherency

Coherency describes the ordering of reads from and writes to a single memory location. A memory system is coherent when the value read from a memory address is always the last value written to the address. In a system where all devices read and write from a single, shared system memory, memory is always coherent.

Comma

A comma is a “K” character used by the transceiver to align the serial data on a byte/half-word boundary (depending on the protocol used), so that the serial data is correctly decoded into parallel data.

Common Mode

The DC component of a signal. In differential channels, it is the average voltage of the differential pair.

Compiler

Software that converts a higher-language description into a lower-level representation. For FPGAs, the complete partition, place, and process.

Configuration Bitstream

Configuration commands with configuration data.

Configuration Commands

Instructions for the Virtex-II Pro device. There are two classes of Configuration Command — Major and Minor. The Major Commands read and write data to configuration registers.
in the Virtex-II Pro device. The Minor commands instruct the Virtex-II Pro configuration logic to perform specific functions.

**Configuration Data**

Bits that directly define the state of programmable logic. These are written to a Virtex-II Pro device in a configuration bitstream, and read as readback data from a Virtex-II Pro device.

**Configuration File**

The internally stored file that controls the FPGA so that it performs the desired logic function. Also, the act of loading an FPGA with that file. That is, the process of programming Xilinx SRAM-based FPGAs with a bitstream.

**Configuration Frame**

The configuration bits in a Virtex-II Pro device are organized in columns. A column of CLBs with the I/O blocks above and below the CLBs contain 48 frames of configuration bits. The smallest number of bits that can be read or written through the configuration interfaces is one frame.

**Configuration Interface**

A logical interface on the Virtex-II Pro device through which configuration commands and data can be read and written. A interface consists of one or more physical device pins.

**Configuration Readback**

The operation of reading configuration data (also known as readback data) from a Virtex-II Pro device.

**Congruence Class**

A collection of cache lines with the same index.

**Constraints**

Performance requirements imposed on the design, usually in the form of maximum allowable delay, or the required operating frequency.

**Context Switch**

The process of switching from one task to another in a multitasking operating system. A context switch involves saving the context of the running task and restoring the previously-saved context of the other.

**CoreConnect™ Bus Architecture**

An interconnection internal bus developed by IBM. It eases the integration and reuse of processor, system, and peripheral cores Elements of CoreConnect architecture include the processor local bus (PLB), the on-chip peripheral bus (OPB), a bus bridge, and a device control register (DCR) bus.

**Cross Compiler**

A compiler that runs on a particular processor architecture and produces code for a different architecture.
Crosstalk
Undesirable signal coupling from noisy aggressor nets to victim nets. May be eliminated by increasing the spacing between the nets or reducing signal amplitude of the aggressor net.

CS Pin
The CS pin is the Chip Enable pin for Virtex-II Pro devices. It is used only in SelectMAP mode. When CS is asserted (Low) the device examines data on the Data bus. When CS is de-asserted (High), all CCLK transitions are ignored.

DataFrame
A DataFrame is a block of configuration data. A configuration bit-stream contains many such frames, each with a start bit and stop bits. Also see Configuration Frame.

DC Balanced
A channel is said to be DC Balanced if it has an equal number of 1’s and 0’s transmitted across it. Encoding schemes like 8B10B are designed to ensure this.

DC Coupling
Method of interfacing drivers and receivers without the use of series capacitors. A direct connection (through PCB trace) from driver to receiver.

DCR (Device Control Register)
A CoreConnect bus. DCR is designed to transfer data between the CPU’s general purpose registers (GPRs) and the DCR slave logic’s device control registers (DCRs).

Debug Monitor
A piece of embedded software that has been designed specifically for use as a debugging tool. It usually resides in ROM and communicates with a debugger via a serial port or network connection. The debug monitor provides a set of primitive commands to view and modify memory locations and registers, create and remove breakpoints, and execute your program. The debugger combines these primitives to fulfill higher-level requests like program download and single-step.

Debugger
A software development tool used to test and debug embedded software. The debugger runs on a host computer and connects to the target through a serial port or network connection. Using a debugger you can download software to the target for immediate execution. You can also set breakpoints and examine the contents of specific memory locations and registers.

Deterministic Jitter
The component of jitter attributable to the data pattern in the channel. Different digital patterns have different spectral contents. These differing spectral contents give rise to varying amounts of signal jitter.

Device Pin
One of the electrical connections on the package containing the Virtex-II Pro device.
Dhrystone MIPS

Dhrystone is a benchmark program for testing a system’s integer performance. The objective is to compare the performance of a machine against the performance of a reference machine. The industry has adopted the VAX 11/780 as the reference 1 MIPS (Million Instruction Per Second) machine.

Differential Signaling

A signaling scheme which uses two complementary signals to transmit data. Differential signaling offers faster data rates at reduced signal swing with higher signal-to-noise ratio.

DIN Pin

During serial configuration, the DIN pin is the serial configuration data input receiving data on the rising edge of CCLK. During parallel configuration, DIN is the D0 input. After configuration, DIN is a user-programmable I/O pin.

Dirty Bit

A bit in a memory cache or virtual memory page that has been modified by the CPU but not yet written back to storage.

Dispersion

"Smearing" of a signal or waveform as a result of transmission through a non-ideal transmission line. Through a non-ideal medium, signals travel at different velocities according to their frequency. Dispersion of the signal is the result. All cables and PCB transmission lines are non-ideal.

DONE Pin

The DONE pin on a Xilinx FPGA is a bidirectional signal with an optional internal pull-up resistor. As an output, it indicates the completion of the configuration process. As an input, a low level on DONE can be configured to delay the global logic initialization and the enabling of outputs.

Double Word

Eight bytes or 64 bits.

DOUT Pin

During configuration in any mode except Express and SelectMAP, the DOUT pin is the serial configuration data output that can drive the DIN pin of daisy-chained slave FPGAs. DOUT data changes on the rising edge of CCLK, one-and-a-half CCLK periods after it is received at the DIN pin (in Master Serial Mode only).

DOUT/BUSY Pin

For Virtex-II Pro devices, the DOUT/BUSY pin has a dual purpose, depending on device mode. When the device is in Serial mode, this pin functions as DOUT. When the device is in SelectMAP/Slave Parallel mode, this pin functions as a handshaking signal. If BUSY is asserted (High) on a rising edge of CCLK, the data is not seen on the data bus, and should be held until the data is accepted.

DRAM (Dynamic Random Access Memory)

A low-cost read-write memory where data is stored on capacitors and must be refreshed periodically. DRAMs are usually addressed by a sequence of two addresses, row address,
and column address, which makes them slower and more difficult to use than SRAMs. Also see SRAM.

**DSL (Digital Subscriber Line)**

Sometimes referred to as a "last-mile technology" because it is used only for connections from a telephone switching station to a home or office, not between switching stations. DSL uses sophisticated modulation schemes to pack data onto POTS (ordinary analog telephone) wires. Downstream data rates of up to 32 Mb/s can be achieved. The physical distance between the subscriber and the switching station must be kept short, however, to attain the higher speeds.

**DSOCM (Data-Side On Chip Memory)**

See OCM (On-Chip Memory).

**DSP (Digital Signal Processing)**

The manipulation of analog data that has been sampled and converted into a digital representation. Examples are filtering, convolution, Fast-Fourier-Transform, and so on.

**EDIF (Electronic Data Interchange Format)**

Industry standard for specifying a logic design in text (ASCII) form.

**EEMBC (Embedded Microprocessor Benchmark Consortium)**

It develops and certifies real-world benchmarks and benchmark scores to help designers select embedded processors.

**Effective Address**

The un-translated memory address as seen by a program.

**Emulator**

Short for ICE (In-Circuit Emulator).

**Endianness**

See Big Endian and Little Endian.

**Equalization**

Amplification or attenuation of certain frequency components of a signal. Used to counteract the effects of a non-ideal transmission medium.

**ESD (Electrostatic Discharge)**

High-voltage discharge can rupture the input transistor gate oxide. ESD-protection diodes divert the current to the supply leads.

**Exception**

An abnormal event or condition that requires the processor’s attention. They can be caused by instruction execution or an external device. The processor records the occurrence of an exception and they often cause an interrupt to occur.
Eye Diagram

An eye diagram of a signal overlays the signal’s waveform over many cycles. Each cycle’s waveform is aligned to a common timing reference, typically a clock. An eye diagram provides a visual indication of the voltage and timing uncertainty associated with the signal. It can be generated by synchronizing an oscilloscope to a timing reference.

The vertical thickness of the line bunches in an eye diagram indicate the magnitude of AC voltage noise, whereas the horizontal thickness of the bunches where they cross over is an indication of the AC timing noise or jitter. Fixed DC voltage and timing offsets are indicated by the position of the eye on the screen.

Eye Mask

The size of the eye opening in the center of an eye diagram indicates the amount of voltage and timing margin available to sample this signal. Thus, for a particular electrical interface, a fixed reticule or window could be placed over the eye diagram showing how the actual signal compares to minimum criteria window, know as the eye mask. If a margin rectangle with width equal to the required timing margin and height equal to the required voltage margin fits into the opening, then the signal has adequate margins. Voltage margin can often be traded off for timing margin.

Fall Time

The time it takes for a waveform to transition from the high logic state to the low logic state. Fall time is usually measured from 90% of the total signal swing to 10% of the signal swing.

FIFO (First-In First-Out)

FIFO memory where data is stored in the incoming sequence and is read out in the same sequence. Input and output can be asynchronous to each other. A FIFO needs no external addresses, although all modern FIFOs are implemented internally with RAMs driven by circular read and write counters.

FIT (Failure In Time)

Describes the number of device failures statistically expected for a certain number of device-hours. Expressed as failures per one billion (10^9) device hours. Device temperature must be specified. Mean time between failure (MTBF) can be calculated from FIT. 10 FITs are good; 100 FITs are bad.

FIT (Fixed Interval Timer)

One of several user-accessible timers available in the Virtex-II Pro FPGA’s PowerPC 405 core. The FIT provides timer interrupts having a repeatable period. The FIT is functionally similar to an auto-reload Programmable Interval Timer (PIT), except that only a smaller fixed selection of interrupt periods is available.

Flash

Non-volatile programmable technology, and alternative to electrically-erasable programmable read-only memory (EEPROM) technology. The memory content can be erased by an electrical signal. This allows in-system programmability and eliminates the need for ultraviolet light and quartz windows in the package.
Flip-Flop

Single-bit storage cell that samples its data input at the active (rising or falling) clock edge, and then presents the new state on its Q output after that clock edge, holding it there until after the next active clock edge.

Flush

A cache or TLB operation that involves writing back a modified entry to memory, followed by an invalidation of the entry.

FPGA (Field Programmable Gate Array)

An integrated circuit that contains configurable (programmable) logic blocks and configurable interconnect between these blocks. Xilinx FPGAs are SRAM-based programmable logic devices (PLDs).

FPU (Floating Point Unit)

Floating-point operations include any operations that involve fractional numbers.

Frame

See Configuration Frame.

Function Generator

Also called a look-up table (LUT), with N inputs and one output. Can implement any logic function of its N inputs. N can be between 3 and 6; 4-input function generators are most popular.

Gate

Smallest logic element with several inputs and one output. The AND gate output is High when all inputs are High. The OR gate output is High when at least one input is High. The NAND gate output is Low when all inputs are High. A 2-input NAND gate is used as the measurement unit for gate array complexity.

Gate Array

An ASIC where transistors are predefined, and only the interconnect pattern is customized for the individual application.

GNU

A recursive acronym “GNU Not Unix” (pronounced “guh-NEW”). The Free Software Foundation’s GNU project was launched in 1984 to develop a complete Unix-like operating system that is freely distributed.

GUI (Graphical User Interface)

The way of representing the computer output on the screen as graphics, pictures, icons, and windows. Pioneered by Xerox and the Apple Macintosh, now universally adopted, e.g., by Windows95 and others.

Halfword

Two bytes, or 16 bits.
HardWire

Xilinx name for a low-cost derivative of an FPGA, where the configuration is fixed, but functionality and footprint are identical with the original FPGA-based design.

Harvard Architecture

Harvard architecture has separate data bus and an instruction bus. This allows instruction and data access in parallel making faster execution than a Von-Neuman architecture possible. PPC405 core is built on Harvard architecture.

HDC Pin

The High during configuration (HDC) pin is driven High until the I/Os become active in the Startup sequence. It is available as a control output indicating that configuration is not yet complete. After configuration, HDC is a user-programmable I/O pin.

HDL (Hardware Description Language)

A kind of language used for the conceptual design of integrated circuits. Examples are VHDL and Verilog.

Hierarchical Design

Design description in multiple layers, from the highest (overview) to the lowest (circuit details). An alternative is flat design, where everything is described at the same level of detail.

Hit

An indication that requested information exists in the accessed cache array, the associated fill buffer, or on the corresponding OCM interface.

HyperTransport™

A high-performance bus solution developed by Advanced Micro Devices and several partners to break the I/O bottleneck in 32- and 64-bit systems. HyperTransport provides a scalable architecture that provides better than an order of magnitude increase in bus transaction throughput over existing I/O bus architectures such as PCI, PCI-X and AGP. Formerly called Lightning Data Transport (LDT).

ICE (In-Circuit Emulator)

A debugging tool that takes the place of (emulates) the processor on the target board. Emulators frequently incorporate a special "bond-out" version of the target processor that allows the user to observe and record its internal state as the program is executing.

Idle Pattern

A data sequence transmitted by a high-speed transceiver as a placeholder or for link maintenance. The particular sequence of an IDLE pattern is determined by the communication protocol, and is usually a control character like K28.5.

Impedance (Characteristic Impedance)

Electrical characteristic of a transmission line, derived from the capacitance and inductance per unit length.
Index Register

A special purpose register used by a processor when performing indexed addressing. The value in the index register is usually the reference location to which a displacement will be added.

### INIT Pin

The INIT pin is a quadruple function signal. Before and during configuration, INIT is a bidirectional signal. A 1 - 10 kΩ external pull-up resistor is recommended. As an active-Low open-drain output, INIT is held Low during power stabilization and internal clearing of the configuration memory. As an active-Low input, it can be used to hold the FPGA in the internal WAIT state before the start of configuration. During configuration, a Low on this output indicates that a configuration data error has occurred. After the I/O become active in the Startup sequence, INIT becomes a user-programmable I/O.

### Instruction Set

Is referred to the set of instructions that the microprocessor can execute. The instruction set specifies the types of instructions (such as load/store, integer arithmetic, and branch instructions), the specific instructions, and the encoding used for the instructions. The instruction set definition also specifies the addressing modes used for accessing memory.

### Interrupt Latency

The amount of time between the assertion of an interrupt and the start of the associated interrupt service routine.

### Interrupt Service Routine

A section of code written to handle the tasks associated with an interrupt request.

### Interrupt Vector

A special code that identifies the circuit requesting an interrupt.

### IP (Intellectual Property)

In the legal sense, patents, copyrights, and trade secrets. In integrated circuits (ICs), predefined large functions, called “cores,” that help the user complete a large design faster.

### ISA (Instruction Set Architecture)

A term referring to a family of microprocessors with similar basic design, for example the PowerPC architecture includes Motorola´s PowerQUICC, PPC7440, 7410, IBM’s PPC 405, 440, and Xilinx Virtex-II Pro.

### ISI (Inter-Symbol Interference)

A form of data corruption or noise due to the effect that data has on data-dependent channel characteristics.

### ISOCM (Instruction-Side On Chip Memory)

See OCM (On-Chip Memory).
Jitter
The jitter of a periodic signal is the delay between the expected transition of the signal and the actual transition. Jitter is a zero mean random variable. When worst case analysis is undertaken the maximum value of this random variable is used.

Jitter Tolerance
Jitter tolerance is defined as the peak-to-peak amplitude of sinusoidal jitter applied on the input that causes a predefined, acceptable loss at the output. For example jitter applied to the input of an OC-N equipment interface that causes an equivalent 1dB optical power penalty.

Jitter Transfer
Jitter transfer is defined as the ratio of jitter on the output of a device to the jitter applied on the input of the device, versus frequency. Jitter transfer is important in applications where the system is utilized in a loop-timed mode, where the recovered clock is used as the source of the transmit clock.

JTAG (Joint Test Action Group)
Earlier name for IEEE 1149.1 boundary scan, a method for testing boards and integrated circuits. Also see Parallel Cable IV.

Kernel
An essential part of any multitasking operating system software which controls how the rest of the system can operate. The kernel is to software what the CPU is to hardware.

LAN (Local Area Network)
A computer network that spans a relatively small area. Most LANs are confined to a single building or group of buildings. However, one LAN can be connected to other LANs over any distance via telephone lines and radio waves. A system of LANs connected in this way is called a WAN (Wide Area Network).

Latency
The time between when something happens and when its response is generated. This is often critical in real-time applications.

LC (Logic Cell)
Metric for FPGA density. The basic building block of the Virtex-II Pro CLB. An LC includes a 4-input function generator, carry logic, and a storage element.

LDC Pin
Low during configuration (LDC) is driven Low until the I/Os become active in the Startup sequence. It is available as a control output indicating that configuration isn’t complete. After configuration, LDC is a user-programmable I/O pin.

LDT (Lightning Data Transport)
See HyperTransport™.
Linker
A software development tool that accepts one or more object files as input and outputs a relocatable program. The linker is thus run after all of the source files have been compiled or assembled.

Little Endian
A representation of a multi-byte value that has the least significant byte of any multi-byte data field stored at the lowest memory address. Also see BigEndian.

LogiBLOX
Library of logic modules, often with user-definable parameters, like data width. Similar to LPM.

Logical Address
Synonym for effective address.

Loopback
Path in a high-speed transceiver which connects the output to the input, on either the PMA or PCS side, for testing purposes.

LPM (Library of Parametrized Modules)
Library of logic modules, often with user-definable parameters, like data width. Similar to LogiBLOX.

LUT (Look-Up Table)
Also called a function generator with N inputs and one output. Can implement any logic function of its N inputs. N is between 3 and 6; most popular are 4-input LUTs.

LUT SelectRAM
Shallow RAM structure implemented in CLB look-up tables (LUTs). Also see Block SelectRAM.

LVDS (Low Voltage Differential Signaling)
A differential I/O standard commonly used for high-speed, low-swing signals.

Machine Language
A computer language that is directly executable by a computer without the need for translation by a compiler or an assembler. Although the computer works on binary patterns, the program can usually be entered in octal or hexadecimal.

MAN (Metropolitan Area Network)
A data network designed for a town or city. In terms of geographic breadth, a MAN is larger than a LAN (Local Area Network), but smaller than a WAN (Wide Area Network).

Mapping
Process of assigning portions of the logic design to the physical chip resources (CLBs). With FPGAs, mapping is more demanding and more important a process than with gate arrays. Also see Synthesis.
Masking
A process in which an operation can be performed on a single bit.

Memory Map
Documentation that lists or shows the function of each location in memory.

Memory-Mapped I/O
A system of I/O in which each I/O location is treated as if it were memory.

MicroBlaze
A 32-bit soft processor developed by Xilinx

Miss
An indication that requested information does not exist in the accessed cache array, the associated fill buffer, or on the corresponding OCM interface.

MMU (Memory Management Unit)
Performs address translation (logical to physical) and protection functions. The MMU divides logical storage into pages.

Mnemonic
A easy to remember string representing a processor instruction. For example, EIEIO is the mnemonic of the PPC405 instruction ‘Enforce In Order Execution of I/O’.

MTBF (Mean Time Between Failures)
The statistically relevant up-time between equipment failures. Also see FIT (Failure In Time).

Multilevel Signaling
System where multiple logic levels are utilized instead of just two (high and low). This enables the transmission of multiple bits in a single waveform.
See [http://www.signalintegrity.com/Pubs/misc/mls.htm](http://www.signalintegrity.com/Pubs/misc/mls.htm).

MultiLINX Cable
The MultiLINX cable provides many complex functions and can be loaded with new firmware as it becomes available. It can be connected to the host computer in two ways: via a Serial port or a USB port. The MultiLINX cable is supported by the Hardware Debugger software for Slave Serial and SelectMAP/Slave Parallel programming (as appropriate), as well as readback/verify. It is also supported by the iMPACT software for JTAG programming of both CPLDs and FPGAs.

Multiprocessing
The use of more than one processor in a single computer system. So-called "multiprocessor systems" usually have a common memory space through which the processors can communicate and share data. In addition, some multiprocessor systems support parallel processing.
Netlist

Textual description of logic and interconnects. Also see XNF File and EDIF (Electronic Data Interchange Format).

Non-maskable Interrupt (NMI)

An interrupt that cannot be turned off.

NRE (Non-Recurring Engineering) Charges

Start-up cost for the creation of an ASIC, gate array, or HardWire. Pays for layout, masks, and test development. FPGAs and CPLD do not require NRE.

Object Code

The form of software after it has been translated (compiled) from the source code format a programmer writes into the machine format a microprocessor can understand. A set of processor-readable opcodes and data. The output of compilers, assemblers, linkers, and locators are files containing object code.

OCM (On-Chip Memory)

Interface that supports the attachment of additional memory to the instruction and data caches, and that can be accessed at performance levels matching the cache arrays.

On-Chip Debugger

It can be considered as advanced on-chip debug monitor. It usually allows code download, memory/resource access, single stepping, reset, status, etc.

OPB (On-chip Peripheral Bus)

A CoreConnect bus. OPB is architected to alleviate system performance bottlenecks by reducing capacitive loading on the Processor Local Bus (PLB). OPB is designed to support lower-performance/speed peripherals such as IIC, UART, GPIO, USB, External Bus Controller, etc

Optimization

Design change to improve performance. Also see Synthesis.

Overshoot

Phenomenon where a signal rises to a level greater than its steady-state voltage before settling to its steady-state voltage.

Pad

Pad bits are extra bits used to make the total number of bits in a frame an integral multiple of 32, the number of bits in a configuration word. A pad word is an extra word used at the end of a configuration frame for pipelining. A pad frame is an extra configuration frame used at the beginning of a configuration readback and at the end of a configuration write for pipelining.

Parallel Cable IV

Xilinx Parallel Cable IV (PC IV) is a high-speed download cable that configures or programs all Xilinx FPGA, CPLD, ISP PROM, and System ACE MPM devices. The cable
takes advantage of the IEEE 1284 ECP protocol and Xilinx iMPACT software to increase
download speeds over eight times faster than existing solutions.

Partitioning
In FPGAs, the process of dividing the logic into subfunctions that can later be placed into
individual CLBs. Partitioning precedes placement.

PCMCIA
Personal Computer Memory Card Interface Association. Physical and electrical standard
for small plug-in boards for portable computers.

PCS (Physical Coding Sublayer)
Part of the physical layer of the ISO/OSI reference stack model for Gigabit Ethernet. The
PCS encodes 8-bit data octets into 10-bit code groups, which it passes down to the PMA
(Physical Media Attachment). In reverse direction, it also decodes 10-bit code groups
passed up from the PMA.

Peak-to-Peak
In the case of peak-to-peak voltage, a measure of a signal’s total amplitude. In the case of
peak-to-peak jitter, a measure of the extremes of excursion of the bit transition times.

PECL (Positive Emitter-Coupled Logic)
A differential I/O standard based on the ECL standard, but which operates with a positive
supply voltage. (ECL uses a negative supply voltage.) PECL is used in clocking and high-
speed data applications.

Peripheral Component Interface (PCI)
Synchronous bus standard characterized by short range, light loading, low cost, and high
performance. 66 MHz PCI can support data byte transfers up to 528 megabytes per second
(MB/s) on 64 parallel data lines.

Physical Address
The actual address that is placed on the address bus when accessing a physically
implemented memory location or register. This address can be translated from the effective
address. When address translation is not used, this address is equal to the effective
address.

Pin-Locking
Rigidly defining and maintaining the functionality and timing requirements of device pins
while the internal logic is still being designed or modified. Pin-locking has become
important, since circuit board fabrication times are longer than PLD design
implementation times.

PIP (Programmable Interconnect Point)
In Xilinx FPGAs, a point where two signal lines can be connected, as determined by the
device configuration.

Placement
In FPGAs, the process of assigning specific parts of the design to specific locations (CLBs)
on the chip. Usually done automatically. Also see Partitioning.
PLB (Processor Local Bus)
A CoreConnect bus. PLB interconnects high-bandwidth devices such as processor cores, external memory interfaces, PCI, and DMA controllers. PLB offers 64- and 128-bit implementations.

PLD (Programmable Logic Device)
Generic name for all programmable logic: PALs, CPLDs, and FPGAs.

PLL (Phase-Locked Loop)
An electronic circuit that controls an oscillator so that it maintains a constant phase angle relative to a reference signal.

PMA (Physical Media Attachment)
Part of the physical layer of the ISO/OSI reference stack model for Gigabit Ethernet. Serializes code-grouped data passed to it from the PCS (Physical Coding Sublayer), and deserializes data to be passed up to the PCS.

Polling
A process in which the status of devices attached to a bus system is periodically sampled.

PowerPC
A RISC-based computer architecture developed jointly by IBM, Apple Computer, and Motorola corporation. The name PowerPC is derived from IBM’s name for the POWER (Performance Optimization With Enhanced RISC) architecture.

PRBS (Pseudo-Random Bit Sequence)
A pattern that appears to be random, but is actually a predictable and repeatable sequence with a very long interval (i.e., billions of bits before repeating), depending on the pattern.

Preamble
The Preamble is a 4-bit binary sentinel (“0010”b) used to indicate the beginning of the LengthCount in the Header portion of the bitstream. At the beginning of configuration, FPGAs ignore all data prior to the preamble but counts the number of data bits preceding the preamble, and the LengthCount counter increments for every rising CCLK edge, even the ones proceeding the preamble.

Pre-emphasis
Pre-emphasis is magnitude boosting of high frequency spectral components before launching the signal (wave) onto the Transmission Line. Transmission Lines embedded in most standard PCB materials (FR4, Rogers 43xx, Nelco and Rogers) suffer varying degrees of dispersion and loss in the 1 gigahertz spectrum. This is mostly due to conductance losses (leakage from the copper trace to any other conducting structure) and Skin Effect. Dispersion is a phenomenon whereby spectral components travel at different velocities. The waveform looks smeared when it arrives at the receiver.
Both of these "characteristics" play into a diminished and poorly received signal. By boosting the high freq. spectral components, the magnitude of these components can be diminished as the wave travels through the Transmission Line, but since it starts out larger than the lower frequency components, the composite signal arrives at the receiver looking the way it was intended.
Pre-emphasis is done by simply increasing the maximum amplitude of the signal for one bit period. If the signal is 1 bit in duration, the amplitude is allowed to rise to a value which is some percentage greater in magnitude. At this point, if the signal is to stay at the same logic state, the driver sends a decreased magnitude signal, or nominal logic level. Every time a transition occurs, the greater magnitude level is used. For all times after this that the same level is to be transmitted, the nominal magnitude is used.

**Priority**

The level of importance of an event. Most often, interrupts are assigned priorities.

**Privileged (or Supervisor) Mode**

Privileged mode allows programs to access all registers and execute all instructions supported by the processor. Normally, the operating system and low-level device drivers operate in this mode.

**Program Counter**

A register that places addresses on the bus to retrieve information stored within a program.

**PROGRAM Pin**

The PROGRAM pin is an active-Low input that forces clearing of the FPGA configuration memory and is used to initiate a configuration cycle. While PROGRAM is held Low, the FPGA drives INIT Low and continues to clear the configuration memory. When PROGRAM goes High, the FPGA finishes the current clear cycle, executes another complete clear cycle, goes into a WAIT state, and releases INIT.

**Random Jitter**

Jitter caused by Power Supply noise, temperature variations and crosstalk.

**Readback**

Initiating a readback causes the configuration memory to become accessible to be serially clocked out and read from the device, or (byte-wide in SelectMAP/Slave Parallel modes). The configuration memory contains the configuration data, facilitating a Read-Verification of the data. The configuration memory can also contain the CLB output logic states facilitating a Read-Capture of the internal logic states. Read-Verification and Read-Capture are used by the Hardware Debugger for hardware verification. For information on the readback specification and timing, refer to The Programmable Logic Data Book. For information on using the readback component in a design, refer to the Libraries Guide. For information on enabling the readback function in the Implementation Software, refer to the Development System Reference Guide. For information on using the Hardware Debugger refer to the Hardware Debugger Reference/User Guide. For information on connecting the XChecker cable for readback, refer to the Hardware Users Guide.

**Readback Data**

Configuration data read from a Virtex-II Pro device. The data is organized as configuration frames.

**Real Address**

Synonym for physical address.

**Real Mode**

In real mode, programs address physical memory directly.
Register
A memory location that is part of a processor or an I/O device. In other words, it’s not normal memory. Generally, each bit or set of bits within the register controls some behavior of the larger device.

Relative Addressing
An addressing mode that calculates a new address based on the position of an instruction within a program.

Ringing
Common name for the characteristic waveform seen when a transmission line ends at a high impedance discontinuity. The signal first overshoots the target voltage, then sags below, then overshoots again—and continues this oscillating pattern with decreasing swing amplitude until finally settling at the target voltage.

RISC (Reduced Instruction Set Computer)
A type of microprocessor architecture that runs very fast by simplifying the number of its commands. PPC405 is a RISC microprocessor.

Rise Time
The time it takes for a signal to rise from 10% of its total logic swing to 90% of its total logic swing.

ROM Emulator
A debugging tool that takes the place of-or emulates-the ROM on the target board. A ROM emulator acts very much like a debug monitor, except that it includes its own serial or network connection to the host.

ROM Monitor
A piece of debugging code which usually communicates via a serial connection to a host computer or terminal. Also see Debug Monitor.

Routing
The interconnection or the process of creating the desired interconnection of logic cells to make them perform the desired function. Routing follows after partitioning and placement.

RTOS (Real Time Operating System)
Also called real-time multitasking kernel. Software which ensures that time critical events are processed simultaneously and efficiently within a predictable response time. In general, the use of an RTOS simplifies the design process of a system by allowing the application to be divided into multiple independent tasks.

SAN (Storage Area Network)
A high-speed subnetwork of shared storage devices. A storage device is a machine that contains nothing but a disk or disks for storing data. A SAN’s architecture works in a way that makes all storage devices available to all servers on a LAN (Local Area Network) or WAN (Wide Area Network).
Schematic

Graphic representation of a logic design in the form of interconnected gates, flip-flops, and larger blocks. Older and more visually intuitive alternative to the increasingly more popular equation-based or high-level language textual description of a logic design.

SelectMAP Interface

One of the configuration interfaces on the Virtex-II Pro device. This is a byte-serial interface. The pins in the SelectMAP interface can be used as user I/O after configuration has been completed or remain configured as a configuration interface.

SelectRAM

Xilinx-specific name for RAM implemented in CLBs.

SERDES (Serializer/Deserializer)

A common name for a high-speed transceiver that performs both parallel-to-serial and serial-to-parallel conversion.

Simulation

Computer modeling of logic and (sometimes) timing behavior of logic driven by simulation inputs (stimuli or vectors).

Single-Ended

Method of signaling which, unlike differential signaling, only transmits signals over one net.

Skin Effect Loss

Electrical loss in a non-ideal medium due to skin effect. Skin effect is the tendency for high-frequency signal components to travel close to the surface of the medium.

Slice

A subdivision of the Virtex-II Pro CLB. There are four vertical slices in each Virtex-II Pro CLB. Each slice contains two Logic Cells.

SNR (Signal-to-Noise Ratio)

A measure of signal strength relative to background noise. The ratio is usually measured in decibels (dB). If the incoming signal strength in microvolts is $V_S$, and the noise level, also in microvolts, is $V_N$, then the signal-to-noise ratio, SNR, in decibels, is given by the formula:

$$ SNR = 20 \log_{10} \left( \frac{V_S}{V_N} \right) $$

Soft IP

A synthesizable Intellectual Property which can be readily incorporated into an FPGA. Soft IP solves many of the time-to-market issues and also can simplify verification if a proper test bench is included.

Software Interrupt

An interruption of a program that is initiated by a software instruction. Software interrupts are commonly used to implement breakpoints and operating system entry points. Unlike true interrupts, they occur synchronously with respect to program execution.
SONET (Synchronous Optical NETwork)
A standard for connecting fiber-optic transmission systems. SONET was proposed by Bellcore in the mid-1980s and is now an ANSI standard.

SPECint95 and SPECfp95
Acronym for Standard Performance Evaluation Corporation, a nonprofit corporation set up by many computer and microprocessor vendors to create a standard set of benchmark tests. The most widely used set of tests, known as SPEC95, results in two sets of measurements, one for integer operations (SPECint95) and one for floating-point operations (SPECfp95). The SPEC95 benchmark tests are also called CPU95 tests.

SRAM
Static random access memory. Read-Write memory with data stored in latches. Faster than DRAM and with simpler timing requirements, but smaller in size and about four times more expensive than DRAM of the same capacity.

Stack
An area of memory used to implement a data structure that follows the last in, first out method of access. The stack is usually used by the processor to keep track of subroutine calls and returns.

Stack Pointer
A special purpose register that tracks the location of the last entry in the stack.

Static Timing
Detailed description of on-chip logic and interconnect delays.

Submicron
The smallest feature size is usually expressed in microns (\(\mu\) = one millionth of a meter, or a thousandth of a millimeter). The state of the art is moving from 0.35\(\mu\) to 0.25\(\mu\), and soon may reach 0.18\(\mu\). For comparison purposes, the wavelength of visible light is 0.4\(\mu\) to 0.8\(\mu\). One thousandth of an inch, or 1 mil, is 25.4\(\mu\).

Sync Word
A 32-bit word with a value that is used to synchronize the configuration logic.

Synchronous
Circuitry that changes state only in response to a common clock, as opposed to asynchronous circuitry that responds to a multitude of derived signals. Synchronous circuits are easier to design, debug, modify, and better tolerate parameter changes and speed upgrades than asynchronous circuits.

Synthesis
Optimization process of adapting a logic design to the logic resources available on the chip, like look-up tables, Longline, and dedicated carry. Synthesis precedes mapping.
TBUFs
Buffers with a 3-state option, where the output can be made inactive. Used for multiplexing different data sources onto a common bus. The pulldown-only option can use the bus as a “wired AND” function.

Termination
Usually implemented with passive components, termination is used to interface drivers, receivers, and traces that have differing impedance values. Typically, device drivers and receivers do not match the impedance of the PCB trace that connects them. Termination resistors are employed to match the impedances of these components, maximizing signal transmission and reducing noise.

Timing
Relating to delays, performance, or speed.

Timing Driven
A design or layout method that takes performance requirements into consideration.

TLB (Translation Lookaside Buffer)
TLB is part of an MMU. It has a table used in a virtual memory system keeping track of the physical address page number associated with each virtual address page number. A TLB is used in conjunction with a cache whose tags are based on virtual addresses.

Trace
A PPC405 feature which supports tracing of the instruction stream being executed out of the instruction cache in real time.

Trap
1. A program interrupt, usually an interrupt caused by some exceptional situation in the user program. In most cases, the OS performs some action, then returns control to the program.
2. Internally generated exceptions that deal with such instances as arithmetic overflow, divide by zero, and bound check failure.

UART (Universal Asynchronous Receiver/Transmitter)
An 8-bit parallel-to-serial and serial-to-parallel converter, combined with parity and start-detect circuitry, and sometimes even FIFO buffers. Used widely in asynchronous serial communications interfaces, such as modems.

UI (Unit Interval)
Unit of time corresponding to one bit period. A unit interval is the time it takes to send one bit.

USB (Universal Serial Bus)
A low-cost, low-speed, self-clocking bit-serial bus (1.5 MHz and 12 MHz) using four wires (V_{CC}, ground, differential data) to daisy-chain up to 128 devices.
User Mode
User mode restricts access to some registers and instructions. Normally, application programs operate in this mode.

Virtual Address
An intermediate address used to translate an effective address into a physical address. It consists of a process ID and the effective address. It is only used when address translation is enabled.

Virtual Mode
In virtual mode, programs address virtual memory and virtual-memory addresses are translated by the processor into physical-memory addresses. This allows programs to access much larger address spaces than might be implemented in the system.

VME
Older bus standard, popular with MC68000-based industrial computers.

Von-Neuman Architecture
Von-Neuman architecture has a shared bus for instruction and data access. Therefore simultaneous instruction and data transfer is not possible.

WAN (Wide Area Network)
A computer network that spans a relatively large geographical area. Typically, a WAN consists of two or more local-area networks (LANs).

Watchdog Timer
A hardware timer that is periodically reset by software. If the software crashes or hangs, the watchdog timer will expire, and the entire system will be reset automatically.

WDM (Wavelength Division Multiplexing)
A type of multiplexing developed for use on optical fiber. WDM modulates each of several data streams onto a different part of the light spectrum.

Word
Four bytes, or 32 bits.

Write Back
A Cache write policy in which data written into the cache by the CPU is not written into main memory until that data line in the cache is to be replaced.

WRITE Pin
The WRITE pin is an input to Virtex-II Pro devices in the SelectMAP/Slave Parallel mode, indicating to the device which direction data is flowing on the Data bus. When WRITE is asserted (Low), data is entering the device (configuration). When WRITE is de-asserted (High), data is leaving the device (readback). If WRITE changes state when the device isn’t expecting it, an abort occurs. For more information on the WRITE pin, refer to The Programmable Logic Data Book, and in this Handbook, Design Considerations, page 159.
Write Through

A Cache write policy. A technique for writing data from the CPU simultaneously into the cache and into main memory to assure coherency

XChecker Cable

The Xilinx XChecker Cable (model DLC4) is a serial download cable. The XChecker uses a serial 9-pin interface to the communication port of a host computer and two 8-pin headers for flying-wire connectors to a target board. The XChecker cable is supported by the Hardware Debugger software for performing Slave Serial configuration and readback of FPGAs. The XChecker cable is also supported by the iMPACT software for performing Slave Serial and Boundary Scan configuration of FPGAs, and Boundary Scan programming of CPLDs. For more information on using the XChecker cable refer to the Hardware Users Guide and the Hardware Debugger Reference/Users Guide.

XNF File

Xilinx-proprietary description format for a logic design. Alternative is EDIF.
Index

Numerics
3-state buffers, 57
3-state driver (TBUF), 57
3-state output buffer, 269
8B/10B decoder, 30
8B/10B encoder, 29

A
AC characteristics, 73
AC coupling
defined, 557
of transmitter/receiver, 75
address mapping, 209
addressing modes, 33
defined, 557
addressing scheme, 209
ALU, 37
defined, 557
arithmetic logic, 55
ASIC
defined, 557
Virtex-II Pro compared with, 11-15, 498
aspect ratios, 60
asynchronous
defined, 557
clocks, 64
interrupt inputs, 38
reads in SelectRAM, 52
set/reset in register or latch, 41, 51
ATM
defined, 558
IP core for, 24, 341, 344
available products
Virtex-II Pro, 19
XC1700D, 554

B
ball grid array (BGA), 24
BER, 344
defined, 558
receiver switching, 86
BGN files, 521
bidirectional LVDS, 328
bidirectional signals, 270
big endian, 39
defined, 558
instruction cache, 39
BIT files
description, 520
disabling, 525
loading downward, 527
loading up or down, 528
loading upward, 529
bit swapping
description, 527
disabling, 527
BitGen
-b option, 521
-d option, 521
description, 519
disabling DRC, 521
DRC file, 521
encryption options, 334
-g option, 521-524
-h option, 525
input files, 520
-j option, 525
-l option, 525
-m option, 525
options, 521
output files, 520
PCF files, 520
persistance switch, 405
readback option, 405
standard bitstream, 401
syntax, 520
-w option, 525
bitstream
defined, 558
configuration, 401
data frames, 402
encryption, 71, 332-336
loading encrypted, 335
standard, 401
block SelectRAM, 22, 58, 201-218
defined, 558
swiching characteristics, 103
timing model, 131
timing parameters, 131
total available, 61
board routability, 506
board support package SeeBSP, 559
boundary scan
instruction set, 379
mode, 69, 354
models, 517
Boundary Scan Description Language (BSDL), 517
boundary scan interface
defined, 559
and readback, 404
BSLD files, 517
BSP, 343
defined, 559
buffers, 62
3-state, 57
3-state output, 269
bidirectional LVDS, 328
global clock, 161
LDT, 329
output, 267
SelectI/O-Ultra, 46
BUFG, 64
BUFGCE, 64, 173
BUFGMUX, 64

C
cache
defined, 559
and MMU, 37
controllers and PLB, 34
data
write-through register, 37
data (PPC405 core), 20, 21, 36
instruction
and debug logic, 39
big endian, 39
instruction (PPC405 core), 20, 21, 36
cache line, 22
defined, 559
cache pollution and OCM, 33
capacitors
decoupling, 501
carry
chains, 54, 68
in one CLB, 57
logic, 54
multiplexer (MUXCY), 54
cascadable shift registers, 228
CCLK, 68, 353
defined, 559
and configuration, 359
and configuration mode, 354
and master serial programming mode, 368
timing, 104, 356
CDR, 12, 19, 21, 29
defined, 559
channel bonding, 31
defined, 559
characteristic impedance
See impedance
characteristics
AC, 73
DC, 73
electrical, 73
IOB input switching, 90
IOB output adjustments, 94
IOB output switching, 94
land pads, 507
performance, 81

Index
PPC405 switching, 83
RocketI/O switching, 86
switching, 83
checksum, 527
ChipScope Pro, 408
and CoreConnect, 408
classification and export
considerations, 333
CLB, 22, 49
defined, 560
switching characteristics, 99
distributed RAM, 100
clearing configuration memory, 356
CLK, 192
CLK2X, 187
CLKDV, 188
CLKFB, 183
CLKIN, 183
clock enable signal (CE), 51
clock nets, 68
clock networks, 160-179
clocks, 67, 160
buffer input, 163
de-skewing, 65, 180
distribution, 63, 160
forwarding, 318
frequency ranges, 67
frequency synthesis, 65
global buffers, 64, 161
global multiplexer buffer, 62
global networks, 160
multiplexer waveform, 64, 172, 173
multiplexers, 160
phase shifting, 66, 190
resources, 161
skew, 66
coherency, 37
defined, 560
combinatorial logic functions, 56
coma
defined, 560
detection, 19, 21, 30
command register (CMD), 396
commands
file, executing, 528
compiler
defined, 560
memory, 225
configuration, 23, 68, 353
bitstream, 394
defined, 560
bitstream header, 401
block SelectRAM, 58
Boundary Scan mode, 354
clearing memory, 356
data frames, 395
data processing flow, 399
distributed SelectRAM, 51
dual-port, 52
-g option, 521-524
internal processing, 394
JTAG, 504
logic, 394
Master SelectMAP mode, 354
Master Serial mode, 354
mode, 69
mode pins, 353
modes, 69, 353, 354
multipliers, 61
of latches, 41
of registers, 41
option register (COR), 396
pin settings, 69
process, 355
register writes, 400
Selectl/O-Ultra, 42
sequence, 70
single-port, 52
Slave SelectMAP mode, 354
Slave Serial mode, 354
configuration registers, 395
CMD, 396
COR, 396
CRC, 397
CTL, 397
FAR, 397
FDRI, 397
FDRO, 397
FLR, 396
LOUT, 397
MASK, 397
STAT, 398
writes, 400
conflict resolution, 205
constraining placement, 233
content-addressable memory
(CAM), 227
control pins, 61
control register (CTL), 397
control signals, 180
controlled impedance, 46
controlled output impedance, 46
conventions
typographical, 8
CORE Generator system, 336-351
CoreConnect™ bus architecture, 35
defined, 561
and ChipScope Pro, 408
CPM
interface, 34
CRC, 28, 32
16-bit polynomial, 403
and transmit latency, 87
register, 397
sequence, 402
cross talk, 504
defined, 562
CS pin, 524
defined, 562
cyclic redundancy check
See CRC

D
data cache write-through register, 37
Data Encryption Standard (DES), 70, 332
data frames, 402
data sheets
Virtex-II Pro, 19
XC18V00 Series PROMs, 531
DC characteristics, 73, 75
DC coupling
defined, 562
of transmitter/receiver, 75
DC input and output levels, 78
DCI, 46, 294-309
I/O buffer library, 300
I/O standards, 47, 48, 49
software support, 300
DCM, 20, 23, 65, 180, 180-201
clock de-skew, 180, 181
clock enable signal, 180
control signals, 180
frequency ranges, 67
frequency synthesis, 65, 180, 186
legacy support, 184
location, 67
miscellaneous timing parameters, 156
operating frequency ranges, 153
overview, 180
phase shifting, 66, 180, 190
port signals, 183
timing model, 152
timing parameters, 111
waveforms, 199
DCR
defined, 562
and processor block timing model, 157
bus interface, 34
DDR I/O, 40, 310-323
input, 310
output, 312
output with 3-state control, 314
SDRAM, 318
debug
interface, 35
debug logic, 38
debugger
defined, 562
hardware, 525
JTAG interface extensions, 35
debugging, 23, 70
using ChipScope Pro, 408
decoupling capacitors, 501
decryptor, 70
dedicated AND (MULT_AND), 55
dedicated OR gate (ORCY), 56
dedicated pins, 353
diagrams, 437, 450, 465, 471, 479, 485
delays, 90
input, 90
IOB, 81
output, 94
DES, 70, 333
deserializer, 30
des-kew, 65
des-kew circuit, 182
DESYNCH command, 403
deterministic jitter
defined, 86
device control register
See DCR
device/package combinations, 24
differential signaling, 329
defined, 563
Digital Clock Manager
See DCM
Digitally Controlled Impedance
See DCI
DIN pin
defined, 563
direct connect lines, 68
disparity control, 29
distributed SelectRAM, 51, 218-227
DLLs
characteristics, 182
source clock input, 183
DONE pin
defined, 563
double data rate I/O
See DDR I/O
DOUT pin
defined, 563
DOUT/BUSY pin
defined, 563
DRC
disabling for BitGen, 521
DRC file, 521
DSOCM
defined, 564
See OCM: data side
DSP, 14, 20, 22, 34, 62, 341, 342, 347
defined, 564
dual-port RAM, 51, 59
dynamic read operations, 229

EDIF, 211, 212, 223, 225, 232, 318, 338, 340
defined, 564
effective address, 37
defined, 564
EIC
interface, 34
electrical characteristics, 73
electrostatic discharge
See ESD
embedded multipliers, 254
timing model, 134
timing parameters, 134
encryption, 71
BitGen options, 334

bitstream, 332-336
endianness
See big endian and little endian
ESD, 43
defined, 564
export considerations, 333

F

call time
defined, 565
REFCLK, 86
fast slew rate, 94, 107
FDDRCPE, 317
FDDRRSE, 317
FF1152
bank information diagram, 452, 462
composite pinout diagram, 449, 461
dedicated pins diagram, 450, 465
flip-chip fine-pitch BGA
package, 492, 493, 495, 496
FF1517
bank information diagram, 468, 476, 482
composite pinout diagram, 467, 475, 477, 481
dedicated pins diagram, 471, 479, 485
flip-chip fine-pitch BGA
package, 494
FF672
bank information diagram, 436
composite pinout diagram, 435
dedicated pins diagram, 437
fine-pitch BGA package, 490
FF896
composite pinout diagram, 443
fine-pitch BGA package, 491
FG256
fine-pitch BGA package, 488
pinouts, 413
FG456
bank information diagram, 430
fine-pitch BGA package, 489
FIFO, 32, 341
defined, 565
application notes, 212
generating async, 201
in block RAM, 82
in SRL, 82
sync and async using CORE
Generator, 218
transmit, 29
fine phase adjustment, 66, 190
flip-chip advantages, 497
flip-chip packages, 24, 497
flip-flop, 22, 40, 43, 51
flip-flops
in one CLB, 57

frame address register (FAR), 397
Frame Data Register Input (FDRI), 397
Frame Data Register Output
(FDRO), 397
frame length register (FLR), 396
frequency ranges, 67
frequency synthesis, 65, 180
fully synchronous shift registers, 234
function generators, 54

global clock buffers, 64, 161
global clock multiplexer buffer, 62
global clock nets, 68, 160
global clocks, 23
input to output delay, 107
input to output timing
parameters, 150
setup and hold, 109
setup and hold timing
parameters, 151
global routing matrix, 23
global routing resources, 67
GTL, 279
GTL+, 280

Hardware Debugger, 525
Harvard architecture, 20, 36
defined, 567
HDC pin
defined, 567
hierarchical routing resources, 67
horizontal routing, 68
HSTL_I, 281, 285
HSTL_II, 282, 286
HSTL_III, 283, 287
HSTL_IV, 284, 288
HSWAP_EN pin, 43, 68
HyperTransport™
defined, 567
See LDT

I/O banks, 43, 44, 409
I/O Buffer Information Specification
See IBIS
I/O standards
DCI, 47, 48, 49
differential signaling, 22
single-ended, 22, 262
supported, 39
I/Os
user, 24
IBIS, 512, 513
advantages, 513
file structure, 513
generation, 513
I/V and dV/dt curves, 514
ramp keyword, 514
simulations, 515
simulators, 516
IEEE 1149.1, 517
IEEE 1149.1 - 1993, 23
IEEE 1532, 23, 69, 406, 517
impedance, 46
defined, 567
controlled, 46
receiver termination, 30
INIT pin
defined, 568
input clock tolerances, 112
input DDR, 310
input delays, 90
input files
BitGen, 520
PROMGen, 526
Instruction Set, 21, 33
instruction set, 36, 37
defined, 568
boundary scan, 379
interrupts
asynchronous, 38
IOBs, 22, 39
3-state timing parameters, 145
delays, 81
input switching characteristics, 90
input timing parameters, 138
output switching characteristics, 94
output timing parameters, 142
timing model, 137
IOBUF, 270
IOSTANDARD attribute, 302
ISOCM
defined, 568
See OCM: instruction side

J
jitter, 113
defined, 569
deterministic
receive, 86
serial data out, 87
random
defined, 575
serial data out, 87
JTAG, 504
defined, 569
instruction, 70
mode, 69
test access port, 106
junction temperature
specifications, 73

K
keys, 335
creating, 333
extended DC specifications, 79
primitives, 324
receiver termination, 325
transmitter termination, 326
LVPECL, 330-332
primitives, 330
receiver termination, 331
transmitter termination, 332

M
mask file, 525
MASK register (MASK), 397
Master SelectMAP mode, 354
Master Serial mode, 69, 354
memory
clearing, 356
memory compiler program, 225
memory management unit
See MMU
MGT (multi-gigabit transceiver)
See RocketIO transceiver
MicroBlaze™, 348, 349, 350
defined, 571
MMU, 37-38
defined, 571
mode pins, 68
modes
boundary scan, 69
configuration, 354
master SelectMAP, 354
master serial, 69, 354, 369
slave SelectMAP, 354
slave serial, 69, 354, 369
JTAG, 69
NO_CHANGE, 204
operating, 67
programming
See modes: configuration
READ_FIRST, 203
WRITE_FIRST, 203
MSK files, 521
MULT_ANDs
in one CLB, 57
MultiLINX cable
defined, 571
Multiplexers, 237-247
multiplexers, 54, 237
clocks, 160
large, 237
primary/secondary global, 164
wide-input, 242
multipliers, 61
blocks, 62
configuration, 61
embedded, 254
location, 61
swinging characteristics, 101
Multipliers, embedded, 254-261

N
National Institute of Standards and Technology (NIST), 332
NO_CHANGE mode, 204
NO_CHANGE option, 61

O
OBUF, 267
OBUFT, 269
OCM, 33
defined, 572
and processor block timing model, 157
cache pollution reduction, 33
data side, 34
instruction side, 34
interfaces, 34
thrashing reduction, 33
See also
PowerPC 405 processor block
on-chip buses, 57
on-chip decryptor, 70
on-chip memory
See OCM
on-chip peripheral bus
See OPB
on-chip termination, 46
OPB
defined, 572
and MicroBlaze™, 348
IP cores for, 343
IP for, 350
operating conditions
recommended, 74
operating frequency ranges, 153
operating modes, 67
optimization
defined, 572
ORCY, 56
ordering information, 25
XC1700D, 554
output buffer (OBUF), 267
output clock
jitter, 113
phase alignment, 113
output DDR, 312
with 3-state control, 314
output delays, 94
output drive strength, 273
output files
BitGen, 520
name, PROMGen, 528
overwriting, 525
PROMGen, 526
output power/ground pairs, 275
overshoot
defined, 572
overview of user guide, 7
dual-function, 354
HDC
defined, 567
HSWEP_EN, 43, 68
INIT
defined, 568
LDC
defined, 569
mode, 68
power, 356
PROGRAM
defined, 575
types, 411
VBATT, 70
WRITE
defined, 580
pin-to-pin input parameters, 109
pin-to-pin output parameters, 107
pin-to-pin timing model, 149
place-and-route software, 67
placement
constraints, 233
defined, 573
PLB
defined, 574
interfaces, 34
port addressing scheme, 209
port aspect ratios, 60
port signals, 183
power analysis software, 512
power consumption, 63
power pins, 356
power supply requirements, 77
power-on ramp rate, 77
PowerPC 405 processor block, 21
cache
data, 20, 21, 36
instruction, 20, 21, 36
debug resources, 22
features summary, 20
MMU (Memory Management Unit), 22
OCM (On-Chip Memory), 22
overview, 33
PPC405 CPU, 21
storage control, 21
switching characteristics, 83	
			
timers, 22
timing model, 157
pre-emphasis, 19, 21
defined, 574
primitives
LVDS, 324, 330
PRM files, 526
PROGRAM pin
defined, 575
PROMGen
-b option, 527
-c option, 527
-d option, 527
description, 525, 526
eamples, 529
flow diagram, 525
-help option, 528
input files, 526
-l option, 528
-n option, 528
-o option, 528
options, 527
output file name, 528
output files, 526
-p option, 528
-r option, 529
-s option, 529
supported families, 525
-u option, 529
-x option, 529
PROMs
bit swapping, 527
data sheet, 531
files, description, 526
formats, 528
loading files, 529
multiple files, 529
package specifications, 531
sizes, 529

R
RAM
dual-port, 51
single-port, 51
rawbits file, 521
RBT files, 520, 521
read operations, 60
dynamic, 229
static, 229
READ_FIRST mode, 203
READ_FIRST option, 60
readback, 23, 70, 404
defined, 575
capture, 404
enabling in software, 405
IEEE 1532 flow, 406
regular flow, 405
verification, 404
with Boundary Scan, 405
recommended operating conditions, 74
reconfiguration
partial, 71
REFCLK timing (waveform), 86
reference clock timing
See REFCLK timing register
defined, 576
set/reset, 51
registers
configuration, 41, 395
DDR, 40
shift, 53
reset
interface, 35
revision history
data sheet, 25, 71, 117
ranging
defined, 576
on PC board signals, 503
rise time
defined, 576
REFCLK, 86
RocketIO transceiver
block diagram, 28
CDR (clock/data recovery), 29
channel bonding, 31
clock correction, 31
clock synthesizer, 29
configuration, 32
crc, 32
features summary, 19, 21
functional description, 27-32
loopback, 30
defined, 570
number of per FPGA, 19
power sequencing, 32
receiver, 30
receiver buffer, 30
reset, 32
switching characteristics, 86
timing model, 157
transmitter, 29
transmitter buffer, 32
routability guidelines, 506
routing, 67
defined, 576
challenges, 506
matrix, 23
resources, 67
strategy, 507
RST, 183

dsegmented routing, 67
SelectI/O-Ultra
buffers, 46
configuration, 42
SelectI/O-Ultra
single-ended resources, 261-293
SelectI/O-Ultra technology, 20
SelectMAP
See configuration modes
SelectRAM, 20
block, 58
distributed, 51
in one CLB, 57
reads and writes in, 52
total available, 61
SERDES, 19, 21
defined, 577
serial transceiver
See RocketIO transceiver

S
serializer, 29
series termination, 504
set/reset
asynchronous, in register or latch, 41
in register or latch, 51
synchronous, in register or latch, 41
set/reset (SR), 51
shift registers, 53
cascading, 228
cascading, 53
fully synchronous, 234
in one CLB, 57
operation, 228
static length, 235
signals
bidirectional, 270
simulation, 14, 83, 98, 199, 207
defined, 577
simultaneous switching output (SSO), 274
single event upset (SEU), 43
single-ended
defined, 577
1/O standards, 22, 262
SelectI/O-Ultra resources, 261-293
single-port RAM, 51
Slave SelectMAP mode, 354
Slave Serial mode, 69, 354
slew rate, 272
slices, 247
defined, 577
description, 49
in one CLB, 57
SO20 specification, 533
software
place-and-route, 67
solder balls, 506
SOP chains, 56, 68
in one CLB, 57
specifications
PC20-84, 532
PROM packages, 531
SO20, 533
VQ44, 534
SR16, 228
SRL16, 228
SRLC16, 228
SSTL2, 289
SSTL2-L, 289
SSTL2_TIER, 290, 291
standard adjustments, 92, 94
standard bitstream, 401
standards
supported I/O, 39
start-up sequence, 403
STARTUP_WAIT attribute, 183
static length shift registers, 235
static read operations, 229
status register (STAT), 398
Sum of Products (SOP), 56, 247-254
summary of Virtex-II Pro features, 19
supply voltage specifications, 73
switching characteristics, 83
synchronous
  defined, 578
set/reset in register or latch, 41, 51
synchronous DRAM, 318

T

TBUF
  switching characteristics, 103
TBUFs
  defined, 579
  in one CLB, 57
termination
  defined, 579
  parallel, 503
  series, 504
  techniques, 274
terminations
  on-chip, 46
  parallel, 46
Test Access Port (TAP), 23
thermal considerations, 498
thermal management, 499
thrashing
  and OCM, 33
Timing Analyzer, 83, 121
timing models, 121
  block SelectRAM, 131
  DCM, 152
  embedded multiplier, 134
  IOB, 137
  pin-to-pin, 149
  PPC405, 157
  RocketIO MGT, 157
timing parameters, 111
  block SelectRAM, 131
  embedded multiplier, 134
general slice, 123
global clock input to output, 150
global clock setup and hold, 151
IOB 3-state, 145
IOB input, 138
IOB output, 142
miscellaneous, 114
miscellaneous DCM, 156
slice distributed RAM, 126
slice SRL, 129
TMULT, 134
transceiver
  See RocketIO transceiver
transmission line effects, 273, 502
TRCE, 121
Triple Data Encryption Algorithm (TDEA), 333
Triple DES, 333
typographical conventions, 8

U

user I/Os, 24

V

VBATT, 336
VBATT pin, 70
VCC decoupling, 500
VCCO, 43, 273
verification
  using ChipScope Pro, 408
vertical routing, 68
VHDL and Verilog templates, 175, 196, 212, 221, 225, 236, 244, 250, 260, 318
Virtex-II Pro
  and Virtex-II compared, 27
  architectural overview, 21
  available products, 19
  compared with ASIC, 11-15, 498
Data Sheet
  DC and switching characteristics, 73-118
  functional description, 27-71
  introduction and overview, 19-25
DCI, 46, 294-309
DES, 332
device/package combinations, 24
features summary, 19
I/O banks, 44
IP core support, 24
LUTs, 227
maximum number of I/Os, 24
multiplexers, 237
ordering information, 25
package specifications, 487
pinout information, 25
pinouts, 409
platform FPGA technology, 20
slices, 247
VQ44 specification, 534
VREF, 43, 273
VRN, 46
VRP, 46

W

weak-keeper circuits, 42
wide logic functions, 54
wide-input multiplexers, 242
wire-bond packages, 24
Write Enable (WE), 51
write operations, 60
WRITE pin
  defined, 580
WRITE_FIRST mode, 203
WRITE_FIRST option, 60

X

XC18V00 Series PROMs, 531
Xilinx Sales Offices

**Headquarters**
2100 Logic Drive
San Jose, CA 95124
Tel: (408) 559-7778
Fax: (408) 559-7114
TWX: (510) 600-8750

**North America**

**Madison, AL**
Tel: (256) 722-4050
Fax: (256) 722-9912

**Phoenix, AZ**
Tel: (480) 753-4503
Fax: (480) 753-4504

**Irvine, CA**
Tel: (949) 727-0780
Fax: (949) 727-3128

**San Diego, CA**
Tel: (858) 558-5974
Fax: (858) 558-6418

**Sunnyvale, CA**
Tel: (408) 245-9850
Fax: (408) 245-9865

**Greenwood Village, CO**
Tel: (303) 220-7541
Fax: (303) 220-8641

**Winter Park, FL**
Tel: (407) 673-8661
Fax: (407) 673-8663

**Schaumburg, IL**
Tel: (847) 605-1972
Fax: (847) 605-1976

**Deephaven, MN**
Tel: (612) 473-4816
Fax: (612) 473-5060

**Marriottsville, MD**
Tel: (410) 442-9748
Fax: (410) 442-9749

**Nashua, NH**
Tel: (603) 891-1098
Fax: (603) 891-0890

**Ledgewood, NJ**
Tel: (973) 584-7199
Fax: (973) 584-1390

**Raleigh, NC**
Tel: (919) 846-3922
Fax: (919) 846-8316

**Brecksfield, OH**
Tel: (330) 659-3131
Fax: (330) 659-9254

**Portland, OR**
Tel: (503) 293-9016
Fax: (503) 293-3858

**West Chester, PA**
Tel: (610) 430-3300
Fax: (610) 430-0470

**Dallas, TX**
Tel: (972) 960-1043
Fax: (972) 960-0927

**Salt Lake City, UT**
Tel: (801) 268-3434
Fax: (801) 266-9021

**Bellevue, WA**
Tel: (425) 451-7000
Fax: (425) 990-8989

**Oakville, Ontario Canada**
Tel: (905) 337-0894
Fax: (905) 337-3554

**Kanata, Ontario Canada**
Tel: (613) 271-5264
Fax: (613) 592-4256

**European Headquarters**
Benchmark House, 203 Brooklands Rd.
Weybridge Surrey KT13 0RH
United Kingdom
Tel: +44-1-870-7350-600
Fax: +44-1-870-7350-601

**Benelux**
Tel: +32-53-848310
Fax: +32-53-848311

**France and Spain**
Tel: +33-1-34-63-01-01
Fax: +33-1-34-63-01-09

**Germany, Switzerland, and Austria**
Tel: +49-89-93088-0
Fax: +49-89-93088-188

**Italy**
Tel: +39-02-487-12-101
Fax: +39-02-400-94-700

**Sweden, Norway, Denmark, and Finland**
Tel: +46-8-594-61-660
Fax: +46-8-594-61-661

**United Kingdom and Ireland**
Tel: +44-870-7350-603
Fax: +44-870-7350-604

**Japan**
Tel: +81-3-5321-7711
Fax: +81-3-5321-7765

**Asia Pacific Headquarters**
Tel: +852-2-424-5200
Fax: +852-2-494-7159

**Korea**
Tel: +822-761-4277
Fax: +822-761-4278

**Shanghai**
Tel: +86-21-6886-2323, 2322
Fax: +86-21-6886-2333

**Taiwan**
Tel: +886-2-2174-1388
Fax: +886-2-2758-8367

For information on Xilinx North American Sales Representative offices, see [http://www.xilinx.com/company/sales/na_reps.htm](http://www.xilinx.com/company/sales/na_reps.htm)

For information on Xilinx International Sales Representative offices, see [http://www.xilinx.com/company/sales/int_reps.htm](http://www.xilinx.com/company/sales/int_reps.htm)