Virtex ${ }^{\text {TM }} 2.5$ V
Field Programmable Gate Arrays

Final Product Specification

## Features

- Fast, high-density Field-Programmable Gate Arrays
- Densities from 50k to 1 M system gates
- System performance up to 200 MHz
- $66-\mathrm{MHz} \mathrm{PCI}$ Compliant
- Hot-swappable for Compact PCI
- Multi-standard SelectIO ${ }^{\text {TM }}$ interfaces
- 16 high-performance interface standards
- Connects directly to ZBTRAM devices
- Built-in clock-management circuitry
- Four dedicated delay-locked loops (DLLs) for advanced clock control
- Four primary low-skew global clock distribution nets, plus 24 secondary local clock nets
- Hierarchical memory system
- LUTs configurable as 16-bit RAM, 32-bit RAM, 16-bit dual-ported RAM, or 16-bit Shift Register
- Configurable synchronous dual-ported 4k-bit RAMs
- Fast interfaces to external high-performance RAMs
- Flexible architecture that balances speed and density
- Dedicated carry logic for high-speed arithmetic
- Dedicated multiplier support
- Cascade chain for wide-input functions
- Abundant registers/latches with clock enable, and dual synchronous/asynchronous set and reset
- Internal 3-state bussing
- IEEE 1149.1 boundary-scan logic
- Die-temperature sensor diode
- Supported by FPGA Foundation ${ }^{\text {TM }}$ and Alliance Development Systems
- Complete support for Unified Libraries, Relationally Placed Macros, and Design Manager
- Wide selection of PC and workstation platforms
- SRAM-based in-system configuration
- Unlimited re-programmability
- Four programming modes
- $0.22 \mu \mathrm{~m}$ 5-layer metal process
- $100 \%$ factory tested


## Description

The Virtex FPGA family delivers high-performance, high-capacity programmable logic solutions. Dramatic increases in silicon efficiency result from optimizing the new architecture for place-and-route efficiency and exploiting an aggressive 5 -layer-metal $0.22-\mu \mathrm{m}$ CMOS process. These advances make Virtex FPGAs powerful and flexible alternatives to mask-programmed gate arrays. The Virtex family comprises the nine members shown in Table 1.

Building on experience gained from previous generations of FPGAs, the Virtex family represents a revolutionary step forward in programmable logic design. Combining a wide variety of programmable system features, a rich hierarchy of fast, flexible interconnect resources, and advanced process technology, the Virtex family delivers a high-speed and high-capacity programmable logic solution that enhances design flexibility while reducing time-to-market.

Table 1: Virtex Field-Programmable Gate Array Family Members.

| Device | System Gates | CLB Array | Logic Cells | Maximum <br> Available I/O | Block RAM <br> Bits | Maximum <br> SelectRAM+ ${ }^{\text {TM }}$ Bits |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| XCV50 | 57,906 | $16 \times 24$ | 1,728 | 180 | 32,768 | 24,576 |
| XCV100 | 108,904 | $20 \times 30$ | 2,700 | 180 | 40,960 | 38,400 |
| XCV150 | 164,674 | $24 \times 36$ | 3,888 | 260 | 49,152 | 55,296 |
| XCV200 | 236,666 | $28 \times 42$ | 5,292 | 284 | 57,344 | 75,264 |
| XCV300 | 322,970 | $32 \times 48$ | 6,912 | 316 | 65,536 | 98,304 |
| XCV400 | 468,252 | $40 \times 60$ | 10,800 | 404 | 81,920 | 153,600 |
| XCV600 | 661,111 | $48 \times 72$ | 15,552 | 512 | 98,304 | 221,184 |
| XCV800 | 888,439 | $56 \times 84$ | 21,168 | 512 | 114,688 | 301,056 |
| XCV1000 | $1,124,022$ | $64 \times 96$ | 27,648 | 512 | 131,072 | 393,216 |

## Virtex Architecture

Virtex devices feature a flexible, regular architecture that comprises an array of configurable logic blocks (CLBs) surrounded by programmable input/output blocks (IOBs), all interconnected by a rich hierarchy of fast, versatile routing resources. The abundance of routing resources permits the Virtex family to accommodate even the largest and most complex designs.
Virtex FPGAs are SRAM-based, and are customized by loading configuration data into internal memory cells. In some modes, the FPGA reads its own configuration data from an external PROM (master serial mode). Otherwise, the configuration data is written into the FPGA (SelectMAPTM, slave serial, and JTAG modes).
The standard Xilinx Foundation ${ }^{\text {TM }}$ and Alliance Series ${ }^{\text {TM }}$ Development systems deliver complete design support for Virtex, covering every aspect from behavioral and schematic entry, through simulation, automatic design translation and implementation, to the creation, downloading, and readback of a configuration bit stream.

## Higher Performance

Virtex devices provide better performance than previous generations of FPGA. Designs can achieve synchronous system clock rates up to 200 MHz including I/O. Virtex inputs and outputs comply fully with PCl specifications, and interfaces can be implemented that operate at 33 MHz or 66 MHz . Additionally, Virtex supports the hot-swapping requirements of Compact PCI .
Xilinx thoroughly benchmarked the Virtex family. While performance is design-dependent, many designs operated internally at speeds in excess of 100 MHz and can achieve 200 MHz . Table 2 shows performance data for representative circuits, using worst-case timing parameters.
Table 2: Performance for Common Circuit Functions

| Function | Bits | Virtex -6 |
| :--- | :---: | :---: |
| Register-to-Register |  |  |
| Adder | 16 | 5.0 ns |
|  | 64 | 7.2 ns |
| Pipelined Multiplier | $8 \times 8$ | 5.1 ns |
|  | $16 \times 16$ | 6.0 ns |
| Address Decoder | 16 | 4.4 ns |
|  | 64 | 6.4 ns |
| 16:1 Multiplexer |  |  |
|  | 9 | 4.1 ns |
| Parity Tree | 18 | 5.0 ns |
|  | 36 | 6.9 ns |
| Chip-to-Chip |  |  |
| HSTL Class IV | 200 MHz |  |
| LVTTL,16mA, fast slew |  |  |

## Architectural Description

## Virtex Array

The Virtex user-programmable gate array, shown in Figure 1, comprises two major configurable elements: configurable logic blocks (CLBs) and input/output blocks (IOBs).

- CLBs provide the functional elements for constructing logic
- IOBs provide the interface between the package pins and the CLBs
CLBs interconnect through a general routing matrix (GRM). The GRM comprises an array of routing switches located at the intersections of horizontal and vertical routing channels. Each CLB nests into a VersaBlock ${ }^{\text {TM }}$ that also provides local routing resources to connect the CLB to the GRM.
The VersaRing ${ }^{\text {TM }}$ I/O interface provides additional routing resources around the periphery of the device. This routing improves I/O routability and facilitates pin locking.
The Virtex architecture also includes the following circuits that connect to the GRM.
- Dedicated block memories of 4096 bits each
- Clock DLLs for clock-distribution delay compensation and clock domain control
- 3-State buffers (BUFTs) associated with each CLB that drive dedicated segmentable horizontal routing resources
Values stored in static memory cells control the configurable logic elements and interconnect resources. These values load into the memory cells on power-up, and can reload if necessary to change the function of the device.

vao_b.eps
Figure 1: Virtex Architecture Overview


## Input/Output Block

The Virtex IOB, Figure 2, features SelectIO™ inputs and outputs that support a wide variety of I/O signalling standards, see Table 3.
The three IOB storage elements function either as edge-triggered D-type flip-flops or as level sensitive latches. Each IOB has a clock signal (CLK) shared by the three flip-flops and independent clock enable signals for each flip-flop.

In addition to the CLK and CE control signals, the three flip-flops share a Set/Reset (SR). For each flip-flop, this signal can be independently configured as a synchronous Set, a synchronous Reset, an asynchronous Preset, or an asynchronous Clear.
The output buffer and all of the IOB control signals have independent polarity controls.
All pads are protected against damage from electrostatic discharge (ESD) and from over-voltage transients. Two forms of over-voltage protection are provided, one that per-
mits 5 V compliance, and one that does not. For 5 V compliance, a Zener-like structure connected to ground turns on when the output rises to approximately 6.5 V . When PCI 3.3 V compliance is required, a conventional clamp diode is connected to the output supply voltage, $\mathrm{V}_{\mathrm{Cc}}$.
Optional pull-up and pull-down resistors and an optional weak-keeper circuit are attached to each pad. Prior to configuration, all pins not involved in configuration are forced into their high-impedance state. The pull-down resistors and the weak-keeper circuits are inactive, but inputs may optionally be pulled up.
The activation of pull-up resistors prior to configuration is controlled on a global basis by the configuration mode pins. If the pull-up resistors are not activated, all the pins will float. Consequently, external pull-up or pull-down resistors must be provided on pins required to be at a well-defined logic level prior to configuration.

All Virtex IOBs support IEEE 1149.1-compatible boundary scan testing.


Figure 2: Virtex Input/Output Block (IOB)

Table 3: Supported Select I/O Standards

| I/O Standard | Input Reference Voltage ( $\mathrm{V}_{\mathrm{REF}}$ ) | Output Source Voltage ( $\mathrm{V}_{\mathrm{Cco}}$ ) | Board Termination Voltage ( $\mathrm{V}_{\mathrm{TT}}$ ) | 5 V Tolerant |
| :---: | :---: | :---: | :---: | :---: |
| LVTTL 2-24 mA | N/A | 3.3 | N/A | Yes |
| LVCMOS2 | N/A | 2.5 | N/A | Yes |
| PCI, 5 V | N/A | 3.3 | N/A | Yes |
| PCI, 3.3 V | N/A | 3.3 | N/A | No |
| GTL | 0.8 | N/A | 1.2 | No |
| GTL+ | 1.0 | N/A | 1.5 | No |
| HSTL Class I | 0.75 | 1.5 | 0.75 | No |
| HSTL Class III | 0.9 | 1.5 | 1.5 | No |
| HSTL Class IV | 0.9 | 1.5 | 1.5 | No |
| SSTL3 Class I \& II | 1.5 | 3.3 | 1.5 | No |
| SSTL2 Class I \& II | 1.25 | 2.5 | 1.25 | No |
| CTT | 1.5 | 3.3 | 1.5 | No |
| AGP | 1.32 | 3.3 | N/A | No |

## Input Path

A buffer In the Virtex IOB input path routes the input signal either directly to internal logic or through an optional input flip-flop.
An optional delay element at the D-input of this flip-flop eliminates pad-to-pad hold time. The delay is matched to the internal clock-distribution delay of the FPGA, 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 signalling standards supported. In some of these standards the input buffer utilizes a user-supplied threshold voltage, $\mathrm{V}_{\text {REF }}$. The need to supply $\mathrm{V}_{\text {REF }}$ imposes constraints on which standards can used in close proximity to each other. See "I/O Banking" on page 4.
There are optional pull-up and pull-down resistors at each input for use after configuration. Their value is in the range $50-100 \mathrm{k} \Omega$.

## Output Path

The output path includes a 3-state output buffer that drives the output signal onto the pad. The output signal can be routed to the buffer directly from the internal logic or through an optional IOB output flip-flop.

The 3 -state control of the output can also be routed directly from the internal logic or through a flip-flip that provides synchronous enable and disable.
Each output driver can be individually programmed for a wide range of low-voltage signalling standards. Each output buffer can source up to 24 mA and sink up to 48 mA . Drive strength and slew rate controls minimize bus transients.

In most signalling standards, the output High voltage depends on an externally supplied $\mathrm{V}_{\mathrm{Cco}}$ voltage. The need
to supply $\mathrm{V}_{\text {CCO }}$ imposes constraints on which standards can be used in close proximity to each other. See "I/O Banking" on page 4.
An 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 to match the input signal. 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.

Because the weak-keeper circuit uses the IOB input buffer to monitor the input level, an appropriate $\mathrm{V}_{\text {REF }}$ voltage must be provided if the signalling standard requires one. The provision of this voltage must comply with the I/O banking rules.

## I/O Banking

Some of the I/O standards described above require $\mathrm{V}_{\mathrm{CCO}}$ and/or $\mathrm{V}_{\text {REF }}$ voltages. These voltages externally and connected to device pins that serve groups of IOBs, called banks. Consequently, restrictions exist about which I/O standards can be combined within a given bank.

Eight I/O banks result from separating each edge of the FPGA into two banks, as shown in Figure 3. Each bank has multiple $\mathrm{V}_{\mathrm{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 may be mixed only if they use the same $\mathrm{V}_{\mathrm{Cco}}$. Compatible standards are shown in Table 4. GTL and GTL+ appear under all voltages because their open-drain outputs do not depend on $\mathrm{V}_{\mathrm{Cco}}$.


X8778_b
Figure 3: Virtex I/O Banks Table 4: Compatible Output Standards

| $\mathbf{V}_{\text {Cco }}$ | Compatible Standards |
| :---: | :--- |
| 3.3 V | PCI, LVTTL, SSTL3 I, SSTL3 II, CTT, AGP, GTL, <br> GTL+ |
| 2.5 V | SSTL2 I, SSTL2 II, LVCMOS2, GTL, GTL+ |
| 1.5 V | HSTL I, HSTL III, HSTL IV, GTL, GTL+ |

Some input standards require a user-supplied threshold voltage, $\mathrm{V}_{\text {REF }}$. In this case, certain user-l/O pins are automatically configured as inputs for the $\mathrm{V}_{\text {REF }}$ voltage. Approximately one in six of the I/O pins in the bank assume this role.
The $\mathrm{V}_{\text {REF }}$ pins within a bank are interconnected internally and consequently only one $\mathrm{V}_{\text {REF }}$ voltage can be used within each bank. All $\mathrm{V}_{\text {REF }}$ pins in the bank, however, must be connected to the external voltage source for correct operation.

Within a bank, inputs that require $\mathrm{V}_{\text {REF }}$ can be mixed with those that do not. However, only one $V_{\text {REF }}$ voltage may be used within a bank. Input buffers that use $\mathrm{V}_{\text {REF }}$ are not 5 V tolerant. LVTTL, LVCMOS2, and PCI 33 MHz 5 V , are 5 V tolerant.
The $\mathrm{V}_{\mathrm{CCO}}$ and $\mathrm{V}_{\text {REF }}$ pins for each bank appear in the device pin-out tables and diagrams. The diagrams also show the bank affiliation of each I/O.

Within a given package, the number of $\mathrm{V}_{\text {REF }}$ and $\mathrm{V}_{\mathrm{CCO}}$ pins can vary depending on the size of device. In larger devices, more I/O pins convert to $V_{\text {REF }}$ pins. Since these are always a superset of the $\mathrm{V}_{\text {REF }}$ pins used for smaller devices, it is possible to design a PCB that permits migration to a larger device if necessary. All the $\mathrm{V}_{\text {REF }}$ pins for the largest device anticipated must be connected to the $\mathrm{V}_{\text {REF }}$ voltage, and not used for $I / O$.

In smaller devices, some $\mathrm{V}_{\mathrm{CCO}}$ pins used in larger devices do not connect within the package. These unconnected pins may be left unconnected externally, or may be connected to the $\mathrm{V}_{\mathrm{CCO}}$ voltage to permit migration to a larger device if necessary.

In TQ144 and PQ/HQ240 packages, all $\mathrm{V}_{\mathrm{CCO}}$ pins are bonded together internally, and consequently the same $\mathrm{V}_{\mathrm{CCO}}$ voltage must be connected to all of them. In the CS144 package, bank pairs that share a side are interconnected internally, permitting four choices for VCCO. In both cases, the $\mathrm{V}_{\text {REF }}$ pins remain internally connected as eight banks, and may be used as described previously.

## Configurable Logic Block

The basic building block of the Virtex CLB is the logic cell (LC). An LC includes a 4 -input function generator, carry logic, and a storage element. The output from the function generator in each LC drives both the CLB output and the D input of the flip-flop. Each Virtex CLB contains four LCs, organized in two similar slices, as shown in Figure 4. Figure 5 shows a more detailed view of a single slice.

In addition to the four basic LCs, the Virtex CLB contains logic that combines function generators to provide functions of five or six inputs. Consequently, when estimating the number of system gates provided by a given device, each CLB counts as 4.5 LCs.

## Look-Up Tables

Virtex function generators are implemented as 4-input look-up tables (LUTs). In addition to operating as a function generator, each LUT can provide a $16 \times 1$-bit synchronous RAM. Furthermore, the two LUTs within a slice can be combined to create a $16 \times 2$-bit or $32 \times 1$-bit synchronous RAM, or a 16x1-bit dual-port synchronous RAM.
The Virtex LUT can also provide a 16 -bit shift register that is ideal for capturing high-speed or burst-mode data. This mode can also be used to store data in applications such as Digital Signal Processing.

## Storage Elements

The storage elements in the Virtex slice can be configured either as edge-triggered D-type flip-flops or as level-sensitive latches. The D inputs can be driven either by the function generators within the slice or directly from slice inputs, bypassing the function generators.
In addition to Clock and Clock Enable signals, each Slice has synchronous set and reset signals (SR and BY). SR forces a storage element into the initialization state specified for it in the configuration. BY forces it into the opposite state. Alternatively, these signals may be configured to operate asynchronously. All of the control signals are independently invertible, and are shared by the two flip-flops within the slice.


Figure 4: 2-Slice Virtex CLB

## Additional Logic

The F5 multiplexer in each slice combines the function generator outputs. This combination provides either a function generator that can implement any 5 -input function, a 4:1 multiplexer, or selected functions of up to nine inputs.
Similarly, the F6 multiplexer combines the outputs of all four function generators in the CLB by selecting one of the F5-multiplexer outputs. This permits the implementation of any 6-input function, an 8:1 multiplexer, or selected functions of up to 19 inputs.

Each CLB has four direct feedthrough paths, one per LC. These paths provide extra data input lines or additional local routing that does not consume logic resources.

## Arithmetic Logic

Dedicated carry logic provides fast arithmetic carry capability for high-speed arithmetic functions. The Virtex CLB supports two separate carry chains, one per Slice. The height of the carry chains is two bits per CLB.
The arithmetic logic includes an XOR gate that allows a 1 -bit full adder to be implemented within an LC. In addition, a dedicated AND gate improves the efficiency of multiplier implementation.

The dedicated carry path can also be used to cascade function generators for implementing wide logic functions.

## BUFTs

Each Virtex CLB contains two 3-state drivers (BUFTs) that can drive on-chip busses. See "Dedicated Routing" on page 9. Each Virtex BUFT has an independent 3-state control pin and an independent input pin.

## Block SelectRAM

Virtex FPGAs incorporate several large Block SelectRAM memories. These complement the distributed LUT SelectRAMs that provide shallow RAM structures implemented in CLBs.
Block SelectRAM memory blocks are organized in columns. All Virtex devices contain two such columns, one along each vertical edge. These columns extend the full height of the chip. Each memory block is four CLBs high, and consequently, a Virtex device 64 CLBs high contains 16 memory blocks per column, and a total of 32 blocks.


Figure 5: Detailed View of VIrtex Slice
Table 5 shows the amount of Block SelectRAM memory that is available in each Virtex device.

Table 5: Virtex Block SelectRAM Amounts

| Virtex Device | \# of Blocks | Total Block <br> SelectRAM Bits |
| :---: | :---: | :---: |
| XCV50 | 8 | 32,768 |
| XCV100 | 10 | 40,960 |
| XCV150 | 12 | 49,152 |
| XCV200 | 14 | 57,344 |
| XCV300 | 16 | 65,536 |
| XCV400 | 20 | 81,920 |
| XCV600 | 24 | 98,304 |
| XCV800 | 28 | 114,688 |
| XCV1000 | 32 | 131,072 |

Each Block SelectRAM cell, as illustrated in Figure 6, is a fully synchronous dual-ported 4096 -bit RAM with independent control signals for each port. The data widths of the two ports can be configured independently, providing built-in bus-width conversion.'


> xcv_ds_006

Figure 6: Dual-Port Block SelectRAM

Table 6 shows the depth and width aspect ratios for the Block SelectRAM
Table 6: Block SelectRAM Port Aspect Ratios

| Width | Depth | ADDR Bus | Data Bus |
| :---: | :---: | :---: | :---: |
| 1 | 4096 | ADDR $<11: 0>$ | DATA $<0>$ |
| 2 | 2048 | ADDR $<10: 0>$ | DATA $<1: 0>$ |
| 4 | 1024 | ADDR $<9: 0>$ | DATA $<3: 0>$ |
| 8 | 512 | ADDR $<8: 0>$ | DATA $<7: 0>$ |
| 16 | 256 | ADDR $<7: 0>$ | DATA $<15: 0>$ |

The Virtex Block SelectRAM also includes dedicated routing to provide an efficient interface with both CLBs and other Block SelectRAMs.

## Programmable Routing Matrix

It is the longest delay path that limits the speed of any worst-case design. Consequently, the Virtex routing architecture and its place-and-route software were defined in a single optimization process. This joint optimization minimizes long-path delays, and consequently, yields the best system performance.
The joint optimization also reduces design compilation times because the architecture is software-friendly. Design cycles are correspondingly reduced due to shorter design iteration times.

## Local Routing

The VersaBlock provides local routing resources, as shown in Figure 7, providing the following three types of connections.

- Interconnections among the LUTs, flip-flops, and GRM
- Internal CLB feedback paths that provide high-speed connections to LUTs within the same CLB, chaining them together with minimal routing delay
- Direct paths that provide high-speed connections between horizontally adjacent CLBs, eliminating the delay of the GRM.


## General Purpose Routing

Most Virtex signals are routed on the general purpose routing, and consequently, the majority of interconnect resources are associated with this level of the routing hierarchy. The general routing resources are located in horizontal and vertical routing channels associated with the rows and columns CLBs. The general-purpose routing resources are listed below.

- Adjacent to each CLB is a General Routing Matrix (GRM). The GRM is the switch matrix through which horizontal and vertical routing resources connect, and is also the means by which the CLB gains access to the general purpose routing.
- 24 single-length lines route GRM signals to adjacent GRMs in each of the four directions.
- 72 buffered Hex lines route GRM signals to another GRMs six-blocks away in each one of the four directions. Organized in a staggered pattern, Hex lines may be driven only at their endpoints. Hex-line signals can be accessed either at the endpoints or at the midpoint (three blocks from the source). One third of the Hex lines are bidirectional, while the remaining ones are uni-directional.
- 12 Longlines are buffered, bidirectional wires that distribute signals across the device quickly and efficiently. Vertical Longlines span the full height of the device, and horizontal ones span the full width of the device.


## I/O Routing

Virtex devices have additional routing resources around their periphery that form an interface between the CLB array and the IOBs. This additional routing, called the VersaRing, facilitates pin-swapping and pin-locking, such that logic redesigns can adapt to existing PCB layouts. Time-to-market is reduced, since PCBs and other system components can be manufactured while the logic design is still in progress.


Figure 7: Virtex Local Routing

## Dedicated Routing

Some classes of signal require dedicated routing resources to maximize performance. In the Virtex architecture, dedicated routing resources are provided for two classes of signal.

- Horizontal routing resources are provided for on-chip 3 -state busses. Four partitionable bus lines are provided per CLB row, permitting multiple busses within a row, as shown in Figure $\cdot$.
- Two dedicated nets per CLB propagate carry signals vertically to the adjacent CLB.


## Global Routing

Global Routing resources distribute clocks and other signals with very high fanout throughout the device. Virtex devices include two tiers of global routing resources
referred to as primary global and secondary local clock routing resources.

- The primary global routing resources are four dedicated global nets with dedicated input pins that are designed to distribute high-fanout clock signals with minimal skew. Each global clock net can drive all CLB, IOB, and block RAM clock pins. The primary global nets may only be driven by global buffers. There are four global buffers, one for each global net.
- The secondary local clock routing resources consist of 24 backbone lines, 12 across the top of the chip and 12 across bottom. From these lines, up to 12 unique signals per column can be distributed via the 12 longlines in the column. These secondary resources are more flexible than the primary resources since they are not restricted to routing only to clock pins.

buft_c.eps

Figure 8: BUFT Connections to Dedicated Horizontal Bus Lines

## Clock Distribution

Virtex provides high-speed, low-skew clock distribution through the primary global routing resources described above. A typical clock distribution net is shown in Figure .
Four global buffers are provided, two at the top center of the device and two at the bottom center. These drive the four primary global nets that in turn drive any clock pin.
Four dedicated clock pads are provided, one adjacent to each of the global buffers. The input to the global buffer is selected either from these pads or from signals in the general purpose routing.

## Delay-Locked Loop (DLL)

Associated with each global clock input buffer is a fully digital Delay-Locked Loop (DLL) that can eliminate skew between the clock input pad and internal clock-input pins throughout the device. Each DLL can drive two global clock networks.The DLL monitors the input clock and the distributed clock, and automatically adjusts a clock delay element. Clock edges reach internal flip-flops one to four clock periods after they arrive at the input. This closed-loop sys-
tem effectively eliminates clock-distribution delay by ensuring that clock edges arrive at internal flip-flops in synchronism with clock edges arriving at the input.
In addition to eliminating clock-distribution delay, the DLL provides advanced control of multiple clock domains. The DLL provides four quadrature phases of the source clock, can double the clock, or divide the clock by $1.5,2,2.5,3,4$, 5,8 , or 16 .
The DLL also operates as a clock mirror. By driving the output from a DLL off-chip and then back on again, the DLL can be used to de-skew a board level clock among multiple Virtex devices.
In order to guarantee that the system clock is operating correctly prior to the FPGA starting up after configuration, the DLL can delay the completion of the configuration process until after it has achieved lock.
See "DLL Timing Parameters" on page 39 for frequency range information.


Figure 9: Global Clock Distribution Network

## Boundary Scan

Virtex devices support all the mandatory boundary-scan instructions specified in the IEEE standard 1149.1. A Test Access Port (TAP) and registers are provided that implement the EXTEST, INTEST, SAMPLE/PRELOAD, BYPASS, IDCODE, USERCODE, and HIGHZ instructions. The TAP also supports two internal scan chains and configuration/readback of the device.The TAP uses dedicated package pins that always operate using LVTTL. For TDO to operate using LVTTL, the $\mathrm{V}_{\mathrm{CCO}}$ for Bank 2 should be 3.3 V . Otherwise, TDO switches rail-to-rail between ground and $\mathrm{V}_{\mathrm{CcO}}$.
Boundary-scan operation is independent of individual IOB configurations, and unaffected by package type. All IOBs, including un-bonded ones, are treated as independent 3 -state bidirectional pins in a single scan chain. Retention of the bidirectional test capability after configuration facilitates the testing of external interconnections.
Table 7 lists the boundary-scan instructions supported in Virtex FPGAs. Internal signals can be captured during EXTEST by connecting them to un-bonded or unused IOBs. They may also be connected to the unused outputs of IOBs defined as unidirectional input pins.
Before the device is configured, all instructions except USER1 and USER2 are available. After configuration, all instructions are available. During configuration, it is recommended that those operations using the boundary-scan register (SAMPLE/PRELOAD, INTEST, EXTEST) not be performed.
In addition to the test instructions outlined above, the boundary-scan circuitry can be used to configure the FPGA, and also to read back the configuration data.
Figure 10 is a diagram of the Virtex Series boundary scan logic. It includes three bits of Data Register per IOB, the IEEE 1149.1 Test Access Port controller, and the Instruction Register with decodes.

## Instruction Set

The Virtex Series boundary scan instruction set also includes instructions to configure the device and read back configuration data (CFG_IN, CFG_OUT, and JSTART). The complete instruction set is coded as shown in Table 7.

## Data Registers

The primary data register is the boundary scan register. For each IOB pin in the FPGA, bonded or not, it includes three bits for In , Out, and 3 -State Control. Non-IOB pins have appropriate partial bit population if input-only or out-
put-only. Each EXTEST CAPTURED-OR state captures all In, Out, and 3-state pins.

## Table 7: Boundary Scan Instructions

| Boundary-Scan <br> Command | Binary <br> Code(4:0) | Description |
| :---: | :---: | :--- |
| EXTEST | 00000 | Enables boundary-scan <br> EXTEST operation |
| SAMPLE/PRE- <br> LOAD | 00001 | Enables boundary-scan <br> SAMPLE/PRELOAD <br> operation |
| USER 1 | 00010 | Access user-defined <br> register 1 |
| USER 2 | 00011 | Access user-defined <br> register 2 |
| CFG_OUT | 00100 | Access the configura- <br> tion bus for read opera- <br> tions. |
| CFG_IN | 00101 | Access the configura- <br> tion bus for write opera- <br> tions. |
| INTEST | 00111 | Enables boundary-scan <br> INTEST operation |
| USERCODE | 01000 | Enables shifting out <br> USER code |
| IDCODE | 01001 | Enables shifting out of <br> ID Code |
| HIGHZ | 01010 | Tri-states output pins <br> while enabling the By- <br> pass Register |
| JSTART | 01100 | Clock the start-up se- <br> quence when Startup- <br> Clk is TCK |
| BYPASS | 11111 | Enables BYPASS |
| RESERVED | All other codes Xilinx reserved instruc- |  |
| tions |  |  |

The other standard data register is the single flip-flop BYPASS register. It synchronizes data being passed through the FPGA to the next downstream boundary scan device.
The FPGA supports up to two additional internal scan chains that can be specified using the BSCAN macro. The macro provides two user pins (SEL1 and SEL2) which are decodes of the USER1 and USER2 instructions respectively. For these instructions, two corresponding pins (TDO1 and TDO2) allow user scan data to be shifted out of TDO.
Likewise, 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)


Figure 10: Virtex Series Boundary Scan Logic

## Bit Sequence

The order within each IOB is: In, Out, 3-State. The input-only pins contribute only the In bit to the boundary scan I/O data register, while the output-only pins contributes all three bits.
From a cavity-up view of the chip (as shown in EPIC), starting in the upper right chip corner, the boundary scan data-register bits are ordered as shown in Figure 11.
BSDL (Boundary Scan Description Language) files for Virtex Series devices are available on the Xilinx web site in the File Download area.

| Bit 0 ( TDO end) Bit 1 Bit 2 |  |
| :---: | :---: |

Figure 11: Boundary Scan Bit Sequence

## Identification Registers

The IDCODE register is supported. By using the IDCODE, the device connected to the JTAG port can be determined.

The IDCODE register has the following binary format:
VVVV:ffff:fffa:aaaa:aaaa:cccc:cccc:ccc1
where
$\mathrm{v}=$ the die version number
$f=$ the family code (03h for Virtex family)
$\mathrm{a}=$ the number of CLB rows (ranges from 010h for XCV50 to 040h for XCV1000)
$\mathrm{c}=$ the company code (49h for Xilinx)
The USERCODE register is supported. By using the USERCODE, a user-programmable identification code can be loaded and shifted out for examination. The identification code is embedded in the bitstream during bitstream generation and is valid only after configuration.
Table 8: IDCODEs Assigned to Virtex FPGAs

| FPGA | IDCODE |
| :---: | :---: |
| XCV50 | v0610093h |
| XCV100 | v0614093h |
| XCV150 | v0618093h |
| XCV200 | v061C093h |
| XCV300 | v0620093h |
| XCV400 | v0628093h |
| XCV600 | v0630093h |
| XCV800 | v0638093h |
| XCV1000 | v0640093h |

## Including Boundary Scan in a Design

Since the boundary scan pins are dedicated, no special element needs to be added to the design unless an internal data register (USER1 or USER2) is desired.
If an internal data register is used, insert the boundary scan symbol and connect the necessary pins as appropriate.

## Development System

Virtex FPGAs are supported by the Xilinx Foundation and Alliance CAE tools. The basic methodology for Virtex design consists of three interrelated steps: design entry, implementation, and verification. Industry-standard tools are used for design entry and simulation (for example, Synopsys FPGA Express), while Xilinx provides proprietary architecture-specific tools for implementation.

The Xilinx development system is integrated under the Xilinx Design Manager (XDM ${ }^{\text {M }}$ ) software, providing designers with a common user interface regardless of their choice of entry and verification tools. The XDM software simplifies the selection of implementation options with pull-down menus and on-line help.

Application programs ranging from schematic capture to Placement and Routing (PAR) can be accessed through the XDM software. The program command sequence is generated prior to execution, and stored for documentation.

Several advanced software features facilitate Virtex design. RPMs, for example, are schematic-based macros with relative location constraints to guide their placement. They help ensure optimal implementation of common functions.
For HDL design entry, the Xilinx FPGA Foundation development system provides interfaces to the following synthesis design environments.

- Synopsys (FPGA Compiler, FPGA Express)
- Exemplar (Spectrum)
- Synplicity (Synplify)

For schematic design entry, the Xilinx FPGA Foundation and alliance development system provides interfaces to the following schematic-capture design environments.

- Mentor Graphics V8 (Design Architect, QuickSim II)
- Viewlogic Systems (Viewdraw)

Third-party vendors support many other environments.
A standard interface-file specification, Electronic Design Interchange Format (EDIF), simplifies file transfers into and out of the development system.
Virtex FPGAs supported by a unified library of standard functions. This library contains over 400 primitives and macros, ranging from 2-input AND gates to 16-bit accumulators, and includes arithmetic functions, comparators, counters, data registers, decoders, encoders, I/O functions, latches, Boolean functions, multiplexers, shift registers, and barrel shifters.

The "soft macro" portion of the library contains detailed descriptions of common logic functions, but does not contain any partitioning or placement information. The performance of these macros depends, therefore, on the
partitioning and placement obtained during implementation.

RPMs, on the other hand, do contain predetermined partitioning and placement information that permits optimal implementation of these functions. Users can create their own library of soft macros or RPMs based on the macros and primitives in the standard library.

The design environment supports hierarchical design entry, with high-level schematics that comprise major functional blocks, while lower-level schematics define the logic in these blocks. These hierarchical design elements are automatically combined by the implementation tools. Different design entry tools can be combined within a hierarchical design, thus allowing the most convenient entry method to be used for each portion of the design.

## Design Implementation

The place-and-route tools (PAR) automatically provide the implementation flow described in this section. The partitioner takes the EDIF net list for the design and maps the logic into the architectural resources of the FPGA (CLBs and IOBs, for example). The placer then determines the best locations for these blocks based on their interconnections and the desired performance. Finally, the router interconnects the blocks.

The PAR algorithms support fully automatic implementation of most designs. For demanding applications, however, the user can exercise various degrees of control over the process. User partitioning, placement, and routing information is optionally specified during the design-entry process. The implementation of highly structured designs can benefit greatly from basic floor planning.
The implementation software incorporates Timing Wizard ${ }^{\circledR}$ timing-driven placement and routing. Designers specify timing requirements along entire paths during design entry. The timing path analysis routines in PAR then recognize these user-specified requirements and accommodate them.

Timing requirements are entered on a schematic in a form directly relating to the system requirements, such as the targeted clock frequency, or the maximum allowable delay between two registers. In this way, the overall performance of the system along entire signal paths is automatically tailored to user-generated specifications. Specific timing information for individual nets is unnecessary.

## Design Verification

In addition to conventional software simulation, FPGA users can use in-circuit debugging techniques. Because Xilinx devices are infinitely reprogrammable, designs can be verified in real time without the need for extensive sets of software simulation vectors.

## E.XILINX ${ }^{\circ}$ Virtex ${ }^{\text {TM }}$ 2.5 V Field Programmable Gate Arrays

The development system supports both software simulation and in-circuit debugging techniques. For simulation, the system extracts the post-layout timing information from the design database, and back-annotates this information into the net list for use by the simulator. Alternatively, the user can verify timing-critical portions of the design using the TRACE ${ }^{\circledR}$ static timing analyzer.
For in-circuit debugging, the development system includes a download and readback cable. This cable connects the FPGA in the target system to a PC or workstation. After downloading the design into the FPGA, the designer can single-step the logic, readback the contents of the flip-flops, and so observe the internal logic state. Simple modifications can be downloaded into the system in a matter of minutes.

## Configuration

Virtex devices are configured by loading configuration data into the internal configuration memory. Some of the pins used for this are dedicated configuration pins, while others may be re-used as general purpose inputs and outputs once configuration is complete.
The dedicated pins are the mode pins (M2, M1, M0), the configuration clock pin (CCLK), the INIT pin, the DONE pin and the boundary-scan pins (TDI, TDO, TMS, TCK). Depending on the configuration mode chosen, CCLK may
be an output generated by the FPGA, or may be generated externally, and provided to the FPGA as an input.
Note that some configuration pins may act as outputs. For correct operation, these pins may require a $\mathrm{V}_{\mathrm{CCO}}$ of 3.3 V to permit LVTTL operation. All the pins affected fall in banks 2 or 3.
After Virtex devices are configured, unused IOBs function as tri-state OBUFTs with weak pull downs.
For a more detailed description than that given below, see the XAPP138, Virtex Configuration and Readback.

## Configuration Modes

Virtex supports the following four configuration modes.

- Slave-serial mode
- Master-serial mode
- SelectMAP mode
- Boundary-scan mode

The Configuration mode pins (M2, M1, M0) select among these configuration modes with the option in each case of having the IOB pins either pulled up or left floating prior to configuration. The selection codes are listed in Table 9.
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. The three mode pins have internal pull-up resistors, and default to a logic High if left unconnected.

## Table 9: Configuration Codes

| Configuration Mode | M2 | M1 | M0 | CCLK Direction | Data Width | Serial D ${ }_{\text {out }}$ | Configuration Pull-ups |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Master-serial mode | 0 | 0 | 0 | Out | 1 | Yes | No |
| Boundary-scan mode | 1 | 0 | 1 | N/A | 1 | No | No |
| SelectMAP mode | 1 | 1 | 0 | In | 8 | No | No |
| Slave-serial mode | 1 | 1 | 1 | In | 1 | Yes | No |
| Master-serial mode | 1 | 0 | 0 | Out | 1 | Yes | Yes |
| Boundary-scan mode | 0 | 0 | 1 | N/A | 1 | No | Yes |
| SelectMAP mode | 0 | 1 | 0 | In | 8 | No | Yes |
| Slave-serial mode | 0 | 1 | 1 | In | 1 | Yes | Yes |

## Slave Serial Mode

In slave serial mode, the FPGA receives configuration data in bit-serial form from a serial PROM or other source of serial configuration data. The serial bitstream must be setup at the DIN input pin a short time before each rising edge of an externally generated CCLK.
For more information on serial PROMs, see the PROM data sheet at http://www.xilinx.com/partinfo/ds026.pdf.
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 to the DOUT pin. The data on the DOUT pin changes on the rising edge of CCLK.

The change of DOUT on the rising edge of CCLK differs from previous families, but will not cause a problem for mixed configuration chains. This change was made to improve serial-configuration rates for Virtex only chains.
Figure 12 shows a full master/slave system. A Virtex device in slave serial mode should be connected as shown in the third device from the left
Slave-serial mode is selected by applying < 111> or <011> 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. Figure 13 shows slave-serial configuration timing.

Table 10 provides more detail about the characteristics shown in Figure 13. Configuration must be delayed until the $\overline{\text { INIT }}$ pins of all daisy-chained FPGAs are High.
Table 10: Master/Slave Serial Mode Programming Switching

|  | Description | Symbol |  |  | Units |
| :--- | :--- | :---: | :---: | :---: | :---: |
| CCLK | DIN setup/hold, slave mode | $1 / 2$ | $\mathrm{~T}_{\mathrm{DCC}} / T_{\mathrm{CCD}}$ | $5.0 / 0$ | $\mathrm{~ns}, \mathrm{~min}$ |
|  | DIN setup/hold, master mode | $1 / 2$ | $\mathrm{~T}_{\mathrm{DSCK}} / \mathrm{T}_{\mathrm{SCKD}}$ | $5.0 / 0$ | $\mathrm{~ns}, \mathrm{~min}$ |
|  | DOUT | 3 | $\mathrm{~T}_{\mathrm{CCO}}$ | 12.0 | $\mathrm{~ns}, \mathrm{max}$ |
|  | High time | 4 | $\mathrm{~T}_{\mathrm{CCH}}$ | 5.0 | $\mathrm{~ns}, \mathrm{~min}$ |
|  | Low time | 5 | $\mathrm{~T}_{\mathrm{CCL}}$ | 5.0 | $\mathrm{~ns}, \mathrm{~min}$ |
|  | Maximum Frequency |  | $\mathrm{F}_{\mathrm{CC}}$ | 66 | $\mathrm{MHz}, \mathrm{max}$ |
|  | Frequency Tolerance, master mode with |  |  | $+45 \%$ |  |
|  | respect to nominal |  |  | $-30 \%$ |  |



Note 1: If none of the Virtex FPGAs have been selected to drive DONE, an external pull-up resistor of $330 \Omega$ should be added to the common DONE line.

Figure 12: Master/Slave Serial Mode Circuit Diagram


Figure 13: Slave Serial Mode Programming Switching Characteristics

## ExXIINX ${ }^{\circ}$

## Master Serial Mode

In master serial mode, the CCLK output of the FPGA drives a Xilinx Serial PROM that 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. Switching to a lower frequency is prohibited.
The CCLK frequency is set using the ConfigRate option in the bitstream generation software. The maximum CCLK frequency that can be selected is 60 MHz . When selecting a CCLK frequency, ensure that the serial PROM and any daisy-chained FPGAs are fast enough to support the clock rate.

On power-up, the CCLK frequency is 2.5 MHz . This frequency is used until the ConfigRate bits have been loaded when the frequency changes to the selected ConfigRate. Unless a different frequency is specified in the design, the default ConfigRate is 4 MHz .
Figure 12 shows a full master/slave system. In this system, the left-most device operates in master-serial mode. The remaining devices operate in slave-serial mode. The SPROM $\overline{\text { RESET }}$ pin is driven by $\overline{\mathrm{INIT}}$, and the $\overline{\mathrm{CE}}$ input is driven by DONE. There is the potential for contention on the DONE pin, depending on the start-up sequence options chosen.

The sequence of operations necessary to configure a Virtex FPGA serially appears in Figure 14.
Figure 15 shows the timing of master-serial configuration. Master serial mode is selected by a <000> or <100> on the mode pins (M2, M1, M0). Table 10 shows the timing information for Figure 15.

At power-up, Vcc must rise from 1.0 V to Vcc min in less than 50 ms , otherwise delay configuration by pulling $\overline{\mathrm{PRO}}$ $\overline{\text { GRAM }}$ Low until Vcc is valid.

## SelectMAP Mode

The SelectMAP mode is the fastest configuration option. Byte-wide data is written into the FPGA with a BUSY flag controlling the flow of data.
An external data source provides a byte stream, CCLK, a Chip Select ( $\overline{\mathrm{CS}}$ ) signal and a Write signal ( $\overline{\mathrm{WRITE}}$ ). 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 $\overline{\text { WRITE }}$ is not asserted, configuration data is read out of the FPGA as part of a readback operation.

In the SelectMAP mode, multiple Virtex devices may be chained in parallel. DATA pins (D7:D0), CCLK, WRITE, $\overline{B U S Y}$, PROG, DONE, and INIT may be connected in parallel between all the FPGAs. Note that the data is organized with the MSB of each byte on pin DO and the LSB of each byte on D7. The $\overline{C S}$ pins are kept separate, insuring that each FPGA can be selected individually. WRITE should be Low before loading the first bitstream and returned High after the last device has been programmed. Use $\overline{\mathrm{CS}}$ to select the appropriate FPGA for loading the bitstream and sending the configuration data. at the end of the bitstream, deselect the loaded device and select the next target FPGA by setting its $\overline{\mathrm{CS}}$ pin High. A free-running oscillator or other externally generated signal can be used for CCLK. The $\overline{B U S Y}$ signal may be ignored for frequencies below 50 MHz . For details about frequencies above 50 MHz , see XAPP138, Virtex Configuration and Readback. Once all the devices have been programmed, the DONE pin goes High.

ds003_154_111799
igure 14: Serial Configuration Flowchart


Figure 15: Master Serial Mode Programming Switching Characteristics

## ExXIINX ${ }^{\circ}$ Virtex ${ }^{\text {TM }} 2.5$ V Field Programmable Gate Arrays

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

Retention of the SelectMAP port is selectable on a design-by-design basis when the bitstream is generated. If retention is selected, PROHIBIT constraints are required to prevent the SelectMAP-port pins from being used as user I/O.

Multiple Virtex 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, WRITE, and BUSY pins of all the devices in parallel. The individual devices are loaded separately by asserting the $\overline{\mathrm{CS}}$ pin of each device in turn and writing the appropriate data. See Table 11 for SelectMAP Write Timing Characteristics.

Table 11: SelectMAP Write Timing Characteristics

|  | Description |  | Symbol |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CCLK | $\mathrm{D}_{0-7}$ Setup/Hold | 1/2 | $\mathrm{T}_{\text {SMDCC }} / \mathrm{T}_{\text {SMCCD }}$ | $5.0 / 0$ | ns, min |
|  | $\overline{\text { CS }}$ Setup/Hold | 3/4 | $\mathrm{T}_{\text {SMCSCC }} / \mathrm{T}_{\text {SMCCCS }}$ | $7.0 / 0$ | $\mathrm{ns}, \mathrm{min}$ |
|  | WRITE Setup/Hold | 5/6 | $\mathrm{T}_{\text {SMCCW }} / \mathrm{T}_{\text {SMWCC }}$ | 7.0 / 0 | ns, min |
|  | BUSY Propagation Delay | 7 | $\mathrm{T}_{\text {SMCKBY }}$ | 12.0 | ns, max |
|  | Maximum Frequency |  | $\mathrm{F}_{\mathrm{CC}}$ | 66 | MHz, max |
|  | Maximum Frequency with no handshake |  | $\mathrm{F}_{\mathrm{CCNH}}$ | 50 | MHz, max |

## Write

Write operations send packets of configuration data into the FPGA. The sequence of operations for a multi-cycle write operation is shown below. Note that a configuration packet can be split into many such sequences. The packet does not have to complete within one assertion of $\overline{C S}$, illustrated in Figure.

1. Assert $\overline{\text { WRITE }}$ and $\overline{\mathrm{CS}}$ Low. Note that when $\overline{\mathrm{CS}}$ is asserted on successive CCLKs, $\overline{\text { WRITE }}$ must remain either asserted or de-asserted. Otherwise an abort will be initiated, as described below.
2. Drive data onto $D[7: 0]$. Note that to avoid contention, the data source should not be enabled while $\overline{\mathrm{CS}}$ is Low and
$\overline{\text { WRITE }}$ is High. Similarly, while $\overline{\text { WRITE }}$ is High, no more that one $\overline{\mathrm{CS}}$ should be asserted.
3. At the rising edge of CCLK: If BUSY is Low, the data is accepted on this clock. If BUSY is High (from a previous write), the data is not accepted. Acceptance will instead occur on the first clock after BUSY goes Low, and the data must be held until this has happened.
4. Repeat steps 2 and 3 until all the data has been sent.
5. De-assert $\overline{\mathrm{CS}}$ and $\overline{\mathrm{WRITE}}$.


Figure 16: Write Operations

A flowchart for the write operation appears in Figure 17. Note that if CCLK is slower than $\mathrm{f}_{\mathrm{CCNH}}$, the FPGA will never assert BUSY, In this case, the above handshake is unnec-
essary, and data can simply be entered into the FPGA every CCLK cycle.

ds003_17_111799

Figure 17: SelectMAP Flowchart for Write Operation

## Abort

During a given assertion of $\overline{\mathrm{CS}}$, the user cannot switch from a write to a read, or vice-versa. This action causes the current packet command to be aborted. The device will remain

BUSY until the aborted operation has completed. Following an abort, data is assumed to be unaligned to word boundaries, and the FPGA requires a new synchronization word prior to accepting any new packets.

## EXXIINX ${ }^{\circ}$

To initiate an abort during a write operation, de-assert $\overline{\text { WRITE. At the rising edge of CCLK, an abort is initiated, as }}$ shown in Figure .


Figure 18: SelectMAP Write Abort Waveforms

## Boundary-Scan Mode

In the boundary-scan mode, no non-dedicated pins are required, configuration being done entirely through the IEEE 1149.1 Test Access Port.

Configuration through the TAP uses the CFG_IN instruction. This instruction allows data input on TDI to be converted into data packets for the internal configuration bus.

The following steps are required to configure the FPGA through the boundary-scan port (when using TCK as a start-up clock).

1. Load the CFG_IN instruction into the boundary-scan instruction register (IR)
2. Enter the Shift-DR (SDR) state
3. Shift a configuration bitstream into TDI
4. Return to Run-Test-Idle (RTI)
5. Load the JSTART instruction into IR
6. Enter the SDR state
7. Clock TCK through the startup sequence
8. Return to RTI

Configuration and readback via the TAP is always available. The boundary-scan mode is selected by a <101> or $001>$ on the mode pins (M2, M1, M0).

## Configuration Sequence

The configuration of Virtex 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, as described below. The configuration process may also be initiated by asserting PRO$\overline{\text { GRAM. }}$. The end of the memory-clearing phase is signalled
by $\overline{\mathrm{INIT}}$ going High, and the completion of the entire process is signalled by DONE going High.
The power-up timing of configuration signals is shown in Figure. The corresponding timing characteristics are listed in Table 12.


Figure 19: Power-up Timing Configuration Signals
Table 12: Power-up Timing Characteristics

| Description | Symbol | Value | Units |
| :--- | :---: | :---: | :---: |
| Power-on Reset | $\mathrm{T}_{\mathrm{POR}}$ | 2.0 | $\mathrm{~ms}, \max$ |
| Program Latency | $\mathrm{T}_{\mathrm{PL}}$ | 100.0 | $\mu \mathrm{~s}, \max$ |
| CCLK (output) Delay | $\mathrm{T}_{\text {ICCK }}$ | 0.5 | $\mu \mathrm{~s}, \min$ |
|  |  | 4.0 | $\mu \mathrm{~s}, \max$ |
| Program Pulse Width | $\mathrm{T}_{\text {PROGRAM }}$ | 300 | $\mathrm{~ns}, \min$ |

## Delaying Configuration

$\overline{\mathrm{INIT}}$ can be held Low using an open-drain driver. An open-drain is required since $\overline{\mathrm{INIT}}$ is a bidirectional open-drain pin that is held Low by the FPGA 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.

## Start-Up Sequence

The default Start-up sequence is that one CCLK cycle after DONE goes High, the global tri-state signal (GTS) is released. This permits device outputs to turn on as necessary.
One CCLK cycle later, the Global Set/Reset (GSR) and Global Write Enable (GWE) signals are 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 may be changed. In addition, the GTS, GSR, and GWE events may be made dependent on the DONE pins of multiple devices all going High, forcing the devices to start in synchronism. The sequence may also be paused at any stage until lock has been achieved on any or all DLLs.

## Data Stream Format

Virtex devices are configured by sequentially loading frames of data. Table 13 lists the total number of bits required to configure each device. For more detailed information, see application note XAPP151 "Virtex Configuration Architecture Advanced Users Guide".

Table 13: Virtex Bit-stream Lengths

| Device | \# of Configuration Bits |
| :---: | :---: |
| XCV50 | 559,200 |
| XCV100 | 781,216 |
| XCV150 | $1,040,096$ |
| XCV200 | $1,335,840$ |
| XCV300 | $1,751,808$ |
| XCV400 | $2,546,048$ |
| XCV600 | $3,607,968$ |
| XCV800 | $4,715,616$ |
| XCV1000 | $6,127,744$ |

## Readback

The configuration data stored in the Virtex configuration memory can be readback for verification. Along with the configuration data it is possible to readback the contents all flip-flops/latches, LUTRAMs, and block RAMs. This capability is used for real-time debugging.
For more detailed information, see application note XAPP138 "Virtex FPGA Series Configuration and Readback".

## Virtex Electrical Characteristics

## Definition of Terms

Data sheets may be designated as Advance or Preliminary. The status of specifications in these data sheets is as follows:
Advance: Initial estimates based on simulation and/or extrapolation from other speed grades, devices, or families. Values are subject to change. Use as estimates, not for production.

Preliminary: Based on preliminary characterization. Further changes are not expected.
Unmarked: Data sheets not identified as either Advance or Preliminary are to be considered final.
All specifications are representative of worst-case supply voltage and junction temperature conditions. The parameters included are common to popular designs and typical applications. Contact the factory for design considerations requiring more detailed information.

All specifications are subject to change without notice.

## Virtex DC Characteristics

## Absolute Maximum Ratings

| Symbol | Description |  | Units |
| :---: | :--- | :---: | :---: |
| $\mathrm{V}_{\mathrm{CCINT}}$ | Supply voltage relative to GND | -0.5 to 3.0 | V |
| $\mathrm{~V}_{\mathrm{CCO}}$ | Supply voltage relative to GND | -0.5 to 4.0 | V |
| $\mathrm{~V}_{\text {REF }}$ | Input Reference Voltage | -0.5 to 3.6 | V |
| $\mathrm{~V}_{\mathrm{IN}}$ | Input voltage relative to GND | -0.5 to 3.6 | V |
|  | Voltage applied to 3-state output | Internal threshold | -0.5 to 5.5 |
| $\mathrm{~V}_{\mathrm{CC}}$ | Longest Supply Voltage Rise Time from 1V-2.375V | -0.5 to 5.5 | V |
| $\mathrm{~T}_{\mathrm{STG}}$ | Storage temperature (ambient) | 50 | V |
| $\mathrm{~T}_{\mathrm{SOL}}$ | Maximum soldering temp. (10s @ 1/16 in. = 1.5 mm) | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| $\mathrm{T}_{\mathrm{J}}$ | Junction temperature | Plastic Packages | +260 |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |

Notes: Stresses beyond those listed under Absolute Maximum Ratings may 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 may affect device reliability.
Power supplies may turn on in any order.
For protracted periods (e.g., longer than a day), $\mathrm{V}_{\mathrm{IN}}$ should not exceed $\mathrm{V}_{\mathrm{CCO}}$ by more than 3.6 V .

## Recommended Operating Conditions

| Symbol | Description | Min | Max | Units |  |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CCINT}}$ | Input Supply voltage relative to $\mathrm{GND}, \mathrm{T}_{J}=0^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | Commercial | $2.5-5 \%$ | $2.5+5 \%$ | V |
|  | Input Supply voltage relative to $\mathrm{GND}, \mathrm{T}_{J}=-40^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ | Industrial | $2.5-5 \%$ | $2.5+5 \%$ | V |
| $\mathrm{~V}_{\mathrm{CCO}} *$ | Supply voltage relative to $\mathrm{GND}, \mathrm{T}_{J}=0^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | Commercial | 1.4 | 3.6 | V |
|  | Supply voltage relative to $\mathrm{GND}, \mathrm{T}_{J}=-40^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ | Industrial | 1.4 | 3.6 | V |
| $\mathrm{~T}_{\mathrm{IN}}$ | Input signal transition time |  | 250 | ns |  |

Notes: Correct operation is guaranteed with a minimum $\mathrm{V}_{\mathrm{CCINT}}$ of 2.375 V (Nominal $\mathrm{V}_{\mathrm{CCINT}}-5 \%$ ). Below the minimum value, all delay parameters increase by $3 \%$ for each $50-\mathrm{mV}$ reduction in $\mathrm{V}_{\mathrm{CCINT}}$ below the specified range.
At junction temperatures above those listed as Operating Conditions, delay parameters do increase. Please refer to the TRCE report.
Input and output measurement threshold is $\sim 50 \%$ of $\mathrm{V}_{\mathrm{CC}}$.

* Note that Min and Max values for $\mathrm{V}_{\mathrm{CCO}}$ are I/O Standard dependant.


## DC Characteristics Over Recommended Operating Conditions

| Symbol | Description | Device | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {DRINT }}$ | Data Retention $\mathrm{V}_{\mathrm{CIINT}}$ Voltage (below which configuration data may be lost) | All | 2.0 |  | V |
| $\mathrm{V}_{\text {DRIO }}$ | Data Retention $\mathrm{V}_{\mathrm{CCO}}$ Voltage (below which configuration data may be lost) | All | 1.2 |  | V |
| $I_{\text {CCINTQ }}$ | Quiescent $\mathrm{V}_{\text {CCINT }}$ supply current (Notes 1 and 3) | XCV50 XCV100 XCV150 XCV200 XCV300 XCV400 XCV600 XCV800 XCV1000 |  | 50 50 50 75 75 75 100 100 100 | mA mA mA mA mA mA mA mA mA |
| $\mathrm{I}_{\mathrm{CCOQ}}$ | Quiescent $\mathrm{V}_{\text {Cco }}$ supply current (Note 1) | XCV50 XCV100 XCV150 XCV200 XCV300 XCV400 XCV600 XCV800 XCV1000 |  | $\begin{aligned} & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ |
| $\mathrm{I}_{\text {REF }}$ | $\mathrm{V}_{\text {REF }}$ current per $\mathrm{V}_{\text {REF }}$ pin | All |  | 20 | $\mu \mathrm{A}$ |
| IL | Input or output leakage current | All | -10 | +10 | $\mu \mathrm{A}$ |
| $\mathrm{C}_{\text {IN }}$ | Input capacitance (sample tested) $\quad \mathrm{BGA}, \mathrm{PQ}, \mathrm{HQ}$, packages | All |  | 8 | pF |
| $\mathrm{I}_{\text {RPU }}$ | Pad pull-up (when selected) @ $\mathrm{V}_{\text {in }}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CCO}}=3.3 \mathrm{~V}$ (sample tested) | All | Note 2 | 0.25 | mA |
| $\mathrm{I}_{\text {RPD }}$ | Pad pull-down (when selected) @ $\mathrm{V}_{\text {in }}=3.6 \mathrm{~V}$ (sample tested) |  | Note 2 | 0.15 | mA |
| Notes: | 1. With no output current loads, no active input pull-up resistors, all I/O pins Tri-stated and floating. <br> 2. Internal pull-up and pull-down resistors guarantee valid logic levels at unconnected input pins. These pull-up and pull-down resistors do not guarantee valid logic levels when input pins are connected to other circuits. <br> 3. Multiply $\mathrm{I}_{\mathrm{CCINTQ}}$ limit by two for industrial grade. |  |  |  |  |

## 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. This is the time required to reach the nominal power supply voltage of the device ${ }^{1}$ from 0 V . The current is highest at the fastest suggested ramp rate ( 0 V to nominal voltage in 2 ms ) and is lowest at the slowest allowed ramp rate ( 0 V to nominal voltage in 50 ms ).

| Product | Description $^{\mathbf{2}}$ | Current Requirement $^{\mathbf{3}}$ |
| :--- | :---: | :---: |
| Virtex Family, Commercial Grade | Minimum required current supply | 500 mA |
| Virtex Family, Industrial Grade | Minimum required current supply | 2 A |

Notes: 1. Ramp rate used for this specification is from 0-2.7 V dc. Peak current occurs on or near the internal power-on reset threshold and lasts for less than 3 ms .
2. Devices are guaranteed to initialize properly with the minimum current available from the power supply as noted above.
3. Larger currents may result if ramp rates are forced to be faster.

## DC Input and Output levels

Values for $\mathrm{V}_{\mathrm{IL}}$ and $\mathrm{V}_{\mathrm{IH}}$ are recommended input voltages. Values for $\mathrm{I}_{\mathrm{OL}}$ and $\mathrm{I}_{\mathrm{OH}}$ are guaranteed output currents over the recommended operating conditions at the $\mathrm{V}_{\mathrm{OL}}$ and $\mathrm{V}_{\mathrm{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 $\mathrm{V}_{\mathrm{CCO}}$ for each standard with the respective $\mathrm{V}_{\mathrm{OL}}$ and $\mathrm{V}_{\mathrm{OH}}$ voltage levels shown. Other standards are sample tested.

| Input/Output Standard | $\mathrm{V}_{\mathrm{IL}}$ |  | $\mathrm{V}_{\mathbf{I H}}$ |  | $\mathrm{V}_{\text {OL }}$ | $\mathrm{V}_{\mathrm{OH}}$ | IOL | IOH |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | V , min | V, max | V , min | V, max | V, Max | V, Min | mA | mA |
| LVTTL (Note 1) | -0.5 | 0.8 | 2.0 | 5.5 | 0.4 | 2.4 | 24 | -24 |
| LVCMOS2 | -0.5 | . 7 | 1.7 | 5.5 | 0.4 | 1.9 | 12 | -12 |
| PCI, 3.3 V | -0.5 | $44 \% \mathrm{~V}_{\text {CCINT }}$ | $60 \% \mathrm{~V}_{\text {CCINT }}$ | $\mathrm{V}_{\mathrm{CCO}}+0.5$ | $10 \% \mathrm{~V}_{\text {cco }}$ | 90\% $\mathrm{V}_{\text {cco }}$ | Note 2 | Note 2 |
| PCI, 5.0 V | -0.5 | 0.8 | 2.0 | 5.5 | 0.55 | 2.4 | Note 2 | Note 2 |
| GTL | -0.5 | $V_{\text {REF }}-0.05$ | $\mathrm{V}_{\text {REF }}+0.05$ | 3.6 | 0.4 | n/a | 40 | n/a |
| GTL+ | -0.5 | $\mathrm{V}_{\text {REF }}-0.1$ | $\mathrm{V}_{\text {REF }}+0.1$ | 3.6 | 0.6 | n/a | 36 | n/a |
| HSTL I | -0.5 | $\mathrm{V}_{\text {REF }}-0.1$ | $\mathrm{V}_{\text {REF }}+0.1$ | 3.6 | 0.4 | $\mathrm{V}_{\text {CCO }}-0.4$ | 8 | -8 |
| HSTL III | -0.5 | $\mathrm{V}_{\text {REF }}-0.1$ | $\mathrm{V}_{\text {REF }}+0.1$ | 3.6 | 0.4 | $\mathrm{V}_{\text {CCO }}-0.4$ | 24 | -8 |
| HSTL IV | -0.5 | $\mathrm{V}_{\text {REF }}-0.1$ | $\mathrm{V}_{\text {REF }}+0.1$ | 3.6 | 0.4 | $\mathrm{V}_{\text {CCO }}-0.4$ | 48 | -8 |
| SSTL3 I | -0.5 | $\mathrm{V}_{\text {REF }}-0.2$ | $\mathrm{V}_{\text {REF }}+0.2$ | 3.6 | $\mathrm{V}_{\text {REF }}-0.6$ | $\mathrm{V}_{\text {REF }}+0.6$ | 8 | -8 |
| SSTL3 II | -0.5 | $\mathrm{V}_{\text {REF }}-0.2$ | $\mathrm{V}_{\text {REF }}+0.2$ | 3.6 | $\mathrm{V}_{\text {REF }}-0.8$ | $\mathrm{V}_{\text {REF }}+0.8$ | 16 | -16 |
| SSTL2 I | -0.5 | $\mathrm{V}_{\text {REF }}-0.2$ | $\mathrm{V}_{\text {REF }}+0.2$ | 3.6 | $\mathrm{V}_{\text {REF }}-0.61$ | $\mathrm{V}_{\text {REF }}+0.61$ | 7.6 | -7.6 |
| SSTL2 II | -0.5 | $\mathrm{V}_{\text {REF }}-0.2$ | $\mathrm{V}_{\text {REF }}+0.2$ | 3.6 | $\mathrm{V}_{\text {REF }}-0.80$ | $V_{\text {REF }}+0.80$ | 15.2 | -15.2 |
| CTT | -0.5 | $\mathrm{V}_{\text {REF }}-0.2$ | $\mathrm{V}_{\text {REF }}+0.2$ | 3.6 | $\mathrm{V}_{\text {REF }}-0.4$ | $\mathrm{V}_{\text {REF }}+0.4$ | 8 | -8 |
| AGP | -0.5 | $\mathrm{V}_{\text {REF }}-0.2$ | $\mathrm{V}_{\text {REF }}+0.2$ | 3.6 | $10 \% \mathrm{~V}_{\text {CCO }}$ | $90 \% \mathrm{~V}_{\mathrm{CCO}}$ | Note 2 | Note 2 |

Note 1: $\mathrm{V}_{\mathrm{OL}}$ and $\mathrm{V}_{\mathrm{OH}}$ for lower drive currents are sample tested.
Note 2: Tested according to the relevant specifications.

## Virtex Switching Characteristics

Testing of switching parameters is modeled after testing methods specified by MIL-M-38510/605. 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-annotated to the simulation net list. All timing parameters assume worst-case operating conditions (supply voltage and junction temperature). Values apply to all Virtex devices unless otherwise noted.

## IOB Input Switching Characteristics

Input delays associated with the pad are specified for LVTTL levels. For other standards, adjust the delays with the values shown in "IOB Input Switching Characteristics Standard Adjustments" on page 27.

|  |  | Speed Grade | All | -6 | -5 | -4 | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Description | Device | Symbol | Min |  |  |  |  |
| Propagation Delays |  |  |  |  |  |  |  |
| Pad to I output, no delay | All | TIOPI | 0.39 | 0.8 | 0.9 | 1.0 | ns, max |
| Pad to I output, with delay | XCV50 | TIOPID | 0.8 | 1.5 | 1.7 | 1.9 | $\begin{aligned} & \hline \mathrm{ns}, \max \\ & \mathrm{~ns}, \max \\ & \mathrm{~ns}, \max \\ & \mathrm{~ns}, \max \\ & \mathrm{~ns}, \max \\ & \mathrm{~ns}, \max \\ & \mathrm{~ns}, \max \\ & \mathrm{~ns}, \max \\ & \mathrm{~ns}, \max \end{aligned}$ |
|  | XCV100 |  | 0.8 | 1.5 | 1.7 | 1.9 |  |
|  | XCV150 |  | 0.8 | 1.5 | 1.7 | 1.9 |  |
|  | XCV200 |  | 0.8 | 1.5 | 1.7 | 1.9 |  |
|  | XCV300 |  | 0.8 | 1.5 | 1.7 | 1.9 |  |
|  | XCV400 |  | 0.9 | 1.8 | 2.0 | 2.3 |  |
|  | XCV600 |  | 0.9 | 1.8 | 2.0 | 2.3 |  |
|  | XCV800 |  | 1.1 | 2.1 | 2.4 | 2.7 |  |
|  | XCV1000 |  | 1.1 | 2.1 | 2.4 | 2.7 |  |
| Pad to output IQ via transparent latch, no delay | All | TIOPLI | 0.8 | 1.6 | 1.8 | 2.0 | ns, max |
| Pad to output IQ via transparent latch, | XCV50 | $\mathrm{T}_{\text {IOPLID }}$ | 1.9 | 3.7 | 4.2 | 4.8 | ns, max |
| with delay | XCV100 |  | 1.9 | 3.7 | 4.2 | 4.8 | ns, max |
|  | XCV150 |  | 2.0 | 3.9 | 4.3 | 4.9 | ns, max |
|  | XCV200 |  | 2.0 | 4.0 | 4.4 | 5.1 | ns, max |
|  | XCV300 |  | 2.0 | 4.0 | 4.4 | 5.1 | ns, max |
|  | XCV400 |  | 2.1 | 4.1 | 4.6 | 5.3 | ns, max |
|  | XCV600 |  | 2.1 | 4.2 | 4.7 | 5.4 | ns, max |
|  | XCV800 |  | 2.2 | 4.4 | 4.9 | 5.6 | ns, max |
|  | XCV1000 |  | 2.3 | 4.5 | 5.1 | 5.8 | ns, max |

## IOB Input Switching Characteristics (Continued)

|  |  | Speed Grade | All | -6 | -5 | -4 | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Description | Device | Symbol | Min |  |  |  |  |
| Sequential Delays |  |  |  |  |  |  |  |
| Clock CLK to output IQ | All | TIOCKIQ | 0.2 | 0.7 | 0.7 | 0.8 | ns, max |
| Setup and Hold Times with ister | Clock CL | at IOB input reg- |  | Setup | ime / H | Time |  |
| Pad, no delay | All | $\mathrm{T}_{\text {IOPICK }} / \mathrm{T}_{\text {IOICKP }}$ | $0.8 / 0$ | 1.6 / 0 | 1.8 / 0 | 2.0 / 0 | ns, min |
| Pad, with delay | XCV50 | TIOPICKD $/$ I $_{\text {IOICKPD }}$ | 1.9 / 0 | $3.7 / 0$ | $4.1 / 0$ | 4.7 / 0 | ns, min |
|  | XCV100 |  | 1.9 / 0 | $3.7 / 0$ | $4.1 / 0$ | 4.7 / 0 | ns, min |
|  | XCV150 |  | 1.9 / 0 | $3.8 / 0$ | $4.3 / 0$ | 4.9 / 0 | ns, min |
|  | XCV200 |  | 2.0 / 0 | $3.9 / 0$ | $4.4 / 0$ | $5.0 / 0$ | ns, min |
|  | XCV300 |  | $2.0 / 0$ | $3.9 / 0$ | $4.4 / 0$ | $5.0 / 0$ | $n \mathrm{n}, \mathrm{min}$ |
|  | XCV400 |  | $2.1 / 0$ | $4.1 / 0$ | $4.6 / 0$ | $5.3 / 0$ | ns, min |
|  | XCV600 |  | $2.1 / 0$ | $4.2 / 0$ | $4.7 / 0$ | $5.4 / 0$ | ns, min |
|  | XCV800 |  | $2.2 / 0$ | $4.4 / 0$ | 4.9 / 0 | $5.6 / 0$ | $n \mathrm{n}, \mathrm{min}$ |
|  | XCV1000 |  | $2.3 / 0$ | $4.5 / 0$ | $5.0 / 0$ | $5.8 / 0$ | ns, min |
| ICE input | All | TIOICECK $/$ T $_{\text {IOCKICE }}$ | $0.37 / 0$ | 0.8/0 | $0.9 / 0$ | $1.0 / 0$ | ns, max |
| Set/Reset Delays |  |  |  |  |  |  |  |
| SR input (IFF, synchronous) | All | TIOSRCKI | 0.49 | 1.0 | 1.1 | 1.3 | ns, max |
| SR input to IQ (asynchronous) | All | TIOSRIQ | 0.70 | 1.4 | 1.6 | 1.8 | ns, max |
| GSR to output IQ | All | TGSRQ | 4.9 | 9.7 | 10.9 | 12.5 | ns, max |

Note: 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.
Note: Input timing for LVTTL is measured at 1.4 V . For other I/O standards, see Table 15.

## IOB Input Switching Characteristics Standard Adjustments

| - Speed Grade |  |  | All | -6 | -5 | -4 | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Description | Symbol | Standard | Min | Adjustments |  |  |  |
| Data Input Delay Adjustments |  |  |  |  |  |  |  |
| Standard-specific data input delay adjustments | T ILVTTL | LVTTL | 0 | 0 | 0 | 0 | ns |
|  | TILVCMOS2 | LVCMOS2 | -0.02 | -0.04 | -0.04 | -0.05 | ns |
|  | TIPCI33_3 | PCI, 33 MHz, 3.3 V | -0.05 | -0.11 | -0.12 | -0.14 | ns |
|  | TIPCI33_5 | PCI, $33 \mathrm{MHz}, 5.0 \mathrm{~V}$ | 0.13 | 0.25 | 0.28 | 0.33 | ns |
|  | TIPCI66_3 | PCI, $66 \mathrm{MHz}, 3.3 \mathrm{~V}$ | -0.05 | -0.11 | -0.12 | -0.14 | ns |
|  | $\mathrm{T}_{\text {IGTL }}$ | GTL | 0.10 | 0.20 | 0.23 | 0.26 | ns |
|  | T IGTLP | GTL+ | 0.06 | 0.11 | 0.12 | 0.14 | ns |
|  | $\mathrm{T}_{\text {IHSTL }}$ | HSTL | 0.02 | 0.03 | 0.03 | 0.04 | ns |
|  | TISSTL2 | SSTL2 | -0.04 | -0.08 | -0.09 | -0.10 | ns |
|  | $\mathrm{T}_{\text {ISSTL3 }}$ | SSTL3 | -0.02 | -0.04 | -0.05 | -0.06 | ns |
|  | $\mathrm{T}_{\text {ICTT }}$ | CTT | 0.01 | 0.02 | 0.02 | 0.02 | ns |
|  | $\mathrm{T}_{\text {IAGP }}$ | AGP | -0.03 | -0.06 | -0.07 | -0.08 | ns |

[^0]
## IOB Output Switching Characteristics

Output delays terminating at a pad are specified for LVTTL 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" on page 29.

|  | Speed Grade | All | -6 | -5 | -4 | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Description | Symbol | Min |  |  |  |  |
| Propagation Delays |  |  |  |  |  |  |
| O input to Pad | TIOOP | 1.2 | 2.9 | 3.2 | 3.5 | ns, max |
| O input to Pad via transparent latch | $\mathrm{T}_{\text {IOOLP }}$ | 1.4 | 3.4 | 3.7 | 4.0 | ns, max |
| 3-State Delays |  |  |  |  |  |  |
| T input to Pad high-impedance (Note 1) | T ${ }_{\text {IOTHZ }}$ | 1.0 | 2.0 | 2.2 | 2.4 | ns, max |
| T input to valid data on Pad | TIOTON | 1.4 | 3.1 | 3.3 | 3.7 | ns, max |
| T input to Pad high-impedance via transparent latch (Note 1) | T IOTLPHZ | 1.2 | 2.4 | 2.6 | 3.0 | ns, max |
| Tinput to valid data on Pad via transparent latch | TIOTLPON | 1.6 | 3.5 | 3.8 | 4.2 | ns, max |
| GTS to Pad high impedance (Note 1) | $\mathrm{T}_{\text {GTS }}$ | 2.5 | 4.9 | 5.5 | 6.3 | ns, max |
| Sequential Delays |  |  |  |  |  |  |
| Clock CLK to Pad | $\mathrm{T}_{\text {IOCKP }}$ | 1.0 | 2.9 | 3.2 | 3.5 | ns, max |
| Clock CLK to Pad high-impedance (synchronous) (Note 1) | $\mathrm{T}_{\text {IOCKHZ }}$ | 1.1 | 2.3 | 2.5 | 2.9 | ns, max |
| Clock CLK to valid data on Pad (synchronous) | TIOCKON | 1.5 | 3.4 | 3.7 | 4.1 | ns, max |
| Setup and Hold Times before/after Clock CLK |  | Setup Time / Hold Time |  |  |  |  |
| O input | $\mathrm{T}_{\text {IOOCK }} / \mathrm{T}_{\text {IOCKO }}$ | $0.51 / 0$ | $1.1 / 0$ | $1.2 / 0$ | $1.3 / 0$ | ns, min |
| OCE input | $\mathrm{T}_{\text {IOOCECK }} / \mathrm{T}_{\text {IOCKOCE }}$ | $0.37 / 0$ | $0.8 / 0$ | $0.9 / 0$ | $1.0 / 0$ | ns, min |
| SR input (OFF) | $\mathrm{T}_{\text {IOSRCKO/ }}$ / ${ }_{\text {IOCKOSR }}$ | $0.52 / 0$ | $1.1 / 0$ | $1.2 / 0$ | $1.4 / 0$ | $\mathrm{ns}, \mathrm{min}$ |
| 3-State Setup Times, T input | $\mathrm{T}_{\text {IOTCK }} / \mathrm{T}_{\text {IOCK }}$ | 0.34/0 | $0.7 / 0$ | $0.8 / 0$ | $0.9 / 0$ | $\mathrm{ns}, \mathrm{min}$ |
| 3-State Setup Times, TCE input | TIOTCECK $/$ TIOCKTCE | $0.41 / 0$ | $0.9 / 0$ | $0.9 / 0$ | $1.1 / 0$ | $\mathrm{ns}, \mathrm{min}$ |
| 3-State Setup Times, SR input (TFF) | $\mathrm{T}_{\text {IOSRCKT }} / \mathrm{T}_{\text {IOCKTSR }}$ | 0.49/0 | $1.0 / 0$ | $1.1 / 0$ | $1.3 / 0$ | ns , min |
| Set/Reset Delays |  |  |  |  |  |  |
| SR input to Pad (asynchronous) | T ${ }_{\text {IOSRP }}$ | 1.6 | 3.8 | 4.1 | 4.6 | ns, max |
| SR input to Pad high-impedance (asynchronous) (Note 1) | TIOSRHZ | 1.6 | 3.1 | 3.4 | 3.9 | ns, max |
| SR input to valid data on Pad (asynchronous) | TIOSRON | 2.0 | 4.2 | 4.6 | 5.1 | ns, max |
| GSR to Pad | T ${ }_{\text {IOGSRQ }}$ | 4.9 | 9.7 | 10.9 | 12.5 | ns, max |

Notes: 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.
Tri-state turn-off delays should not be adjusted.

## IOB Output Switching Characteristics Standard Adjustments

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

| Speed Grade |  |  | All | -6 | -5 | -4 | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Description | Symbol | Standard | Min | Adjustments |  |  |  |
| Output Delay Adjustments |  |  |  |  |  |  |  |
| Standard-specific adjustments for output delays terminating at pads (based on standard capacitive load, Csl) | Tolvttl s2 | LVTTL, Slow, 2 mA |  | $14.7$ | $15.8$ |  | ns |
|  | ToLVtTL_S4 | 4 mA | 2.5 | 7.5 | 8.0 | 8.6 | ns |
|  | Tolvttl_s6 | 6 mA | 1.8 | 4.8 | 5.1 | 5.6 | ns |
|  | Tolvtil_s8 | 8 mA | 1.2 | 3.0 | 3.3 | 3.5 | ns |
|  | TOLVTTL_S12 | 12 mA | 1.0 | 1.9 | 2.1 | 2.2 | ns |
|  | ToLVTTL_S16 | 16 mA | 0.9 | 1.7 | 1.9 | 2.0 | ns |
|  | ToLVTTL_S24 | 24 mA | 0.8 | 1.3 | 1.4 | 1.6 | ns |
|  | Tolvtil_ F2 | LVTTL, Fast,2 mA | 1.9 | 13.1 | 14.0 | 15.1 | ns |
|  | ToLVtTL_F4 | 4 mA | 0.7 | 5.3 | 5.7 | 6.1 | ns |
|  | Tolvtil_f6 | 6 mA | 0.2 | 3.1 | 3.3 | 3.6 | ns |
|  | Tolvttl_f8 | 8 mA | 0.1 | 1.0 | 1.1 | 1.2 | ns |
|  | ToLVTTL_F12 | 12 mA | 0 | 0 | 0 | 0 | ns |
|  | ToLVTTL_F16 | 16 mA | -0.10 | -0.05 | -0.05 | -0.05 | ns |
|  | ToLVTTL_F24 | 24 mA | -0.10 | -0.20 | -0.21 | -0.23 | ns |
|  | Tolvcmos2 | LVCMOS2 | 0.10 | 0.10 | 0.11 | 0.12 | ns |
|  | TopCl33_3 | PCI, $33 \mathrm{MHz}, 3.3 \mathrm{~V}$ | 0.50 | 2.3 | 2.5 | 2.7 | ns |
|  | T ${ }_{\text {OPCI33_5 }}$ | PCI, $33 \mathrm{MHz}, 5.0 \mathrm{~V}$ | 0.40 | 2.8 | 3.0 | 3.3 | ns |
|  | TOPCI66_3 | PCI, $66 \mathrm{MHz}, 3.3 \mathrm{~V}$ | 0.10 | -0.40 | -0.42 | -0.46 | ns |
|  | T OGTL | GTL | 0.6 | 0.50 | 0.54 | 0.6 | ns |
|  | Togtlp | GTL+ | 0.7 | 0.8 | 0.9 | 1.0 | ns |
|  | TOHSTL_I | HSTL I | 0.10 | -0.50 | -0.53 | -0.5 | ns |
|  | TOHSTL_III | HSTL III | -0.10 | -0.9 | -0.9 | -1.0 | ns |
|  | TOHSTL_IV | HSTL IV | -0.20 | -1.0 | -1.0 | -1.1 | ns |
|  | Tosstl2_I | SSTL2 I | -0.10 | -0.50 | -0.53 | -0.5 | ns |
|  | TOSSLT2_II | SSTL2 II | -0.20 | -0.9 | -0.9 | -1.0 | ns |
|  | TosstL3_I | SSTL3 I | -0.20 | -0.50 | -0.53 | -0.5 | ns |
|  | TOSSTL3_II | SSTL3 II | -0.30 | -1.0 | -1.0 | -1.1 | ns |
|  | TOCTT | CTT | 0 | -0.6 | -0.6 | -0.6 | ns |
|  | ToAGP | AGP | 0 | -0.9 | -0.9 | -1.0 | ns |

Output timing is measured at 1.4 V with 35 pF external capacitive load for LVTTL. For other I/O standards and different loads, see Table 14 and Table 15.

## Calculation of $\mathrm{T}_{\text {ioop }}$ as a Function of Capacitance

$\mathrm{T}_{\text {ioop }}$ is the propagation delay from the O Input of the IOB to the pad. The values for $\mathrm{T}_{\text {ioop }}$ were based on the standard capacitive load (Csl) for each I/O standard as listed in Table 14.

For other capacitive loads, use the formulas below to calculate the corresponding $\mathrm{T}_{\text {ioop }}$.

$$
\mathrm{T}_{\text {ioop }}=\mathrm{T}_{\text {ioop }}+\mathrm{T}_{\text {opadjust }}+\left(\mathrm{C}_{\text {load }}-\mathrm{C}_{\mathrm{sl}}\right)^{*} \mathrm{fl}
$$

Where:
$T_{\text {opadjust }}$ is reported above in the Output Delay Adjustment section.
$\mathrm{C}_{\text {load }}$ is the capacitive load for the design.

## Table 14: Constants for Calculating $\mathrm{T}_{\text {ioop }}$

| Standard | CsI (pF) | fl (ns/pF) |
| :--- | :---: | :---: |
| LVTTL Fast Slew Rate, 2mA drive | 35 | 0.41 |
| LVTTL Fast Slew Rate, 4mA drive | 35 | 0.20 |
| LVTTL Fast Slew Rate, 6mA drive | 35 | 0.13 |
| LVTTL Fast Slew Rate, 8mA drive | 35 | 0.079 |
| LVTTL Fast Slew Rate, 12mA drive | 35 | 0.044 |
| LVTTL Fast Slew Rate, 16mA drive | 35 | 0.043 |
| LVTTL Fast Slew Rate, 24mA drive | 35 | 0.033 |
| LVTTL Slow Slew Rate, 2mA drive | 35 | 0.41 |
| LVTTL Slow Slew Rate, 4mA drive | 35 | 0.20 |
| LVTTL Slow Slew Rate, 6mA drive | 35 | 0.100 |
| LVTTL Slow Slew Rate, 8mA drive | 35 | 0.086 |
| LVTTL Slow Slew Rate, 12mA drive | 35 | 0.058 |
| LVTTL Slow Slew Rate, 16mA drive | 35 | 0.050 |
| LVTTL Slow Slew Rate, 24mA drive | 35 | 0.048 |
| LVCMOS2 | 35 | 0.041 |
| PCI 33MHz 5V | 50 | 0.050 |
| PCI 33MHZ 3.3 V | 10 | 0.050 |
| PCI 66 MHz 3.3 V | 10 | 0.033 |
| GTL | 0 | 0.014 |
| GTL+ | 0 | 0.017 |
| HSTL Class I | 20 | 0.022 |
| HSTL Class III | 20 | 0.016 |
| HSTL Class IV | 20 | 0.014 |
| SSTL2 Class I | 30 | 0.028 |
| SSTL2 Class II | 30 | 0.016 |
| SSTL3 Class I | 30 | 0.029 |
| SSTL3 Class II | 30 | 0.016 |
| CTT | 20 | 0.035 |
| AGP | 10 | 0.037 |

Note 1://O parameter measurements are made with the capacitance values shown above. See Xilinx application note XAPP133 for appropriate terminations.
Note 2: I/O standard measurements are reflected in the IBIS model information except where the IBIS format precludes it.

Table 15: Delay Measurement Methodology

| Standard | $\mathrm{V}_{\mathrm{L}}{ }^{1}$ | $\mathrm{V}_{\mathrm{H}}{ }^{1}$ | Meas. Point | $\begin{gathered} \mathbf{V}_{\text {REF }} \\ (\mathrm{Typ})^{2} \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: |
| LVTTL | 0 | 3 | 1.4 |  |
| LVCMOS2 | 0 | 2.5 | 1.125 |  |
| PCI33_5 | Per PCI Spec |  |  |  |
| PCI33_3 | Per PCI Spec |  |  |  |
| PCI66_3 | Per PCI Spec |  |  |  |
| GTL | $\mathrm{V}_{\text {REF }}-0.2$ | $\mathrm{V}_{\text {REF }}+0.2$ | $\mathrm{V}_{\text {REF }}$ | 0.80 |
| GTL+ | $\mathrm{V}_{\text {REF }}-0.2$ | $\mathrm{V}_{\text {REF }}+0.2$ | $\mathrm{V}_{\text {REF }}$ | 1.0 |
| HSTL Class I | $\mathrm{V}_{\text {REF }}-0.5$ | $\mathrm{V}_{\text {REF }}+0.5$ | $V_{\text {REF }}$ | 0.75 |
| HSTL Class III | $\mathrm{V}_{\text {REF }}-0.5$ | $\mathrm{V}_{\text {REF }}+0.5$ | $\mathrm{V}_{\text {REF }}$ | 0.90 |
| HSTL Class IV | $V_{\text {REF }}-0.5$ | $\mathrm{V}_{\text {REF }}+0.5$ | $\mathrm{V}_{\text {REF }}$ | 0.90 |
| SSTL3 I \& II | $V_{\text {REF }}-1.0$ | $\mathrm{V}_{\text {REF }}+1.0$ | $\mathrm{V}_{\text {REF }}$ | 1.5 |
| SSTL2 I \& II | $\mathrm{V}_{\text {REF }}-0.75$ | $\mathrm{V}_{\text {REF }}+0.75$ | $V_{\text {REF }}$ | 1.25 |
| CTT | $V_{\text {REF }}-0.2$ | $\mathrm{V}_{\text {REF }}+0.2$ | $V_{\text {REF }}$ | 1.5 |
| AGP | $\begin{gathered} \mathrm{V}_{\mathrm{REF}}{ }^{-} \\ \left(0.2 \times \mathrm{V}_{\mathrm{CCO}}\right) \end{gathered}$ | $\begin{gathered} \mathrm{V}_{\text {REF }}+ \\ \left(0.2 \times \mathrm{V}_{\mathrm{CCO}}\right) \end{gathered}$ | $\mathrm{V}_{\text {REF }}$ | Per AGP Spec |

Note 1: Input waveform switches between $\mathrm{V}_{\mathrm{L}}$ and $\mathrm{V}_{\mathrm{H}}$.
Note 2: Measurements are made at VREF (Typ), Maximum, and Minimum. Worst-case values are reported.
Note 3: I/O parameter measurements are made with the capacitance values shown in Table 14. See Xilinx application note XAPP133 for appropriate terminations.
Note 4: I/O standard measurements are reflected in the IBIS model information except where the IBIS format precludes it.

## Clock Distribution Guidelines

|  |  |  | Speed Grade |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Description | Device | Symbol | -6 | -5 | -4 |  |
| Global Clock Skew |  |  |  |  |  |  |
| Global Clock Skew between IOB Flip-flops | XCV50 | TGSKEWIOB | 0.10 | 0.12 | 0.14 | ns, max |
|  | XCV100 |  | 0.12 | 0.13 | 0.15 | ns, max |
|  | XCV150 |  | 0.12 | 0.13 | 0.15 | ns, max |
|  | XCV200 |  | 0.13 | 0.14 | 0.16 | $n \mathrm{~ns}$ max |
|  | XCV300 |  | 0.14 | 0.16 | 0.18 | $n \mathrm{n}$, max |
|  | XCV400 |  | 0.13 | 0.13 | 0.14 | ns, max |
|  | XCV600 |  | 0.14 | 0.15 | 0.17 | ns, max |
|  | XCV800 |  | 0.16 | 0.17 | 0.20 | ns, max |
|  | XCV1000 |  | 0.20 | 0.23 | 0.25 | ns, max |

Note: These clock-skew delays are provided for guidance only. They reflect the delays encountered in a typical design under worst-case conditions. Precise values for a particular design are provided by the timing analyzer.

## Clock Distribution Switching Characteristics

|  | Speed Grade | All | -6 | -5 | -4 | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Description | Symbol | Min |  |  |  |  |
| GCLK IOB and Buffer |  |  |  |  |  |  |
| Global Clock PAD to output. | $\mathrm{T}_{\text {GPIO }}$ | 0.33 | 0.7 | 0.8 | 0.9 | ns, max |
| Global Clock Buffer I input to O output | $\mathrm{T}_{\mathrm{GIO}}$ | 0.34 | 0.7 | 0.8 | 0.9 | ns, max |

## I/O Standard Global Clock Input Adjustments

|  |  | Speed Grade | All | -6 | -5 | -4 | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Description | Symbol | Standard | Min | Adjustments |  |  |  |
| Data Input Delay Adjustments |  |  |  |  |  |  |  |
| Standard-specific global clock input | T GPLVTTL | LVTTL | 0 | 0 | 0 | 0 | ns, max |
| delay adjustments | TGPLVCMOS2 | LVCMOS2 | -0.02 | -0.04 | -0.04 | -0.05 | ns, max |
|  | T GPPCI33_3 | PCI, 33 MHz, 3.3 V | -0.05 | -0.11 | -0.12 | -0.14 | ns, max |
|  | T ${ }_{\text {GPPCI33_5 }}$ | $\mathrm{PCI}, 33 \mathrm{MHz}, 5.0 \mathrm{~V}$ | 0.13 | 0.25 | 0.28 | 0.33 | ns, max |
|  | T ${ }_{\text {GPPCI66_3 }}$ | PCI, $66 \mathrm{MHz}, 3.3 \mathrm{~V}$ | -0.05 | -0.11 | -0.12 | -0.14 | ns, max |
|  | T GPGTL | GTL | 0.7 | 0.8 | 0.9 | 0.9 | ns, max |
|  | TGPGTLP | GTL+ | 0.7 | 0.8 | 0.8 | 0.8 | ns, max |
|  | T GPHSTL | HSTL | 0.7 | 0.7 | 0.7 | 0.7 | ns, max |
|  | T GPSSTL2 | SSTL2 | 0.6 | 0.52 | 0.51 | 0.50 | ns, max |
|  | T GPSSTL3 | SSTL3 | 0.6 | 0.6 | 0.55 | 0.54 | ns, max |
|  | $\mathrm{T}_{\text {GPCTT }}$ | CTT | 0.7 | 0.7 | 0.7 | 0.7 | ns, max |
|  | TGPAGP | AGP | 0.6 | 0.54 | 0.53 | 0.52 | ns, max |

[^1]
## CLB Switching Characteristics

Delays originating at $\mathrm{F} / \mathrm{G}$ inputs vary slightly according to the input used. The values listed below are worst-case. Precise values are provided by the timing analyzer.

|  | Speed Grade | All | -6 | -5 | -4 | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Description | Symbol | Min |  |  |  |  |
| Combinatorial Delays |  |  |  |  |  |  |
| 4-input function: F/G inputs to X/Y outputs | $\mathrm{T}_{\text {ILO }}$ | 0.29 | 0.6 | 0.7 | 0.8 | ns, max |
| 5-input function: F/G inputs to F5 output | $\mathrm{T}_{\text {IF5 }}$ | 0.32 | 0.7 | 0.8 | 0.9 | ns, max |
| 5-input function: F/G inputs to X output | $\mathrm{T}_{\text {IF5 }} \mathrm{X}$ | 0.36 | 0.8 | 0.8 | 1.0 | ns, max |
| 6-input function: F/G inputs to Y output via F6 MUX | $\mathrm{T}_{\text {IFGY }}$ | 0.44 | 0.9 | 1.0 | 1.2 | ns, max |
| 6-input function: F5IN input to Y output | $\mathrm{T}_{\text {F5INY }}$ | 0.17 | 0.32 | 0.36 | 0.42 | ns, max |
| Incremental delay routing through transparent latch to XQ/YQ outputs | $\mathrm{T}_{\text {IFNCTL }}$ | 0.31 | 0.7 | 0.7 | 0.8 | ns, max |
| BY input to YB output | $\mathrm{T}_{\text {BYYB }}$ | 0.27 | 0.53 | 0.6 | 0.7 | ns, max |
| Sequential Delays |  |  |  |  |  |  |
| FF Clock CLK to XQ/YQ outputs | T ${ }_{\text {CKO }}$ | 0.54 | 1.1 | 1.2 | 1.4 | ns, max |
| Latch Clock CLK to XQ/YQ outputs | $\mathrm{T}_{\text {CKLO }}$ | 0.6 | 1.2 | 1.4 | 1.6 | ns, max |
| Setup and Hold Times before/after Clock CLK | Setup Time / Hold Time |  |  |  |  |  |
| 4-input function: F/G Inputs | $\mathrm{T}_{\text {ICK }} / \mathrm{T}_{\text {CKI }}$ | $0.6 / 0$ | $1.2 / 0$ | $1.4 / 0$ | 1.5/0 | ns, min |
| 5-input function: F/G inputs | $\mathrm{T}_{\text {IF5CK }} / \mathrm{T}_{\text {CKIF5 }}$ | $0.7 / 0$ | 1.3/0 | 1.5/0 | 1.7/0 | ns, min |
| 6-input function: F5IN input | $\mathrm{T}_{\text {F5INCK }} / \mathrm{T}_{\text {CKF5IN }}$ | $0.46 / 0$ | 1.0/0 | 1.1/0 | $1.2 / 0$ | ns, min |
| 6-input function: F/G inputs via F6 MUX | $\mathrm{T}_{\text {IF6CK }} / \mathrm{T}_{\text {CKIF6 }}$ | 0.8/0 | 1.5/0 | 1.7/0 | 1.9/0 | ns, min |
| BX/BY inputs | $\mathrm{T}_{\text {DICK }} / \mathrm{T}_{\text {CKDI }}$ | $0.30 / 0$ | 0.6/0 | $0.7 / 0$ | 0.8/0 | ns, min |
| CE input | $\mathrm{T}_{\text {CECK }} / \mathrm{T}_{\text {CKCE }}$ | $0.37 / 0$ | 0.8/0 | 0.9/0 | $1.0 / 0$ | ns, min |
| SR/BY inputs (synchronous) | $\mathrm{T}_{\text {RCK }}{ }^{\text {T }}$ CKR | $0.33 / 0$ | 0.7/0 | 0.8/0 | 0.9/0 | ns, min |
| Clock CLK |  |  |  |  |  |  |
| Minimum Pulse Width, High | $\mathrm{T}_{\mathrm{CH}}$ | 0.8 | 1.5 | 1.7 | 2.0 | ns, min |
| Minimum Pulse Width, Low | $\mathrm{T}_{\mathrm{CL}}$ | 0.8 | 1.5 | 1.7 | 2.0 | ns, min |
| Set/Reset |  |  |  |  |  |  |
| Minimum Pulse Width, SR/BY inputs | $\mathrm{T}_{\text {RPW }}$ | 1.3 | 2.5 | 2.8 | 3.3 | ns, min |
| Delay from SR/BY inputs to XQ/YQ outputs (asynchronous) | $\mathrm{T}_{\mathrm{RQ}}$ | 0.54 | 1.1 | 1.3 | 1.4 | ns, max |
| Delay from GSR to XQ/YQ outputs | TIOGSRQ | 4.9 | 9.7 | 10.9 | 12.5 | ns, max |
| Toggle Frequency (MHz) (for export control) | $\mathrm{F}_{\text {TOG }}(\mathrm{MHz})$ | 625 | 333 | 294 | 250 | MHz |

Note: 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.

## EXILINX ${ }^{\circ}$

## CLB Arithmetic Switching Characteristics

Setup times not listed explicitly can be approximated by decreasing the combinatorial delays by the setup time adjustment listed. Precise values are provided by the timing analyzer.


Note: 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.

## CLB SelectRAM Switching Characteristics

| Speed Grade |  | All | -6 | -5 | -4 | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Description | Symbol | Min |  |  |  |  |
| Sequential Delays |  |  |  |  |  |  |
| Clock CLK to X/Y outputs (WE active) $16 \times 1$ mode | T ${ }_{\text {SHCKO16 }}$ | 1.2 | 2.3 | 2.6 | 3.0 | ns, max |
| Clock CLK to X/Y outputs (WE active) $32 \times 1$ mode | TSHCKO32 | 1.2 | 2.7 | 3.1 | 3.5 | ns, max |
| Shift-Register Mode Clock CLK to X/Y outputs | $\mathrm{T}_{\text {REG }}$ | 1.2 | 3.7 | 4.1 | 4.7 | ns, max |
| Setup and Hold Times before/after Clock CLK | Setup Time / Hold Time |  |  |  |  |  |
| F/G address inputs | $\mathrm{T}_{\text {AS }} / \mathrm{T}_{\text {AH }}$ | 0.25 / 0 | 0.5 / 0 | 0.6 / 0 | 0.7 / 0 | ns, min |
| BX/BY data inputs (DIN) | $\mathrm{T}_{\mathrm{DS}} / \mathrm{T}_{\mathrm{DH}}$ | $0.34 / 0$ | $0.7 / 0$ | 0.8/0 | $0.9 / 0$ | ns, min |
| CE input (WE) | $\mathrm{T}_{\mathrm{WS}} / \mathrm{T}_{\mathrm{WH}}$ | $0.38 / 0$ | $0.8 / 0$ | 0.9/0 | 1.0 / 0 | $\mathrm{ns}, \mathrm{min}$ |
| Shift-Register Mode <br> BX/BY data inputs (DIN) <br> CE input (WS) | TSHDICK <br> TSHCECK | $\begin{aligned} & 0.34 \\ & 0.38 \end{aligned}$ | 0.7 0.8 | 0.8 0.9 | 0.9 1.0 | ns, min ns, min |
| Clock CLK |  |  |  |  |  |  |
| Minimum Pulse Width, High | T WPH | 1.2 | 2.4 | 2.7 | 3.1 | ns, min |
| Minimum Pulse Width, Low | $\mathrm{T}_{\text {WPL }}$ | 1.2 | 2.4 | 2.7 | 3.1 | $\mathrm{ns}, \mathrm{min}$ |
| Minimum clock period to meet address write cycle time | Twc | 2.4 | 4.8 | 5.4 | 6.2 | $\mathrm{ns}, \mathrm{min}$ |
| Shift-Register Mode <br> Minimum Pulse Width, High Minimum Pulse Width, Low | $T_{\text {SRPH }}$ <br> TSRPL | $\begin{aligned} & 1.2 \\ & 1.2 \end{aligned}$ | 2.4 2.4 | $\begin{aligned} & 2.7 \\ & 2.7 \end{aligned}$ | $\begin{aligned} & 3.1 \\ & 3.1 \end{aligned}$ | ns, min ns, min |

Note: 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.

## Block RAM Switching Characteristics

|  | Speed Grade | All | -6 | -5 | -4 | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Description | Symbol | Min |  |  |  |  |
| Sequential Delays |  |  |  |  |  |  |
| Clock CLK to DOUT output | $\mathrm{T}_{\text {BCKO }}$ | 1.7 | 3.4 | 3.8 | 4.3 | ns, max |
| Setup and Hold Times before/after Clock CLK | Setup Time / Hold Time |  |  |  |  |  |
| ADDR inputs | $\mathrm{T}_{\text {BACK }} / \mathrm{T}_{\text {BCKA }}$ | $0.6 / 0$ | $1.2 / 0$ | $1.3 / 0$ | $1.5 / 0$ | ns, min |
| DIN inputs | $\mathrm{T}_{\text {BDCK }} / \mathrm{T}_{\text {BCKD }}$ | $0.6 / 0$ | $1.2 / 0$ | $1.3 / 0$ | $1.5 / 0$ | $\mathrm{ns}, \mathrm{min}$ |
| EN input | $\mathrm{T}_{\text {BECK }} / \mathrm{T}_{\text {BCKE }}$ | $1.3 / 0$ | $2.6 / 0$ | 3.0 / 0 | $3.4 / 0$ | ns, min |
| RST input | $\mathrm{T}_{\text {BRCK }} / \mathrm{T}_{\text {BCKR }}$ | $1.3 / 0$ | $2.5 / 0$ | $2.7 / 0$ | $3.2 / 0$ | ns , min |
| WEN input | $\mathrm{T}_{\text {BWCK }} / \mathrm{T}_{\text {BCKW }}$ | $1.2 / 0$ | $2.3 / 0$ | 2.6 / 0 | $3.0 / 0$ | $\mathrm{ns}, \mathrm{min}$ |
| Clock CLK |  |  |  |  |  |  |
| Minimum Pulse Width, High | $\mathrm{T}_{\text {BPWH }}$ | 0.8 | 1.5 | 1.7 | 2.0 | ns, min |
| Minimum Pulse Width, Low | $\mathrm{T}_{\text {BPWL }}$ | 0.8 | 1.5 | 1.7 | 2.0 | ns , min |
| CLKA -> CLKB setup time for different ports | T BCCS |  | 3.0 | 3.5 | 4.0 | ns , min |

Note: 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

| Speed Grade |  | All | -6 | -5 | -4 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Description | Symbol | Min |  |  |  | Units |
| Combinatorial Delays |  |  |  |  |  |  |
| IN input to OUT output | $\mathrm{T}_{10}$ | 0 | 0 | 0 | 0 | ns, max |
| TRI input to OUT output high-impedance | TofF | 0.05 | 0.09 | 0.10 | 0.11 | ns, max |
| TRI input to valid data on OUT output | Ton | 0.05 | 0.09 | 0.10 | 0.11 | ns, max |

## JTAG Test Access Port Switching Characteristics

| Description |  | Speed Grade |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Symbol | $\mathbf{- 6}$ | $\mathbf{- 5}$ | $\mathbf{- 4}$ | Units |  |
| TMS and TDI Setup times before TCK | $\mathrm{T}_{\text {TAPTCK }}$ | 4.0 | 4.0 | 4.0 | $\mathrm{~ns}, \mathbf{m i n}$ |
| TMS and TDI Hold times after TCK | $\mathrm{T}_{\text {TCKTAP }}$ | 2.0 | 2.0 | 2.0 | $\mathrm{~ns}, \mathrm{~min}$ |
| Output delay from clock TCK to output TDO | $\mathrm{T}_{\text {TCKTDO }}$ | 11.0 | 11.0 | 11.0 | $\mathrm{~ns}, \mathrm{max}$ |
| Maximum TCK clock frequency | $\mathrm{F}_{\text {TCK }}$ | 33 | 33 | 33 | $\mathrm{MHz}, \mathrm{max}$ |

## Virtex Pin-to-Pin Output Parameter Guidelines

Testing of switching parameters is modeled after testing methods specified by MIL-M-38510/605. 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 LVTTL, 12 mA, Fast Slew Rate, with DLL

|  | Speed Grade |  | All | -6 | -5 | -4 | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Description | Symbol | Device | Min |  |  |  |  |
| LVTTL Global Clock Input to Output Delay using Output Flip-flop, 12 mA, Fast Slew Rate, with DLL. For data output with different standards, adjust delays with the values shown in Output Delay Adjustments. | TICKOFDLL | XCV50 | 1.0 | 3.1 | 3.3 | 3.6 | ns, max |
|  |  | XCV100 | 1.0 | 3.1 | 3.3 | 3.6 | ns, max |
|  |  | XCV150 | 1.0 | 3.1 | 3.3 | 3.6 | $n \mathrm{n}$, max |
|  |  | XCV200 | 1.0 | 3.1 | 3.3 | 3.6 | ns, max |
|  |  | XCV300 | 1.0 | 3.1 | 3.3 | 3.6 | $n \mathrm{n}$, max |
|  |  | XCV400 | 1.0 | 3.1 | 3.3 | 3.6 | $n \mathrm{n}$, max |
|  |  | XCV600 | 1.0 | 3.1 | 3.3 | 3.6 | ns, max |
|  |  | XCV800 | 1.0 | 3.1 | 3.3 | 3.6 | ns, max |
|  |  | XCV1000 | 1.0 | 3.1 | 3.3 | 3.6 | ns, max |

Notes: 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.
Output timing is measured at 1.4 V with 35 pF external capacitive load for LVTTL. The 35 pF load does not apply to the Min values. For other I/O standards and different loads, see Table 14 and Table 15.
DLL output jitter is already included in the timing calculation.

## Global Clock Input to Output Delay for LVTTL, 12 mA , Fast Slew Rate, without DLL

|  | Speed Grade |  | All | -6 | -5 | -4 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Description | Symbol | Device | Min |  |  |  |  |
| LVTTL Global Clock Input to Output Delay using Output Flip-flop, 12 mA, Fast Slew Rate, without DLL. For data output with different standards, adjust delays with the values shown in Input and Output Delay Adjustments. <br> For I/O standards requiring $\mathrm{V}_{\text {REF }}$, such as GTL, GTL+, SSTL, HSTL, CTT, and AGO, an additional 600 ps must be added. | TICKOF | $\begin{gathered} \hline \text { XCV50 } \\ \text { XCV100 } \\ \text { XCV150 } \\ \text { XCV200 } \\ \text { XCV300 } \\ \text { XCV400 } \\ \text { XCV600 } \\ \text { XCV800 } \\ \text { XCV1000 } \end{gathered}$ | $\begin{aligned} & \hline 1.5 \\ & 1.5 \\ & 1.5 \\ & 1.5 \\ & 1.5 \\ & 1.5 \\ & 1.6 \\ & 1.6 \\ & 1.7 \end{aligned}$ | $\begin{aligned} & \hline 4.6 \\ & 4.6 \\ & 4.7 \\ & 4.7 \\ & 4.7 \\ & 4.8 \\ & 4.9 \\ & 4.9 \\ & 5.0 \end{aligned}$ | $\begin{aligned} & 5.1 \\ & 5.1 \\ & 5.2 \\ & 5.2 \\ & 5.2 \\ & 5.3 \\ & 5.4 \\ & 5.5 \\ & 5.6 \end{aligned}$ | $\begin{aligned} & 5.7 \\ & 5.7 \\ & 5.8 \\ & 5.8 \\ & 5.9 \\ & 6.0 \\ & 6.0 \\ & 6.2 \\ & 6.0 \end{aligned}$ | ns, max <br> ns, max <br> ns, max <br> ns, max <br> ns, max <br> ns, max <br> ns, max <br> ns, max <br> ns, max |

Notes: 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.
Output timing is measured at 1.4 V with 35 pF external capacitive load for LVTTL. The 35 pF load does not apply to the Min values. For other I/O standards and different loads, see Table 14 and Table 15.

## ExXIINX ${ }^{\circ}$

## Minimum Clock to Out for Virtex Devices

| I/O Standard | With DLL | Without DLL |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | All Devices | V50 | V100 | V150 | V200 | V300 | V400 | V600 | V800 | V1000 | Units |
| *LVTTL_S2 | 5.2 | 6.0 | 6.0 | 6.0 | 6.0 | 6.1 | 6.1 | 6.1 | 6.1 | 6.1 | ns |
| *LVTTL_S4 | 3.5 | 4.3 | 4.3 | 4.3 | 4.3 | 4.4 | 4.4 | 4.4 | 4.4 | 4.4 | ns |
| *LVTTL_S6 | 2.8 | 3.6 | 3.6 | 3.6 | 3.6 | 3.7 | 3.7 | 3.7 | 3.7 | 3.7 | ns |
| *LVTTL_S8 | 2.2 | 3.1 | 3.1 | 3.1 | 3.1 | 3.1 | 3.1 | 3.2 | 3.2 | 3.2 | ns |
| *LVTTL_S12 | 2.0 | 2.9 | 2.9 | 2.9 | 2.9 | 2.9 | 2.9 | 3.0 | 3.0 | 3.0 | ns |
| *LVTTL_S16 | 1.9 | 2.8 | 2.8 | 2.8 | 2.8 | 2.8 | 2.8 | 2.9 | 2.9 | 2.9 | ns |
| *LVTTL_S24 | 1.8 | 2.6 | 2.6 | 2.7 | 2.7 | 2.7 | 2.7 | 2.7 | 2.7 | 2.8 | ns |
| *LVTTL_F2 | 2.9 | 3.8 | 3.8 | 3.8 | 3.8 | 3.8 | 3.8 | 3.9 | 3.9 | 3.9 | ns |
| *LVTTL_F4 | 1.7 | 2.6 | 2.6 | 2.6 | 2.6 | 2.6 | 2.6 | 2.7 | 2.7 | 2.7 | ns |
| *LVTTL_F6 | 1.2 | 2.0 | 2.0 | 2.0 | 2.1 | 2.1 | 2.1 | 2.1 | 2.1 | 2.2 | ns |
| *LVTTL_F8 | 1.1 | 1.9 | 1.9 | 1.9 | 1.9 | 2.0 | 2.0 | 2.0 | 2.0 | 2.0 | ns |
| *LVTTL_F12 | 1.0 | 1.8 | 1.8 | 1.8 | 1.8 | 1.9 | 1.9 | 1.9 | 1.9 | 1.9 | ns |
| *LVTTL_F16 | 0.9 | 1.7 | 1.8 | 1.8 | 1.8 | 1.8 | 1.8 | 1.8 | 1.9 | 1.9 | ns |
| *LVTTL_F24 | 0.9 | 1.7 | 1.7 | 1.7 | 1.8 | 1.8 | 1.8 | 1.8 | 1.8 | 1.9 | ns |
| LVCMOS2 | 1.1 | 1.9 | 1.9 | 1.9 | 2.0 | 2.0 | 2.0 | 2.0 | 2.0 | 2.1 | ns |
| PCI33_3 | 1.5 | 2.4 | 2.4 | 2.4 | 2.4 | 2.4 | 2.4 | 2.5 | 2.5 | 2.5 | ns |
| PCI33_5 | 1.4 | 2.2 | 2.2 | 2.3 | 2.3 | 2.3 | 2.3 | 2.3 | 2.3 | 2.4 | ns |
| PCI66_3 | 1.1 | 1.9 | 1.9 | 2.0 | 2.0 | 2.0 | 2.0 | 2.0 | 2.1 | 2.1 | ns |
| GTL | 1.6 | 2.5 | 2.5 | 2.5 | 2.5 | 2.5 | 2.5 | 2.6 | 2.6 | 2.6 | ns |
| GTL+ | 1.7 | 2.5 | 2.5 | 2.6 | 2.6 | 2.6 | 2.6 | 2.6 | 2.6 | 2.7 | ns |
| HSTL I | 1.1 | 1.9 | 1.9 | 1.9 | 1.9 | 2.0 | 2.0 | 2.0 | 2.0 | 2.0 | ns |
| HSTL III | 0.9 | 1.7 | 1.7 | 1.8 | 1.8 | 1.8 | 1.8 | 1.8 | 1.8 | 1.9 | ns |
| HSTL IV | 0.8 | 1.6 | 1.6 | 1.6 | 1.7 | 1.7 | 1.7 | 1.7 | 1.7 | 1.8 | ns |
| SSTL2 I | 0.9 | 1.7 | 1.7 | 1.7 | 1.7 | 1.8 | 1.8 | 1.8 | 1.8 | 1.8 | ns |
| SSTL2 II | 0.8 | 1.6 | 1.6 | 1.6 | 1.6 | 1.7 | 1.7 | 1.7 | 1.7 | 1.7 | ns |
| SSTL3 I | 0.8 | 1.6 | 1.7 | 1.7 | 1.7 | 1.7 | 1.7 | 1.7 | 1.8 | 1.8 | ns |
| SSTL3 II | 0.7 | 1.5 | 1.5 | 1.6 | 1.6 | 1.6 | 1.6 | 1.6 | 1.6 | 1.7 | ns |
| CTT | 1.0 | 1.8 | 1.8 | 1.8 | 1.9 | 1.9 | 1.9 | 1.9 | 1.9 | 2.0 | ns |
| AGP | 1.0 | 1.8 | 1.8 | 1.9 | 1.9 | 1.9 | 1.9 | 1.9 | 1.9 | 2.0 | ns |

${ }^{*}$ S = Slow Slew Rate, F = Fast Slew Rate
Notes: 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. Input and output timing is measured at 1.4 V for LVTTL. For other I/O standards, see Table 15. In all cases, an 8 pF external capacitive load is used.

## Virtex Pin-to-Pin Input Parameter Guidelines

Testing of switching parameters is modeled after testing methods specified by MIL-M-38510/605. 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 LVTTL Standard, with DLL

| Speed Grade |  |  | All | -6 | -5 | -4 | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Description | Symbol | Device | Min |  |  |  |  |

Input Setup and Hold Time Relative to Global Clock Input Signal for LVTTL Standard. For data input with different standards, adjust the setup time delay by the values shown in Input Delay Adjustments.

| No Delay Global Clock and IFF, with DLL | $\mathrm{T}_{\text {PSDLL }} / \mathrm{T}_{\text {PHDLL }}$ | XCV50 XCV100 XCV150 XCV200 XCV300 XCV400 XCV600 XCV800 XCV1000 | $\begin{aligned} & \hline 0.40 / 0 \\ & 0.40 / 0 \\ & 0.40 / 0 \\ & 0.40 / 0 \\ & 0.40 / 0 \\ & 0.40 / 0 \\ & 0.40 / 0 \\ & 0.40 / 0 \\ & 0.40 / 0 \end{aligned}$ | $\begin{aligned} & \hline 1.7 / 0 \\ & 1.7 / 0 \\ & 1.7 / 0 \\ & 1.7 / 0 \\ & 1.7 / 0 \\ & 1.7 / 0 \\ & 1.7 / 0 \\ & 1.7 / 0 \\ & 1.7 / 0 \end{aligned}$ | $\begin{aligned} & \hline 1.8 / 0 \\ & 1.9 / 0 \\ & 1.9 / 0 \\ & 1.9 / 0 \\ & 1.9 / 0 \\ & 1.9 / 0 \\ & 1.9 / 0 \\ & 1.9 / 0 \\ & 1.9 / 0 \end{aligned}$ | $\begin{aligned} & \hline 2.1 / 0 \\ & 2.1 / 0 \\ & 2.1 / 0 \\ & 2.1 / 0 \\ & 2.1 / 0 \\ & 2.1 / 0 \\ & 2.1 / 0 \\ & 2.1 / 0 \\ & 2.1 / 0 \end{aligned}$ | ns, min ns, min ns, min ns, min ns, min ns, min ns, min ns, min ns, min |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

IFF = Input Flip-Flop or Latch
Notes: 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.
DLL output jitter is already included in the timing calculation.
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.

## Global Clock Set-Up and Hold for LVTTL Standard, without DLL

| Speed Grade |  |  | All | -6 | -5 | -4 | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Description | Symbol | Device | Min |  |  |  |  |
| Input Setup and Hold Time Relative to Global Clock Input Signal for LVTTL Standard. For data input with different standards, adjust the setup time delay by the values shown in Input Delay Adjustments. |  |  |  |  |  |  |  |
| Full Delay Global Clock and IFF, without DLL | $\mathrm{T}_{\text {PSFD }} / \mathrm{T}_{\text {PHFD }}$ | XCV50 | 0.6 / 0 | $2.3 / 0$ | $2.6 / 0$ | $2.9 / 0$ | ns, min |
|  |  | XCV100 | $0.6 / 0$ | $2.3 / 0$ | $2.6 / 0$ | $3.0 / 0$ | ns, min |
|  |  | XCV150 | $0.6 / 0$ | $2.4 / 0$ | $2.7 / 0$ | $3.1 / 0$ | ns, min |
|  |  | XCV200 | $0.7 / 0$ | $2.5 / 0$ | $2.8 / 0$ | 3.2 / 0 | ns, min |
|  |  | XCV300 | $0.7 / 0$ | $2.5 / 0$ | $2.8 / 0$ | $3.2 / 0$ | ns, min |
|  |  | XCV400 | $0.7 / 0$ | $2.6 / 0$ | $2.9 / 0$ | $3.3 / 0$ | ns, min |
|  |  | XCV600 | $0.7 / 0$ | $2.6 / 0$ | $2.9 / 0$ | $3.3 / 0$ | ns, min |
|  |  | XCV800 | $0.7 / 0$ | $2.7 / 0$ | $3.1 / 0$ | $3.5 / 0$ | ns, min |
|  |  | XCV1000 | $0.7 / 0$ | $2.8 / 0$ | $3.1 / 0$ | 3.6 / 0 | ns , min |

IFF = Input Flip-Flop or Latch
Notes: 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.
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.

## DLL Timing Parameters

Switching parameters testing is modeled after testing methods specified by MIL-M-38510/605; all devices are 100 percent 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.

|  | Speed Grade | $\mathbf{- 6}$ |  |  |  | $\mathbf{- 5}$ |  |  | $\mathbf{- 4}$ |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Description | Symbol | Min | Max | Min | Max | Min | Max | Units |  |
| Input Clock Frequency (CLKDLLHF) | $\mathrm{F}_{\text {CLKINHF }}$ | 60 | 200 | 60 | 180 | 60 | 180 | MHz |  |
| Input Clock Frequency (CLKDLL) | $\mathrm{F}_{\text {CLKINLF }}$ | 25 | 100 | 25 | 90 | 25 | 90 | MHz |  |
| Input Clock Pulse Width (CLKDLLHF) | $\mathrm{T}_{\text {DLLPWHF }}$ | 2.0 | - | 2.4 | - | 2.4 | - | ns |  |
| Input Clock Pulse Width (CLKDLL) | $\mathrm{T}_{\text {DLLPWLF }}$ | 2.5 | - | 3.0 |  | 3.0 | - | ns |  |

Note: All specifications correspond to Commercial Operating Temperatures $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$.

## DLL Clock Tolerance, Jitter, and Phase Information

All DLL output jitter and phase specifications determined through statistical measurement at the package pins using a clock mirror configuration and matched drivers.

| Description | Symbol | $\mathrm{F}_{\text {cLKIN }}$ | CLKDLLHF |  | CLKDLL |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
| Input Clock Period Tolerance | TIPTOL |  | - | 1.0 | - | 1.0 | ns |
| Input Clock Jitter Tolerance (Cycle to Cycle) | $\mathrm{T}_{\text {IJITCC }}$ |  | - | $\pm 150$ | - | $\pm 300$ | ps |
| Time Required for DLL to Acquire Lock | TLOCK | $>60 \mathrm{MHz}$ | - | 20 | - | 20 | $\mu \mathrm{s}$ |
|  |  | $50-60 \mathrm{MHz}$ | - | - | - | 25 | $\mu \mathrm{s}$ |
|  |  | $40-50 \mathrm{MHz}$ | - | - | - | 50 | $\mu \mathrm{s}$ |
|  |  | 30-40 MHz | - | - | - | 90 | $\mu \mathrm{s}$ |
|  |  | 25-30 MHz | - | - | - | 120 | Ms |
| Output Jitter (cycle-to-cycle) for any DLL Clock Output ${ }^{1}$ | TOJITCC |  |  | $\pm 60$ |  | $\pm 60$ | ps |
| Phase Offset between CLKIN and CLKO² | $\mathrm{T}_{\text {PHIO }}$ |  |  | $\pm 100$ |  | $\pm 100$ | ps |
| Phase Offset between Clock Outputs on the DLL ${ }^{3}$ | $\mathrm{T}_{\text {PHOO }}$ |  |  | $\pm 140$ |  | $\pm 140$ | ps |
| Maximum Phase Difference between CLKIN and CLKO ${ }^{4}$ | T ${ }_{\text {PHIOM }}$ |  |  | $\pm 160$ |  | $\pm 160$ | ps |
| Maximum Phase Difference between Clock Outputs on the DLL ${ }^{5}$ | $\mathrm{T}_{\text {PHOOM }}$ |  |  | $\pm 200$ |  | $\pm 200$ | ps |

Note 1: Output Jitter is cycle-to-cycle jitter measured on the DLL output clock, excluding input clock jitter.
Note 2: Phase Offset between CLKIN and CLKO is the worst-case fixed time difference between rising edges of CLKIN and CLKO, excluding Output Jitter and input clock jitter.
Note 3: 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.
Note 4: Maximum Phase Difference between CLKIN an CLKO is the sum of Output Jitter and Phase Offset between CLKIN and CLKO, or the greatest difference between CLKIN and CLKO rising edges due to DLL alone (excluding input clock jitter).
Note 5: Maximum Phase Dlfference between Clock Outputs on the DLL is the sum of Output Jltter and Phase Offset between any DLL clock outputs, or the greatest difference between any two DLL output rising edges sue to DLL alone (excluding input clock jitter).
Note 6: All specifications correspond to Commercial Operating Temperatures ( $0^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ).

Period Tolerance: the allowed input clock period change in nanoseconds.


Output Jitter: the difference between an ideal
Phase Offset and Maximum Phase Difference reference clock edge and the actual design.

ds003_20c_110399
Figure 20: Frequency Tolerance and Clock Jitter

## Virtex Pin Definitions

## Table 16: Special Purpose Pins

| Pin Name | Dedicated Pin | Direction | Description |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { GCKO, GCK1, } \\ & \text { GCK2, GCK3 } \end{aligned}$ | Yes | Input | Clock input pins that connect to Global Clock Buffers. These pins become user inputs when not needed for clocks. |
| M0, M1, M2 | Yes | Input | Mode pins are used to specify the configuration mode. |
| CCLK | Yes | Input or Output | The configuration Clock I/O pin: it is an input for SelectMAP and slave-serial modes, and output in master-serial mode. After configuration, it is input only, logic level = Don't Care. |
| PROGRAM | Yes | Input | Initiates a configuration sequence when asserted Low. |
| DONE | Yes | Bidirectional | Indicates that configuration loading is complete, and that the start-up sequence is in progress. The output may be open drain. |
| INIT | No | Bidirectional (Open-drain) | When Low, indicates that the configuration memory is being cleared. The pin becomes a user I/O after configuration. |
| $\begin{aligned} & \hline \text { BUSY/ } \\ & \text { DOUT } \end{aligned}$ | No | Output | 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. <br> In bit-serial modes, DOUT provides header information to downstream devices in a daisy-chain. The pin becomes a user I/O after configuration. |
| $\begin{aligned} & \hline \text { D0/DIN, } \\ & \text { D1, D2, } \\ & \text { D3, D4, } \\ & \text { D5, D6, } \\ & \text { D7 } \end{aligned}$ | No | Input or Output | In SelectMAP mode, D0-7 are configuration data pins. These pins become user I/Os after configuration unless the SelectMAP port is retained. <br> In bit-serial modes, DIN is the single data input. This pin becomes a user I/O after configuration. |
| $\overline{\text { WRITE }}$ | No | Input | In SelectMAP mode, the active-low Write Enable signal. The pin becomes a user I/O after configuration unless the SelectMAP port is retained. |
| CS | No | Input | In SelectMAP mode, the active-low Chip Select signal. The pin becomes a user I/O after configuration unless the SelectMAP port is retained. |
| $\begin{aligned} & \text { TDI, TDO, } \\ & \text { TMS, TCK } \end{aligned}$ | Yes | Mixed | Boundary-scan Test-Access-Port pins, as defined in IEEE 1149.1. |
| DXN, DXP | Yes | N/A | Temperature-sensing diode pins. (Anode: DXP, cathode: DXN) |
| $\mathrm{V}_{\text {CCINT }}$ | Yes | Input | Power-supply pins for the internal core logic. |
| $\mathrm{V}_{\mathrm{CCO}}$ | Yes | Input | Power-supply pins for the output drivers (subject to banking rules) |
| $\mathrm{V}_{\text {REF }}$ | No | Input | Input threshold voltage pins. Become user I/Os when an external threshold voltage is not needed (subject to banking rules). |
| GND | Yes | Input | Ground |

## Virtex Pin Outs

## Pin-Out Tables

See the Xilinx WebLINX web site (http://www.xilinx.com/partinfo/databook.htm) for updates or additional pin-out information. For convenience, Table 17, Table 18 and Table 19 list the locations of special-purpose and power-supply pins. Pins not listed are either user I/Os or not connected, depending on the device/package combination. Please see the Pinout Diagrams starting on page 59 for any pins not listed for a particular part/package combination.

Table 17: Virtex Pin-out Tables (Chip-scale and QFP Packages)

| Pin Name | Device | CS144 | TQ144 | PQ/HQ240 |
| :---: | :---: | :---: | :---: | :---: |
| GCK0 | All | K7 | 90 | 92 |
| GCK1 | All | M7 | 93 | 89 |
| GCK2 | All | A7 | 19 | 210 |
| GCK3 | All | A6 | 16 | 213 |
| M0 | All | M1 | 110 | 60 |
| M1 | All | L2 | 112 | 58 |
| M2 | All | N2 | 108 | 62 |
| CCLK | All | B13 | 38 | 179 |
| $\overline{\text { PROGRAM }}$ | All | L12 | 72 | 122 |
| DONE | All | M12 | 74 | 120 |
| $\overline{\text { INIT }}$ | All | L13 | 71 | 123 |
| BUSY/DOUT | All | C11 | 39 | 178 |
| DO/DIN | All | C12 | 40 | 177 |
| D1 | All | E10 | 45 | 167 |
| D2 | All | E12 | 47 | 163 |
| D3 | All | F11 | 51 | 156 |
| D4 | All | H12 | 59 | 145 |
| D5 | All | J13 | 63 | 138 |
| D6 | All | J11 | 65 | 134 |
| D7 | All | K10 | 70 | 124 |
| $\overline{\text { WRITE }}$ | All | C10 | 32 | 185 |
| $\overline{\mathrm{CS}}$ | All | D10 | 33 | 184 |
| TDI | All | A11 | 34 | 183 |
| TDO | All | A12 | 36 | 181 |
| TMS | All | B1 | 143 | 2 |
| TCK | All | C3 | 2 | 239 |
| $\mathrm{V}_{\text {CCINT }}$ | All | $\begin{gathered} \text { A9, B6, } \\ \text { C5, G3, } \\ \text { G12, M5, } \\ \text { M9, N6 } \end{gathered}$ | $\begin{aligned} & \hline 10,15, \\ & 25,57, \\ & 84,94, \\ & 99,126 \end{aligned}$ | 16,32, 43,77, 88,104, 137,148, 164,198, 214,225 |

Table 17: Virtex Pin-out Tables (Chip-scale and QFP Packages) (Continued)

| Pin Name | Device | CS144 | TQ144 | PQ/HQ240 |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CCO}}$ | All | Banks 0 and 1: <br> A2, A13, D7 <br> Banks 2 and 3: <br> B12, G11, M13 <br> Banks 4 and 5: <br> N1, N7, N13 <br> Banks 6 and 7: <br> B2, G2, M2 | No I/O Banks in this package: $\begin{gathered} 1,17, \\ 37,55, \\ 73,92, \\ 109,128 \end{gathered}$ | No I/O Banks in this package: $\begin{gathered} 15,30, \\ 44,61, \\ 76,90, \\ 105,121, \\ 136,150, \\ 165,180, \\ 197,212, \\ 226,240 \end{gathered}$ |
| $V_{\text {REF }}$, Bank 0 <br> ( $V_{\text {REF }}$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) | XCV50 | C4, D6 | 5, 13 | 218, 232 |
|  | XCV100/150 | ... + B4 | ... +7 | ... + 229 |
|  | XCV200/300 |  |  | $\ldots+236$ |
|  | XCV400 |  |  | $\ldots+215$ |
|  | XCV600 |  |  | ... + 230 |
| Within each bank, if input reference voltage is not required, all $\mathrm{V}_{\text {REF }}$ pins are general I/O. | XCV800 |  |  | $\ldots+222$ |
| $\mathrm{V}_{\text {REF }}$, Bank 1 <br> ( $V_{\text {REF }}$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) <br> Within each bank, if input reference voltage is not required, all $\mathrm{V}_{\text {REF }}$ pins are general I/O. | XCV50 | A10, B8 | 22, 30 | 191, 205 |
|  | XCV100/150 | ... + D9 | ... + 28 | ... + 194 |
|  | XCV200/300 |  |  | ... + 187 |
|  | XCV400 |  |  | ... + 208 |
|  | XCV600 |  |  | ... + 193 |
|  | XCV800 |  |  | ... + 201 |
| $V_{\text {REF }}$, Bank 2 <br> ( $V_{\text {REF }}$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) | XCV50 | D11, F10 | 42, 50 | 157, 171 |
|  | XCV100/150 | ... + D13 | $\ldots+44$ | ... + 168 |
|  | XCV200/300 |  |  | ... +175 |
|  | XCV400 |  |  | $\ldots+154$ |
|  | XCV600 |  |  | ... + 169 |
| the same package.) <br> Within each bank, if input reference voltage is not required, all $\mathrm{V}_{\text {REF }}$ pins are general I/O. | XCV800 |  |  | ... + 161 |

Table 17: Virtex Pin-out Tables (Chip-scale and QFP Packages) (Continued)

| Pin Name | Device | CS144 | TQ144 | PQ/HQ240 |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {REF }}$, Bank 3 <br> ( $\mathrm{V}_{\text {REF }}$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) | XCV50 | H11, K12 | 60,68 | 130, 144 |
|  | XCV100/150 | $\ldots+\mathrm{J} 10$ | $\ldots+66$ | $\ldots+133$ |
|  | XCV200/300 |  |  | $\ldots+126$ |
|  | XCV400 |  |  | $\ldots+147$ |
|  | XCV600 |  |  | $\ldots+132$ |
|  | XCV800 |  |  | $\ldots+140$ |
| Within each bank, if input reference voltage is not required, all $\mathrm{V}_{\text {REF }}$ pins are general I/O. |  |  |  |  |
| $\mathrm{V}_{\text {REF }}$, Bank 4 <br> ( $V_{\text {REF }}$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) | XCV50 | L8, L10 | 79, 87 | 97, 111 |
|  | XCV100/150 | $\ldots+$ N10 | $\ldots+81$ | $\ldots+108$ |
|  | XCV200/300 |  |  | $\ldots+115$ |
|  | XCV400 |  |  | $\ldots+94$ |
|  | XCV600 |  |  | $\ldots+109$ |
|  | XCV800 |  |  | $\ldots+101$ |
| Within each bank, if input reference voltage is not required, all $\mathrm{V}_{\text {REF }}$ pins are general I/O. |  |  |  |  |
| $\mathrm{V}_{\text {REF }}$, Bank 5 <br> ( $\mathrm{V}_{\text {REF }}$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) <br> Within each bank, if input reference voltage is not required, all $\mathrm{V}_{\text {REF }}$ pins are general I/O. | XCV50 | L4, L6 | 96, 104 | 70, 84 |
|  | XCV100/150 | $\ldots+\mathrm{N} 4$ | $\ldots+102$ | $\ldots+73$ |
|  | XCV200/300 |  |  | $\ldots+66$ |
|  | XCV400 |  |  | $\ldots+87$ |
|  | XCV600 |  |  | $\ldots+72$ |
|  | XCV800 |  |  | ... +80 |
| $\mathrm{V}_{\text {REF }}$, Bank 6 <br> ( $\mathrm{V}_{\text {REF }}$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) <br> Within each bank, if input reference voltage is not required, all $\mathrm{V}_{\text {REF }}$ pins are general I/O. | XCV50 | H2, K1 | 116, 123 | 36, 50 |
|  | XCV100/150 | $\ldots+$ J3 | $\ldots+118$ | $\ldots+47$ |
|  | XCV200/300 |  |  | $\ldots+54$ |
|  | XCV400 |  |  | $\ldots+33$ |
|  | XCV600 |  |  | $\ldots+48$ |
|  | XCV800 |  |  | $\ldots+40$ |

Table 17: Virtex Pin-out Tables (Chip-scale and QFP Packages) (Continued)

| Pin Name | Device | CS144 | TQ144 | PQ/HQ240 |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {REF }}$, Bank 7 <br> ( $V_{\text {REF }}$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) | XCV50 | D4, E1 | 133, 140 | 9, 23 |
|  | XCV100/150 | ... + D2 | $\ldots+138$ | $\ldots+12$ |
|  | XCV200/300 |  |  | $\ldots+5$ |
|  | XCV400 |  |  | $\ldots+26$ |
|  | XCV600 |  |  | $\ldots+11$ |
| the same package.) <br> Within each bank, if input reference voltage is not required, all $\mathrm{V}_{\text {REF }}$ pins are general I/O. | XCV800 |  |  | $\ldots+19$ |
| GND | All | A1, B9, B11, C7, <br> D5, E4, <br> E11, F1, <br> G10, J1, <br> J12, L3, <br> L5, L7, <br> L9, N12 | $\begin{gathered} \hline 9,18, \\ 26,35, \\ 46,54, \\ 64,75 \\ 83,91, \\ 100,111, \\ 120,129, \\ 136,144, \end{gathered}$ | 1, 8, 14, 22, 29,37, 45,51, 5,69, 75,83, 91,98, 106,112, 119,129, 135,143, 151,158, 166,172, 182,190, 196,204, 211,219, 227,233 |

Table 18: Virtex Pin-out Tables (BGA)

| Pin Name | Device | BG256 | BG352 | BG432 | BG560 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| GCK0 | All | Y11 | AE13 | AL16 | AL17 |
| GCK1 | All | Y10 | AF14 | AK16 | AJ17 |
| GCK2 | All | A10 | B14 | A16 | D17 |
| GCK3 | All | B10 | D14 | D17 | A17 |
| M0 | All | Y1 | AD24 | AH28 | AJ29 |
| M1 | All | U3 | AB23 | AH29 | AK30 |
| M2 | All | W2 | AC23 | AJ28 | AN32 |
| CCLK | All | B19 | C3 | D4 | C4 |
| PROGRAM | All | Y20 | AC4 | AH3 | AM1 |
| DONE | All | W19 | AD3 | AH4 | AJ5 |
| $\overline{\text { INIT }}$ | All | U18 | AD2 | AJ2 | AH5 |
| BUSY/DOUT | All | D18 | E4 | D3 | D4 |
| DO/DIN | All | C19 | D3 | C2 | E4 |
| D1 | All | E20 | G1 | K4 | K3 |
| D2 | All | G19 | J3 | K2 | L4 |
| D3 | All | J19 | M3 | P4 | P3 |
| D4 | All | M19 | R3 | V4 | W4 |
| D5 | All | P19 | U4 | AB1 | AB5 |
| D6 | All | T20 | V3 | AB3 | AC4 |
| D7 | All | V19 | AC3 | AG4 | AJ4 |
| $\overline{\text { WRITE }}$ | All | A19 | D5 | B4 | D6 |
| $\overline{\overline{C S}}$ | All | B18 | C4 | D5 | A2 |
| TDI | All | C17 | B3 | B3 | D5 |
| TDO | All | A20 | D4 | C4 | E6 |
| TMS | All | D3 | D23 | D29 | B33 |
| TCK | All | A1 | C24 | D28 | E29 |
| DXN | All | W3 | AD23 | AH27 | AK29 |
| DXP | All | V4 | AE24 | AK29 | AJ28 |

Table 18: Virtex Pin-out Tables (BGA) (Continued)

| Pin Name | Device | BG256 | BG352 | BG432 | BG560 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {CCINT }}$ <br> ( $\mathrm{V}_{\mathrm{CCINT}}$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) | XCV50/100 | $\begin{aligned} & \hline \text { C10, D6, } \\ & \text { D15, F4, } \\ & \text { F17, L3, } \\ & \text { L18, R4, } \\ & \text { R17, U6, } \\ & \text { U15, V10 } \end{aligned}$ |  |  |  |
|  | XCV150/200/300 |  | A20, C14, D10, J24, K4, P2, P25, V24, W2, AC10, AE14, AE19, B16, D12, L1, L25, R23, T1, AF11, AF16 | $\begin{gathered} \text { A10, A17, } \\ \text { B23, C14, } \\ \text { C19, K3, } \\ \text { K29, N2, } \\ \text { N29, T1, } \\ \text { T29, W2, } \\ \text { W31, AB2, } \\ \text { AB30, AJ10, } \\ \text { AJ16, AK13, } \\ \text { AK19, AK22 } \end{gathered}$ |  |
|  | XCV400/600 |  |  | $\begin{gathered} \ldots+\text { B26, C7, } \\ \text { F1, F30 } \\ \text { AE29, AF1, } \\ \text { AH8, AH24 } \end{gathered}$ | $\begin{gathered} \text { A21, B14, } \\ \text { B18, B28, } \\ \text { C24, E9, } \\ \text { E12, F2, } \\ \text { H30, J1, } \\ \text { K32, N1, } \\ \text { N33, U5, } \\ \text { U30, Y2, } \\ \text { Y31, AD2, } \\ \text { AD32, AG3, } \\ \text { AG31, AK8, } \\ \text { AK11, AK17, } \\ \text { AK20, AL14, } \\ \text { AL27, AN25 } \end{gathered}$ |
|  | XCV800/1000 |  |  |  | $\begin{gathered} \hline \ldots+\text { B12, C22, } \\ \text { M3, N29, } \\ \text { AB2, AB32, } \\ \text { AJ13, AL22, } \end{gathered}$ |
| $\mathrm{V}_{\mathrm{CcO}}$, Bank 0 | All | D7, D8 | $\begin{gathered} \text { A17, B25, } \\ \text { D19 } \end{gathered}$ | $\begin{gathered} \text { A21, C29, } \\ \text { D21 } \end{gathered}$ | $\begin{gathered} \text { A22, A26, } \\ \text { A30, B19, } \\ \text { B32 } \end{gathered}$ |
| $\mathrm{V}_{\mathrm{CCO}}$, Bank 1 | All | D13, D14 | $\begin{gathered} \hline \text { A10, D7, } \\ \text { D13 } \end{gathered}$ | $\begin{gathered} \text { A1, A11, } \\ \text { D11 } \end{gathered}$ | $\begin{gathered} \text { A10, A16, } \\ \text { B13, C3, } \\ \text { E5 } \end{gathered}$ |
| $\mathrm{V}_{\mathrm{CcO}}$, Bank 2 | All | G17, H17 | $\begin{gathered} \mathrm{B} 2, \mathrm{H} 4, \\ \mathrm{~K} 1 \end{gathered}$ | $\begin{gathered} \text { C3, L1 } \\ \text { L4 } \end{gathered}$ | $\begin{gathered} \text { B2, D1, } \\ \text { H1, M1, } \\ \text { R2 } \end{gathered}$ |
| V ${ }_{\text {cco }}$, Bank 3 | All | N17, P17 | $\begin{gathered} \hline \text { P4, U1 } \\ \text { Y4 } \end{gathered}$ | $\begin{gathered} \text { AA1, AA4, } \\ \text { AJ3 } \end{gathered}$ | $\begin{gathered} \text { V1, AA2, } \\ \text { AD1, AK1, } \\ \text { AL2 } \end{gathered}$ |
| $\mathrm{V}_{\text {Cco }}$, Bank 4 | All | U13, U14 | $\begin{gathered} \text { AC8, AE2, } \\ \text { AF10 } \end{gathered}$ | $\mathrm{AH} 11, \mathrm{AL} 1,$ <br> AL11 | AM2, AM15, AN4, AN8, AN12 |

Table 18: Virtex Pin-out Tables (BGA) (Continued)

| Pin Name | Device | BG256 | BG352 | BG432 | BG560 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {CCO }}$, Bank 5 | All | U7, U8 | $\begin{gathered} \text { AC14, AC20, } \\ \text { AF17 } \end{gathered}$ | $\begin{gathered} \text { AH21, AJ29, } \\ \text { AL21 } \end{gathered}$ | $\begin{gathered} \text { AL31, AM21, } \\ \text { AN18, AN24, } \\ \text { AN30 } \end{gathered}$ |
| $\mathrm{V}_{\mathrm{CcO}}$, Bank 6 | All | N4, P4 | $\begin{gathered} \text { U26, W23, } \\ \text { AE25 } \end{gathered}$ | $\begin{gathered} \text { AA28, AA31, } \\ \text { AL31 } \end{gathered}$ | $\begin{gathered} \hline \text { W32, AB33, } \\ \text { AF33, AK33, } \\ \text { AM32 } \end{gathered}$ |
| $\mathrm{V}_{\text {cco }}$, Bank 7 | All | G4, H4 | $\begin{gathered} \text { G23, K26, } \\ \text { N23 } \end{gathered}$ | $\begin{gathered} \text { A31, L28, } \\ \text { L31 } \end{gathered}$ | $\begin{gathered} \text { C32, D33, } \\ \text { K33, N32, } \\ \text { T33 } \end{gathered}$ |
| $\mathrm{V}_{\text {REF }}$, Bank 0 <br> (VREF pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) <br> Within each bank, if input reference voltage is not required, all $V_{\text {REF }}$ pins are general I/O. | XCV50 | A8, B4 |  |  |  |
|  | XCV100/150 | $\ldots+$ A4 | $\begin{gathered} \text { A16,C19, } \\ \text { C21 } \end{gathered}$ |  |  |
|  | XCV200/300 |  | $\ldots+$ D21 | $\begin{aligned} & \hline \text { B19, D22, } \\ & \text { D24. D26 } \end{aligned}$ |  |
|  | XCV400 |  | $\ldots+\mathrm{B15}$ | $\ldots+$ C18 | $\begin{gathered} \hline \text { A19, D20, } \\ \text { D26, E23, } \\ \text { E27 } \end{gathered}$ |
|  | XCV600 |  |  | $\ldots+\mathrm{C} 24$ | $\ldots+\mathrm{E} 24$ |
|  | XCV800 |  |  | $\ldots+\mathrm{B} 21$ | $\ldots+$ E21 |
|  | XCV1000 |  |  |  | $\ldots+$ D29 |
| $\mathrm{V}_{\text {REF }}$, Bank 1 <br> (VREF pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) <br> Within each bank, if input reference voltage is not required, all $V_{\text {REF }}$ pins are general I/O. | XCV50 | A17, B12 |  |  |  |
|  | XCV100/150 | $\ldots+$ B15 | $\begin{gathered} \text { B6, C9, } \\ \text { C12 } \end{gathered}$ |  |  |
|  | XCV200/300 |  | ... + D6 | $\begin{aligned} & \mathrm{A} 13, \mathrm{~B} 7, \\ & \mathrm{C} 6, \mathrm{C} 10 \end{aligned}$ |  |
|  | XCV400 |  | $\ldots+$ C13 | $\ldots+$ B15 | $\begin{gathered} \text { A6, D7, } \\ \text { D11, D16, } \\ \text { E15 } \end{gathered}$ |
|  | XCV600 |  |  | $\ldots+$ D10 | $\ldots+$ D10 |
|  | XCV800 |  |  | $\ldots+\mathrm{B12}$ | $\ldots+$ D13 |
|  | XCV1000 |  |  |  | $\ldots+$ E7 |
| $\mathrm{V}_{\text {REF }}$, Bank 2 <br> ( $\mathrm{V}_{\text {REF }}$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) <br> Within each bank, if input reference voltage is not required, all $\mathrm{V}_{\text {REF }}$ pins are general I/O. | XCV50 | C20, J18 |  |  |  |
|  | XCV100/150 | $\ldots+$ F19 | E2, H2, <br> M4 |  |  |
|  | XCV200/300 |  | $\ldots+\mathrm{D} 2$ | $\begin{gathered} \text { E2, G3, } \\ \text { J2, N1 } \end{gathered}$ |  |
|  | XCV400 |  | $\ldots+\mathrm{M} 1$ | $\ldots+\mathrm{R} 3$ | $\begin{gathered} \text { G5, H4 } \\ \text { L5, P4 } \\ \text { R1 } \end{gathered}$ |
|  | XCV600 |  |  | $\ldots+\mathrm{H} 1$ | $\ldots+\mathrm{K} 5$ |
|  | XCV800 |  |  | $\ldots+$ M3 | $\ldots+$ N5 |
|  | XCV1000 |  |  |  | $\ldots+$ B3 |

Table 18: Virtex Pin-out Tables (BGA) (Continued)

| Pin Name | Device | BG256 | BG352 | BG432 | BG560 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {REF }}$, Bank 3 <br> ( $\mathrm{V}_{\text {REF }}$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) | XCV50 | M18, V20 |  |  |  |
|  | XCV100/150 | $\ldots$ + R19 | $\begin{gathered} \mathrm{R} 4, \mathrm{~V} 4, \\ \text { Y3 } \end{gathered}$ |  |  |
|  | XCV200/300 |  | $\ldots+$ AC2 | $\begin{aligned} & \text { V2, AB4, } \\ & \text { AD4, AF3 } \end{aligned}$ |  |
| Within each bank, if input reference voltage is not required, all $\mathrm{V}_{\text {REF }}$ pins are general I/O. | XCV400 |  | . + R1 | $\ldots+\mathrm{U} 2$ | $\begin{gathered} \text { V4, W5, } \\ \text { AD3, AE5, } \\ \text { AK2 } \end{gathered}$ |
|  | XCV600 |  |  | $\ldots+$ AC3 | $\ldots+\mathrm{AF} 1$ |
|  | XCV800 |  |  | $\ldots+\mathrm{Y} 3$ | $\ldots$ + AA4 |
|  | XCV1000 |  |  |  | $\ldots+\mathrm{AH} 4$ |
| $\mathrm{V}_{\text {REF }}$, Bank 4 | XCV50 | V12, Y18 |  |  |  |
| ( $\mathrm{V}_{\text {REF }}$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) | XCV100/150 | $\ldots+$ W15 | $\begin{gathered} \text { AC12, AE5, } \\ \text { AE8, } \end{gathered}$ |  |  |
|  | XCV200/300 |  | $\ldots$ + AE4 | $\begin{aligned} & \text { AJ7, AL4, } \\ & \text { AL8, AL13 } \end{aligned}$ |  |
| Within each bank, if input reference voltage is not required, all $\mathrm{V}_{\text {REF }}$ pins are general I/O. | XCV400 |  | $\ldots+$ AF12 | $\ldots+$ AK15 | AL7, AL10, AL16, AM4, AM14 |
|  | XCV600 |  |  | ... + AK8 | ... + AL9 |
|  | XCV800 |  |  | $\ldots+$ AJ12 | $\ldots+$ AK13 |
|  | XCV1000 |  |  |  | $\ldots+$ AN3 |
| $\mathrm{V}_{\text {REF }}$, Bank 5 | XCV50 | V9, Y3 |  |  |  |
| ( $\mathrm{V}_{\text {REF }}$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) | XCV100/150 | $\ldots+$ W6 | $\begin{gathered} \text { AC15, AC18, } \\ \text { AD20 } \end{gathered}$ |  |  |
|  | XCV200/300 |  | $\ldots+$ AE23 | AJ18, AJ25, AK23, AK27 |  |
|  | XCV400 |  | $\ldots+$ AF15 | ... + AJ17 | $\begin{gathered} \text { AJ18, AJ25, } \\ \text { AL20, AL24, } \\ \text { AL29 } \end{gathered}$ |
| Within each bank, if input reference voltage is not required, all $\mathrm{V}_{\text {REF }}$ pins are general I/O. | XCV600 |  |  | $\ldots+$ AL24 | $\ldots+$ AM26 |
|  | XCV800 |  |  | $\ldots+$ AH19 | $\ldots+$ AN23 |
|  | XCV1000 |  |  |  | $\ldots+$ AK28 |
| $\mathrm{V}_{\text {REF }}$, Bank 6 | XCV50 | M2, R3 |  |  |  |
| ( $\mathrm{V}_{\text {REF }}$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) | XCV100/150 | $\ldots+\mathrm{T} 1$ | $\begin{gathered} \text { R24, Y26, } \\ \text { AA25, } \end{gathered}$ |  |  |
|  | XCV200/300 |  | ... + AD26 | $\begin{aligned} & \text { V28, AB28, } \\ & \text { AE30, AF28 } \end{aligned}$ |  |
|  | XCV400 |  | $\ldots+$ P24 | ... + U28 | $\begin{gathered} \text { V29, Y32, } \\ \text { AD31, AE29, } \\ \text { AK32 } \end{gathered}$ |
| Within each bank, if input reference voltage is not required, all $V_{\text {REF }}$ pins are general I/O. | XCV600 |  |  | $\ldots+$ AC28 | $\ldots+$ AE31 |
|  | XCV800 |  |  | $\ldots+\mathrm{Y} 30$ | $\ldots+$ AA30 |
|  | XCV1000 |  |  |  | $\ldots+$ AH30 |

Table 18: Virtex Pin-out Tables (BGA) (Continued)

| Pin Name | Device | BG256 | BG352 | BG432 | BG560 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {REF }}$, Bank 7 <br> ( $V_{\text {REF }}$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) | XCV50 | G3, H1 |  |  |  |
|  | XCV100/150 | $\ldots+$ D1 | $\begin{gathered} \hline \text { D26, G26, } \\ \text { L26 } \end{gathered}$ |  |  |
|  | XCV200/300 |  | ... + E24 | $\begin{aligned} & \hline \text { F28, F31, } \\ & \text { J30, N30 } \end{aligned}$ |  |
| Within each bank, if input reference voltage is not required, all $V_{\text {REF }}$ pins are general I/O. | XCV400 |  | $\ldots+$ M25 | $\ldots+$ R31 | $\begin{gathered} \text { E31, G31, } \\ \text { K31, P31, } \\ \text { T31 } \end{gathered}$ |
|  | XCV600 |  |  | ... + J28 | $\ldots+$ H32 |
|  | XCV800 |  |  | ... + M28 | ... + L33 |
|  | XCV1000 |  |  |  | ... + D31 |
| GND | All | C3, C18, <br> D4, D5, <br> D9, D10, <br> D11, D12, <br> D16, D17. <br> E4, E17, <br> J4, J17, <br> K4, K17, <br> L4, L17, <br> M4, M17, <br> T4, T17, <br> U4, U5, <br> U9, U10, <br> U11, U12, <br> U16, U17, <br> V3, V18 | A1, A2, <br> A5, A8, <br> A14, A19, <br> A22, A25, <br> A26, B1, <br> B26, E1, <br> E26, H1, <br> H26, N1, <br> P26, W1, <br> W26, AB1, <br> AB26, AE1, <br> AE26, AF1, <br> AF2, AF5, <br> AF8, AF13, <br> AF19, AF22, <br> AF25, AF26 | A2, A3, <br> A7, A9, <br> A14, A18, <br> A23, A25, <br> A29, A30, <br> B1, B2, <br> B30, B31, <br> C1, C31, <br> D16, G1, <br> G31, J1, <br> J31, P1, <br> P31, T4, <br> T28, V1, <br> V31, AC1, <br> AC31, AE1, <br> AE31, AH16, <br> AJ1, AJ31, <br> AK1, AK2, <br> AK30, AK31, <br> AL2, AL3, <br> AL7, AL9 <br> AL14, AL18 <br> AL23, AL25, <br> AL29, AL30 | A1, A7, A12, A14, A18, A20, A24, A29, A32, A33, B1, B6, B9, B15, B23, B27, B31, C2, E1, F32, G2, G33, J32, K1, L2, M33, P1, P33, R32, T1, V33, W2, Y1, Y33, AB1, AC32, AD33, AE2, AG1, AG32, AH2, AJ33, AL32, AM3, AM7, AM11, AM1, AM25, AM28, AM33, AN1, AN2, AN5, AN10, AN14, AN16, AN20, AN22, AN27, AN33 |
| GND* | All | $\begin{gathered} \mathrm{J} 9, \mathrm{~J} 10, \\ \mathrm{~J} 11, \mathrm{~J} 12, \\ \mathrm{~K} 9, \mathrm{~K} 10, \\ \mathrm{~K} 11, \mathrm{~K} 12, \\ \mathrm{~L} 9, \mathrm{~L} 10, \\ \mathrm{~L} 11, \mathrm{~L} 12, \\ \text { M9, M10, } \\ \text { M11, M12 } \end{gathered}$ |  |  |  |

Table 18: Virtex Pin-out Tables (BGA) (Continued)

| Pin Name | Device | BG256 | BG352 | BG432 | BG560 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| No Connect |  |  |  |  | C31, AC2, |
|  |  |  |  | AK4, AL3 |  |

* 16 extra balls (grounded) at package center.

Table 19: Virtex Pin-out Tables (Fine-pitch BGA)

| Pin Name | Device | FG256 | FG456 | FG676 | FG680 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| GCK0 | All | N8 | W12 | AA14 | AW19 |
| GCK1 | All | R8 | Y11 | AB13 | AU22 |
| GCK2 | All | C9 | A11 | C13 | D21 |
| GCK3 | All | B8 | C11 | E13 | A20 |
| M0 | All | N3 | AB2 | AD4 | AT37 |
| M1 | All | P2 | U5 | W7 | AU38 |
| M2 | All | R3 | Y4 | AB6 | AT35 |
| CCLK | All | D15 | B22 | D24 | E4 |
| PROGRAM | All | P15 | W20 | AA22 | AT5 |
| DONE | All | R14 | Y19 | AB21 | AU5 |
| $\overline{\text { INIT }}$ | All | N15 | V19 | Y21 | AU2 |
| BUSY/DOUT | All | C15 | C21 | E23 | E3 |
| D0/DIN | All | D14 | D20 | F22 | C2 |
| D1 | All | E16 | H22 | K24 | P4 |
| D2 | All | F15 | H2O | K22 | P3 |
| D3 | All | G16 | K20 | M22 | R1 |
| D4 | All | J16 | N22 | R24 | AD3 |
| D5 | All | M16 | R21 | U23 | AG2 |
| D6 | All | N16 | T22 | V24 | AH1 |
| D7 | All | N14 | Y21 | AB23 | AR4 |
| $\overline{\text { WRITE }}$ | All | C13 | A20 | C22 | B4 |
| $\overline{\mathrm{CS}}$ | All | B13 | C19 | E21 | D5 |
| TDI | All | A15 | B20 | D22 | B3 |
| TDO | All | B14 | A21 | C23 | C4 |
| TMS | All | D3 | D3 | F5 | E36 |
| TCK | All | C4 | C4 | E6 | C36 |
| DXN | All | R4 | Y5 | AB7 | AV37 |
| DXP | All | P4 | V6 | Y8 | AU35 |
| $\mathrm{V}_{\text {CCINT }}$ | All | C3, C14, <br> D4, D13, <br> E5, E12, <br> M5, M12, <br> N4, N13, <br> P3, P14 | E5, E18, F6, F17, G7, G8, <br> G9, G14, <br> G15, G16, <br> H7, H16, <br> J7, J16, <br> P7, P16, <br> R7, R16, <br> T7, T8, <br> T9, T14, <br> T15, T16, <br> U6, U17, <br> V5, V18 | G7, G20, H8, H19, J9, J10, J11, J16, J17, J18, K9, K18, L9, L18, T9, T18, U9, U18, V9, V10, V11, V16, V17, V18, W8, W19, Y7, Y20 | AD5, AD35, AE5, AE35, AL5, AL35, AM5, AM35, AR8, AR9, AR15, AR16, AR24, AR25, AR31, AR32, E8, E9, E15, E16, E24, E25, E31, E32, H5, H35, J5, J35, R5, R35, T5, T35 |

Table 19: Virtex Pin-out Tables (Fine-pitch BGA) (Continued)

| Pin Name | Device | FG256 | FG456 | FG676 | FG680 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {Cco }}$, Bank 0 | All | E8, F8 | $\begin{aligned} & \text { F7, F8, } \\ & \text { F9, F10 } \\ & \text { G10, G11 } \end{aligned}$ | $\begin{aligned} & \hline \mathrm{H} 9, \mathrm{H} 10, \mathrm{H} 11, \\ & \mathrm{H} 12, \mathrm{~J} 12, \mathrm{~J} 13 \end{aligned}$ | $\begin{aligned} & \hline \text { E26, E27, E29, } \\ & \text { E30, E33, E34 } \end{aligned}$ |
| $\mathrm{V}_{\text {Cco }}$, Bank 1 | All | E9, F9 | $\begin{aligned} & \text { F13, F14, } \\ & \text { F15, F16, } \\ & \text { G12, G13 } \end{aligned}$ | $\begin{gathered} \hline \text { H15, H16, H17, } \\ \text { H18, J14, J15 } \end{gathered}$ | $\begin{gathered} \text { E6, E7, E10, } \\ \text { E11, E13, E14 } \end{gathered}$ |
| $\mathrm{V}_{\mathrm{CcO}}$, Bank 2 | All | H11, H12 | $\begin{aligned} & \hline \text { G17, H17, } \\ & \text { J17, K16, } \\ & \text { K17, L16 } \end{aligned}$ | $\begin{aligned} & \text { J19, K19, L19, } \\ & \text { M18, M19, N18 } \end{aligned}$ | $\begin{aligned} & \hline \text { F5, G5, } \\ & \text { K5, L5, } \\ & \text { N5, P5 } \end{aligned}$ |
| $\mathrm{V}_{\text {Cco }}$, Bank 3 | All | J11, J12 | $\begin{aligned} & \hline \text { M16, N16, } \\ & \text { N17, P17, } \\ & \text { R17, T17 } \end{aligned}$ | $\begin{gathered} \hline \text { P18, R18, R19, } \\ \text { T19, U19, V19 } \end{gathered}$ | AF5, AG5, AN5, AK5, AJ5, AP5 |
| $\mathrm{V}_{\mathrm{CcO}}$, Bank 4 | All | L9. M9 | $\begin{aligned} & \text { T12, T13, } \\ & \text { U13, U14, } \\ & \text { U15, U16, } \end{aligned}$ | V14, V15, W15, W16, W17, W18 | AR6, AR7, AR10, AR11, AR13, AR14 |
| $\mathrm{V}_{\text {Cco }}$, Bank 5 | All | L8, M8 | $\begin{gathered} \hline \text { T10, T11, } \\ \text { U7, U8, } \\ \text { U9, U10 } \end{gathered}$ | V12, V13, W9,W10, W11, W12 | AR26, AR27, AR29, AR30, AR33, AR34 |
| $\mathrm{V}_{\text {Cco }}$, Bank 6 | All | J5, J6 | $\begin{aligned} & \text { M7, N6, } \\ & \text { N7, P6, } \\ & \text { R6, T6 } \end{aligned}$ | $\begin{gathered} \hline \text { P9, R8, R9, T8, } \\ \text { U8, V8 } \end{gathered}$ | AF35, AG35, AJ35, AK35, AN35, AP35 |
| $\mathrm{V}_{\text {Cco }}$, Bank 7 | All | H5, H6 | $\begin{aligned} & \text { G6, H6, } \\ & \text { J6, K6, } \\ & \text { K7, L7 } \end{aligned}$ | $\begin{aligned} & \hline \text { J8, K8, L8, M8, } \\ & \text { M9, N9 } \end{aligned}$ | F35, G35, K35, L35, N35, P35 |
| $\mathrm{V}_{\text {REF }}$, Bank 0 <br> (VREF pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) <br> Within each bank, if input reference voltage is not required, all $V_{\text {REF }}$ pins are general I/O. | XCV50 | B4, B7 |  |  |  |
|  | XCV100/150 | ... + C6 | $\begin{gathered} \text { A9, C6, } \\ \text { E8 } \end{gathered}$ |  |  |
|  | XCV200/300 | $\ldots+$ A3 | ... + B4 |  |  |
|  | XCV400 |  |  | $\begin{gathered} \text { A12, C11, D6, } \\ \text { E8, G10 } \end{gathered}$ |  |
|  | XCV600 |  |  | ...+B7 | $\begin{aligned} & \text { A33, B28, B30, } \\ & \text { C23, C24, D33 } \end{aligned}$ |
|  | XCV800 |  |  | ...+B10 | ...+A26 |
|  | XCV1000 |  |  |  | ...+D34 |
| $\mathrm{V}_{\text {REF }}$, Bank 1 <br> (VREF pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) <br> Within each bank, if input reference voltage is not required, all $\mathrm{V}_{\text {REF }}$ pins are general I/O. | XCV50 | B9, C11 |  |  |  |
|  | XCV100/150 | ... + E11 | $\begin{gathered} \text { A18, B13, } \\ \text { E14 } \end{gathered}$ |  |  |
|  | XCV200/300 | $\ldots+$ A14 | $\ldots+$ A19 |  |  |
|  | XCV400 |  |  | $\begin{gathered} \text { A14, C20, C21, } \\ \text { D15, G16 } \end{gathered}$ |  |
|  | XCV600 |  |  | ...+B19 | $\begin{gathered} \text { B6, B8, B18, } \\ \text { D11, D13, D17 } \end{gathered}$ |
|  | XCV800 |  |  | $\ldots+$ A17 | ...+B14 |
|  | XCV1000 |  |  |  | ...+B5 |

Table 19: Virtex Pin-out Tables (Fine-pitch BGA) (Continued)

| Pin Name | Device | FG256 | FG456 | FG676 | FG680 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {REF }}$, Bank 2 <br> ( $\mathrm{V}_{\text {REF }}$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) | XCV50 | F13, H13 |  |  |  |
|  | XCV100/150 | $\ldots+$ F14 | $\begin{gathered} \mathrm{F} 21, \mathrm{H} 18, \\ \mathrm{~K} 21 \end{gathered}$ |  |  |
|  | XCV200/300 | $\ldots+$ E13 | $\ldots$ + D22 |  |  |
|  | XCV400 |  |  | $\begin{gathered} \text { F24, H23, K20, } \\ \text { M23, M26 } \end{gathered}$ |  |
| Within each bank, if input reference voltage is not required, all $\mathrm{V}_{\text {REF }}$ pins are general I/O. | XCV600 |  |  | ...+G26 | $\begin{gathered} \text { G1, H4, J1, L2, } \\ \text { V5, W3 } \end{gathered}$ |
|  | XCV800 |  |  | ...+K25 | $\ldots+\mathrm{N} 1$ |
|  | XCV1000 |  |  |  | $\ldots+$ D2 |
| $\mathrm{V}_{\text {REF }}$, Bank 3 | XCV50 | K16, L14 |  |  |  |
| ( $\mathrm{V}_{\text {REF }}$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) | XCV100/150 | $\ldots$ + L13 | N21, R19, U21 |  |  |
|  | XCV200/300 | $\ldots+\mathrm{M} 13$ | $\ldots+\mathrm{U} 20$ |  |  |
|  | XCV400 |  |  | $\begin{aligned} & \text { R23, R25, U21, } \\ & \text { W22, W23 } \end{aligned}$ |  |
| Within each bank, if input reference voltage is not required, all $\mathrm{V}_{\text {REF }}$ pins are general I/O. | XCV600 |  |  | $\ldots+\mathrm{W} 26$ | AC1, AJ2, AK3, AL4, AR1, Y1 |
|  | XCV800 |  |  | ...+U25 | $\ldots+$ AF3 |
|  | XCV1000 |  |  |  | $\ldots+$ AP4 |
| $V_{\text {REF }}$, Bank 4 <br> ( $\mathrm{V}_{\text {REF }}$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) <br> Within each bank, if input reference voltage is not required, all $\mathrm{V}_{\text {REF }}$ pins are general I/O. | XCV50 | P9, T12 |  |  |  |
|  | XCV100/150 | $\ldots+$ T11 | $\begin{gathered} \text { AA13, AB16 } \\ \text { AB19 } \end{gathered}$ |  |  |
|  | XCV200/300 | $\ldots+\mathrm{R} 13$ | $\ldots+$ AB20 |  |  |
|  | XCV400 |  |  | $\begin{gathered} \text { AC15, AD18, } \\ \text { AD21, AD22, } \\ \text { AF15 } \end{gathered}$ |  |
|  | XCV600 |  |  | ...AF20 | AT19, AU7, AU17, AV8, AV10, AW11 |
|  | XCV800 |  |  | ...AF17 | $\ldots+$ AV14 |
|  | XCV1000 |  |  |  | ...AU6 |
| $\mathrm{V}_{\text {REF }}$, Bank 5 <br> $\left(V_{\text {REF }}\right.$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) <br> Within each bank, if input reference voltage is not required, all $\mathrm{V}_{\text {REF }}$ pins are general I/O. | XCV50 | T4, P8 |  |  |  |
|  | XCV100/150 | $\ldots+\mathrm{R} 5$ | $\begin{gathered} \text { W8, Y10, } \\ \text { AA5 } \end{gathered}$ |  |  |
|  | XCV200/300 | $\ldots+$ T2 | $\ldots+\mathrm{Y} 6$ |  |  |
|  | XCV400 |  |  | AA10, AB8, AB12, AC7, AF12 |  |
|  | XCV600 |  |  | ...AF8 | AT27, AU29, AU31, AV35, AW21, AW23 |
|  | XCV800 |  |  | $\ldots+$ AE10 | ...+AT25 |
|  | XCV1000 |  |  |  | ...+AV36 |

Table 19: Virtex Pin-out Tables (Fine-pitch BGA) (Continued)

| Pin Name | Device | FG256 | FG456 | FG676 | FG680 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {REF }}$, Bank 6 <br> ( $V_{\text {REF }}$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) | XCV50 | J3, N1 |  |  |  |
|  | XCV100/150 | $\ldots+\mathrm{M} 1$ | $\begin{gathered} \mathrm{N} 2, \mathrm{R} 4, \\ \mathrm{~T} 3 \end{gathered}$ |  |  |
|  | XCV200/300 | $\ldots+\mathrm{N} 2$ | $\ldots+\mathrm{Y} 1$ |  |  |
|  | XCV400 |  |  | $\begin{gathered} \text { AB3, R1, R4, U6, } \\ \text { V5 } \end{gathered}$ |  |
| Within each bank, if input reference voltage is not required, all $\mathrm{V}_{\text {REF }}$ pins are general I/O. | XCV600 |  |  | $\ldots+\mathrm{Y} 1$ | AB35, AD37, AH39, AK39, AM39, AN36 |
|  | XCV800 |  |  | ...+U2 | ...+AE39 |
|  | XCV1000 |  |  |  | ...+AT39 |
| $V_{\text {REF }}$, Bank 7 <br> ( $\mathrm{V}_{\text {REF }}$ pins are listed incrementally. Connect all pins listed for both the required device and all smaller devices listed in the same package.) | XCV50 | C1, H3 |  |  |  |
|  | XCV100/150 | $\ldots+$ D1 | $\begin{gathered} \mathrm{E} 2, \mathrm{H} 4, \\ \mathrm{~K} 3 \end{gathered}$ |  |  |
|  | XCV200/300 | $\ldots+\mathrm{B1}$ | $\ldots+$ D2 |  |  |
|  | XCV400 |  |  | $\begin{gathered} \text { F4, G4, K6, M2, } \\ \text { M5 } \end{gathered}$ |  |
| Within each bank, if input reference voltage is not required, all $\mathrm{V}_{\text {REF }}$ pins are general I/O. | XCV600 |  |  | $\ldots+\mathrm{H} 1$ | $\begin{aligned} & \text { E38, G38, L36, } \\ & \text { N36, U36, U38 } \end{aligned}$ |
|  | XCV800 |  |  | ...+K1 | ...+N38 |
|  | XCV1000 |  |  |  | ...+F36 |

Table 19: Virtex Pin-out Tables (Fine-pitch BGA) (Continued)

| Pin Name | Device | FG256 | FG456 | FG676 | FG680 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| GND | All | A1, A16, B2, B15, F6, F7, <br> F10, F11, <br> G6, G7, <br> G8, G9, <br> G10, G11, <br> H7, H8, <br> H9, H10, <br> J7, J8, <br> J9, J10, <br> K6, K7, <br> K8, K9, <br> K10, K11, <br> L6, L7, <br> L10, L11, <br> R2, R15, <br> T1, T16 | $\begin{gathered} \hline \text { A1, A22, } \\ \text { B2, B21, } \\ \text { C3, C20, } \\ \text { J9, J10, } \\ \text { J11, J12, } \\ \text { J13, J14, } \\ \text { K9, K10, } \\ \text { K11, K12, } \\ \text { K13, K14, } \\ \text { L9, L10, } \\ \text { L11, L12, } \\ \text { L13, L14, } \\ \text { M9, M10, } \\ \text { M11, M12, } \\ \text { M13, M14, } \\ \text { N9, N10, } \\ \text { N11, N12, } \\ \text { N13, N14, } \\ \text { P9, P10, } \\ \text { P11, P12, } \\ \text { P13, P14, } \\ \text { Y3, Y20, } \\ \text { AA2, AA21, } \\ \text { AB1, AB22 } \end{gathered}$ | A1, A26, B2, B9, B14, B18, B25, C3, C24, D4, D23, E5, E22, J2, J25, K10, K11, K12, K13, K14, K15, K16, K17, L10, L11, L12, L13, L14, L15, L16, L17, M10, M11, M12, M13, M14, M15, M11, M17, N2, N10, N11, N12, N13, N14, N15, N16, N17, P10, P11, P12, P13, P14, P15, P16, P17, P25, R10, R11, R12, R13, R14, R15, R16, R17, T10, T11, T12, T13, 114, T15, T1, T17, U10, U11, U12, U13, U14, U15, U16, U17, V2, V25, AB5, AB22, AC4, AC23, AD3, AD24, AE2, AE9, AE13, AE18, AE25, AF1, AF26 | A1, A2, A3, A37, A38, A39, AA5, AA35, AH4, AH5, AH35, AH36, AR5, AR12, AR19, AR20, AR21, AR28, AR35, AT4, AT12, AT20, AT28, AT36, AU1, AU3, AU20, AU37, AU39, AV1, AV2, AV38, AV39, AW1, AW2, AW3, AW37, AW38, AW39, B1, B2, B38, B39, C1, C3, C20, C37, C39, D4, D12, D20, D28, D36, E5, E12, E19, E20, E21, E28, E35, M4, M5, M35, M36, W5, W35, Y3, Y4, Y5, Y35, Y36, Y37 |

Table 19: Virtex Pin-out Tables (Fine-pitch BGA) (Continued)

| Pin Name | Device | FG256 | FG456 | FG676 | FG680 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| No Connect <br> (No-connect pins are listed incrementally. All pins listed for both the required device and all larger devices listed in the same package are no connects.) | XCV800 |  |  | A2, A3, A15, A25, B1, B6, B11, B16, B21, B24, B26, C1, C2, C25, C26, F2, F6, F21, F25, L2, L25, N25, P2, T2, T25, AA2, AA6, AA21, AA25, AD1, AD2, AD25, AE1, AE3, AE6, AE11, AE14, AE16, AE21, AE24, AE26, AF2, AF24, AF25 |  |
|  | XCV600 |  |  | ... |  |
|  | XCV400 |  |  | A9, A10, A13, A16, A24, AC1, AC25, AE12, AE15, AF3, AF10, AF11, AF13, AF14, AF16, AF18, AF23, B4, B12, B13, B15, B17, D1, D25, H26, J1, K26, L1, M1, M25, N1, N26, P1, P26, R2, R26, T1, T26, U26, V1 |  |
|  | XCV300 |  | D4, D19, W4, W19 |  |  |
|  | XCV200 |  | ... + A2, A6, <br> A12, B11, <br> B16, C2, <br> D1, D18, <br> E17, E19, <br> G2, G22, <br> L2, L19, <br> M2, M21, <br> R3, R20, <br> U3, U18, <br> Y22, AA1, <br> AA3, AA11, <br> AA16, AB7, <br> AB12, AB21, | ... |  |

Table 19: Virtex Pin-out Tables (Fine-pitch BGA) (Continued)

| Pin Name | Device | FG256 | FG456 | FG676 | FG680 |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | XCV150 |  | $\begin{gathered} \hline \ldots+\text { A13. A14, } \\ \text { C8, C9, } \\ \text { E13, F11, } \\ \text { H21, J1, } \\ \text { J4 K2, } \\ \text { K18, K19, } \\ \text { M17, N1, } \\ \text { P1, P5, } \\ \text { P22, R22, } \\ \text { W13, W15, } \\ \text { AA9, AA10, } \\ \text { AB8, AB14 } \end{gathered}$ |  |  |

## Pin-Out Diagrams

The following diagrams, page 60 through page 70, illustrate the locations of special-purpose pins on Virtex

FPGAs. Table 20 lists the symbols used in these diagrams. The diagrams also show I/O-bank boundaries.

Table 20: Pin-out Diagram Symbols

| Symbol | Pin Function |
| :---: | :---: |
| * | General I/O |
| 粯 | Device-dependent general I/O, $\mathrm{n} / \mathrm{c}$ on smaller devices |
| V | $\mathrm{V}_{\text {CCINT }}$ |
| $v$ | Device-dependent $\mathrm{V}_{\text {CCINT }}$, $\mathrm{n} / \mathrm{c}$ on smaller devices |
| O | $\mathrm{V}_{\text {cco }}$ |
| R | $\mathrm{V}_{\text {REF }}$ |
| $r$ | Device-dependent $\mathrm{V}_{\text {REF }}$, remains I/O on smaller devices |
| G | Ground |
| $\varnothing, 1,2,3$ | Global Clocks |
| (1), ©, © | M0, M1, M2 |
|  | D0/DIN, D1, D2, D3, D4, D5, D6, D7 |
| B | DOUT/BUSY |
| D | DONE |
| P | PROGRAM |
| I | INIT |
| K | CCLK |
| W | WRITE |
| S | CS |
| T | Boundary-scan Test Access Port |
| + | Temperature diode, anode |
| - | Temperature diode, cathode |
| $n$ | No connect |

## CS144 Pin Function Diagram



## TQ144 Pin Function Diagram



## PQ240/HQ240 Pin Function Diagram





$\mathrm{A} \mathrm{G} \mathrm{G} * * \operatorname{G} * * \mathrm{G} * \mathrm{O} * * * \mathrm{G} \mid * \mathrm{R} \mathrm{O} * \mathrm{G} \mathrm{V} * \mathrm{G} * * \operatorname{G\mathrm {G}} \mathrm{~A}$

$\mathrm{C} \quad * * \mathrm{~K} \mathrm{~S} * * * * \mathrm{R} * * \mathrm{R} * \mathrm{~V} * * * * \mathrm{R} * \mathrm{R} * * * \mathrm{~T} * * * \mathrm{C}$
D ＊ r （10） $\mathrm{T} \mid \mathrm{W} \mathrm{O}$ 米 $\operatorname{\mathrm {V}*} \mathrm{v} \mathrm{O} 3 * * * * \mathrm{O} * \mathrm{r} * \mathrm{~T} * * \mathrm{R} \mathrm{D}$
$\mathrm{E} \quad \mathrm{GR}$ 米 B
F $\quad$ 米 米
Bank 1
Bank 0
$\begin{array}{lll}\text {＊} r & * \mathrm{G} & \mathrm{E} \\ \text {＊} & \text { 米 } & \text { F }\end{array}$
G ① 米 米 ， Bank 0 ＊

O＊$* \mathrm{R} \quad \mathrm{G}$
$\mathrm{H} \quad \mathrm{GR}$ 号

Bank 7 ＊$*$ O K
v＊＊ 米
M 米 米（3）R
N
P
G $\mathrm{G}^{*} \mathrm{~V}$ 米
BG352
（Top View）
＊ ＊ $\mathrm{G} \quad \mathrm{H}$
＊V＊ ＊ $\square$

R ＊＊（4）R
T $\quad v$ 米 米
U O 米（5）Bank 3
V 米（6）R
$\mathrm{W} \quad \mathrm{G} V * *$
Y 米 R O
$\mathrm{AA} * * *$ 米 Bank 4
$\mathrm{AB} \quad \mathrm{G} * * * *$
$\begin{aligned} \text { Bank } 6 & \text {＊} * \text { O } \mathrm{U} \\ & \text {＊} \mathrm{V} \text {＊}\end{aligned}$
$\mathrm{AC} \quad * \mathrm{r}$ ⑦ P 米 米 $\mathrm{O} * \mathrm{~V} * \mathrm{R} * \mathrm{O} \mathrm{R} * * \mathrm{R} * \mathrm{O} * *$（2）$⿻ 丷 木 * * \mathrm{AC}$


$\mathrm{AF} \mathrm{GG} * * \mathrm{G} * * \mathrm{G} * \mathrm{O} v * \mathrm{G} \mid 1 * v \mathrm{O} * \mathrm{G} * * \operatorname{G} * * \mathrm{G} \mathrm{G} \mathrm{AF}$


## BG432 Pin Function Diagram




## BG560 Pin Function Diagram





## FG256 Pin Function Diagram



# Bank $5 \quad$ Bank 4 

## FG256 <br> (Top view)

## FG456 Pin Function Diagram



FG456
(Top view)

Bank 0
Bank 1



Note: Packages FG456 and FG676 are layout compatible.

## FG680 Pin Function Diagram



Note: AA3, AA4, and AB2 are in Bank 2
Note: AA37 is in Bank 7
fg680_12a

## Virtex Device/Package Combinations and Maximum I/O

| Package | Maximum User I/O (excluding dedicated clock pins) |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | XCV50 | XCV100 | XCV150 | XCV200 | XCV300 | XCV400 | XCV600 | XCV800 | XCV1000 |
| CS144 | 94 | 94 |  |  |  |  |  |  |  |
| TQ144 | 98 | 98 |  |  |  |  |  |  |  |
| PQ240 | 166 | 166 | 166 | 166 | 166 |  |  |  |  |
| HQ240 |  |  |  |  |  | 166 | 166 | 166 |  |
| BG256 | 180 | 180 | 180 | 180 |  |  |  |  |  |
| BG352 |  |  | 260 | 260 | 260 |  |  | 316 | 316 |
| BG432 |  |  |  |  | 316 | 316 | 304 | 404 | 404 |
| BG560 |  |  |  |  |  | 404 | 404 |  |  |
| FG256 | 176 | 176 | 176 | 176 |  |  |  |  |  |
| FG456 |  |  | 260 | 284 | 312 |  |  |  |  |
| FG676 |  |  |  |  |  | 404 | 444 | 444 |  |
| FG680 |  |  |  |  |  |  | 512 | 512 | 512 |

## Virtex Ordering Information

```
Example: XCV300 -6 PQ 240 C
```

- Temperature Range
$\mathrm{C}=$ Commercial $\left(\mathrm{T}_{J}=0^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$
$\mathrm{I}=$ Industrial $\left(\mathrm{T}_{\mathrm{J}}=-40^{\circ} \mathrm{C}\right.$ to $\left.+100^{\circ} \mathrm{C}\right)$

Number of Pins

Device Type

-5
-6


Speed Grade
-4

Package Type
$B G=$ Ball Grid Array
FG = Fine-pitch Ball Grid Array
$P Q=$ Plastic Quad Flat Pack
HQ = High Heat Dissipation QFP
TQ = Thin Quad Flat Pack
CS = Chip-scale Package

## Revision History

| Version | Description |
| :--- | :--- |
| $1.0(11 / 98)$ | Initial document release. |
| $1.2(1 / 99)$ | Updated package drawings and specs. |
| $1.3(2 / 99)$ | Update of package drawings, updated specifications. |
| $1.4(5 / 99)$ | Addition of package drawings and specifications. |
| $1.5(5 / 99)$ | Replaced FG 676 \& FG680 package drawings. |
| $1.6(7 / 99)$ | Changed Boundary Scan Information and changed Figure 11, Boundary Scan Bit Sequence. Updated <br> IOB Input \& Output delays. Added Capacitance info for different I/O Standards. Added 5 V tolerant <br> information. Added DLL Parameters and waveforms and new Pin-to-pin Input and Output Parameter <br> tables for Global Clock Input to Output and Setup and Hold. Changed Configuration Information includ- <br> ing Figures 12, 14, 17 \& 19. Added device-dependent listings for quiescent currents ICCINTQ and <br> ICCOQ. Updated IOB Input and Output Delays based on default standard of LVTTL, 12 mA, Fast Slew <br> Rate. Added IOB Input Switching Characteristics Standard Adjustments. |
| $1.7(9 / 99)$ | Speed grade update to preliminary status, Power-on specification and Clock-to-Out Minimums addi- <br> tions, "0" hold time listing explanation, quiescent current listing update, and Figure 6 ADDRA input label <br> correction. Added TIJITcc parameter, changed TOJIT to ToPHASE. |
| $1.8(1 / 00)$ | Update to speed.txt file 1.96. Corrections for CRs 111036,111137, 112697, 115479, 117153, 117154, <br> and 117612. Modified notes for Recommended Operating Conditions (voltage and temperature). <br> Changed Bank information for VCco in CS144 package on page 43. |
| $1.9(1 / 00)$ | Updated DLL Jitter Parameter table and waveforms, added Delay Measurement Methodology table for <br> different I/O standards, changed buffered Hex line info and Input/Output Timing measurement notes. |
| $2.0(3 / 00)$ | New TBCKO values p. 34, corrected FG680 package connection drawing, new note about status of <br> CCLK pin after configuration, page 41. |
| $2.1(5 / 00)$ | Modified "Pins not listed ..." statement on page 42. Speed grade update to Final status. |
| $2.2(5 / 00)$ | Modified Table 18 on page 47. |
| $2.3(9 / 00)$ | - Added XCV400 values to table under "Minimum Clock to Out for Virtex Devices" on page 37. <br> - Corrected Units column in table under "IOB Input Switching Characteristics" on page 26. <br> - Added values to table under "CLB SelectRAM Switching Characteristics" on page 34. |

© 2000, Xilinx, Inc. All rights reserved. All Xilinx trademarks, registered trademarks, patents, and disclaimers are as listed at http://www.xilinx.com/legal.htm. All other trademarks and registered trademarks are the property of their respective owners.


[^0]:    Note: Input timing for LVTTL is measured at 1.4 V . For other I/O standards, see Table 15.

[^1]:    Note: Input timing for GPLVTTL is measured at 1.4 V. For other I/O standards, see Table 15.

