



#### Welcome to E-XFL.COM

#### Understanding Embedded - FPGAs (Field Programmable Gate Array)

Embedded - FPGAs, or Field Programmable Gate Arrays, are advanced integrated circuits that offer unparalleled flexibility and performance for digital systems. Unlike traditional fixed-function logic devices, FPGAs can be programmed and reprogrammed to execute a wide array of logical operations, enabling customized functionality tailored to specific applications. This reprogrammability allows developers to iterate designs quickly and implement complex functions without the need for custom hardware.

#### **Applications of Embedded - FPGAs**

The versatility of Embedded - FPGAs makes them indispensable in numerous fields. In telecommunications.

| Details                        |                                                             |
|--------------------------------|-------------------------------------------------------------|
| Product Status                 | Obsolete                                                    |
| Number of LABs/CLBs            | 400                                                         |
| Number of Logic Elements/Cells | 950                                                         |
| Total RAM Bits                 | 12800                                                       |
| Number of I/O                  | 160                                                         |
| Number of Gates                | 10000                                                       |
| Voltage - Supply               | 4.75V ~ 5.25V                                               |
| Mounting Type                  | Surface Mount                                               |
| Operating Temperature          | 0°C ~ 85°C (TJ)                                             |
| Package / Case                 | 208-BFQFP Exposed Pad                                       |
| Supplier Device Package        | 208-PQFP (28x28)                                            |
| Purchase URL                   | https://www.e-xfl.com/product-detail/xilinx/xc4010e-3hq208c |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

## XC4000E and XC4000X Series Compared to the XC4000

For readers already familiar with the XC4000 family of Xilinx Field Programmable Gate Arrays, the major new features in the XC4000 Series devices are listed in this section. The biggest advantages of XC4000E and XC4000X devices are significantly increased system speed, greater capacity, and new architectural features, particularly Select-RAM memory. The XC4000X devices also offer many new routing features, including special high-speed clock buffers that can be used to capture input data with minimal delay.

Any XC4000E device is pinout- and bitstream-compatible with the corresponding XC4000 device. An existing XC4000 bitstream can be used to program an XC4000E device. However, since the XC4000E includes many new features, an XC4000E bitstream cannot be loaded into an XC4000 device.

XC4000X Series devices are not bitstream-compatible with equivalent array size devices in the XC4000 or XC4000E families. However, equivalent array size devices, such as the XC4025, XC4025E, XC4028EX, and XC4028XL, are pinout-compatible.

## Improvements in XC4000E and XC4000X

## Increased System Speed

XC4000E and XC4000X devices can run at synchronous system clock rates of up to 80 MHz, and internal performance can exceed 150 MHz. This increase in performance over the previous families stems from improvements in both device processing and system architecture. XC4000 Series devices use a sub-micron multi-layer metal process. In addition, many architectural improvements have been made, as described below.

The XC4000XL family is a high performance 3.3V family based on  $0.35\mu$  SRAM technology and supports system speeds to 80 MHz.

## PCI Compliance

XC4000 Series -2 and faster speed grades are fully PCI compliant. XC4000E and XC4000X devices can be used to implement a one-chip PCI solution.

## Carry Logic

The speed of the carry logic chain has increased dramatically. Some parameters, such as the delay on the carry chain through a single CLB (TBYP), have improved by as much as 50% from XC4000 values. See "Fast Carry Logic" on page 18 for more information.

## Select-RAM Memory: Edge-Triggered, Synchronous RAM Modes

The RAM in any CLB can be configured for synchronous, edge-triggered, write operation. The read operation is not affected by this change to an edge-triggered write.

## **Dual-Port RAM**

A separate option converts the 16x2 RAM in any CLB into a 16x1 dual-port RAM with simultaneous Read/Write.

The function generators in each CLB can be configured as either level-sensitive (asynchronous) single-port RAM, edge-triggered (synchronous) single-port RAM, edge-triggered (synchronous) dual-port RAM, or as combinatorial logic.

## Configurable RAM Content

The RAM content can now be loaded at configuration time, so that the RAM starts up with user-defined data.

## H Function Generator

In current XC4000 Series devices, the H function generator is more versatile than in the original XC4000. Its inputs can come not only from the F and G function generators but also from up to three of the four control input lines. The H function generator can thus be totally or partially independent of the other two function generators, increasing the maximum capacity of the device.

## **IOB Clock Enable**

The two flip-flops in each IOB have a common clock enable input, which through configuration can be activated individually for the input or output flip-flop or both. This clock enable operates exactly like the EC pin on the XC4000 CLB. This new feature makes the IOBs more versatile, and avoids the need for clock gating.

## **Output Drivers**

The output pull-up structure defaults to a TTL-like totem-pole. This driver is an n-channel pull-up transistor, pulling to a voltage one transistor threshold below Vcc, just like the XC4000 family outputs. Alternatively, XC4000 Series devices can be globally configured with CMOS outputs, with p-channel pull-up transistors pulling to Vcc. Also, the configurable pull-up resistor in the XC4000 Series is a p-channel transistor that pulls to Vcc, whereas in the original XC4000 family it is an n-channel transistor that pulls to a voltage one transistor threshold below Vcc.

## Set/Reset

An asynchronous storage element input (SR) can be configured as either set or reset. This configuration option determines the state in which each flip-flop becomes operational after configuration. It also determines the effect of a Global Set/Reset pulse during normal operation, and the effect of a pulse on the SR pin of the CLB. All three set/reset functions for any single flip-flop are controlled by the same configuration data bit.

The set/reset state can be independently specified for each flip-flop. This input can also be independently disabled for either flip-flop.

The set/reset state is specified by using the INIT attribute, or by placing the appropriate set or reset flip-flop library symbol.

SR is active High. It is not invertible within the CLB.

## Global Set/Reset

A separate Global Set/Reset line (not shown in Figure 1) sets or clears each storage element during power-up, re-configuration, or when a dedicated Reset net is driven active. This global net (GSR) does not compete with other routing resources; it uses a dedicated distribution network.

Each flip-flop is configured as either globally set or reset in the same way that the local set/reset (SR) is specified. Therefore, if a flip-flop is set by SR, it is also set by GSR. Similarly, a reset flip-flop is reset by both SR and GSR.



Figure 2: Schematic Symbols for Global Set/Reset

GSR can be driven from any user-programmable pin as a global reset input. To use this global net, place an input pad and input buffer in the schematic or HDL code, driving the GSR pin of the STARTUP symbol. (See Figure 2.) A specific pin location can be assigned to this input using a LOC attribute or property, just as with any other user-programmable pad. An inverter can optionally be inserted after the input buffer to invert the sense of the Global Set/Reset signal.

Alternatively, GSR can be driven from any internal node.

## Data Inputs and Outputs

The source of a storage element data input is programmable. It is driven by any of the functions F', G', and H', or by the Direct In (DIN) block input. The flip-flops or latches drive the XQ and YQ CLB outputs. Two fast feed-through paths are available, as shown in Figure 1. A two-to-one multiplexer on each of the XQ and YQ outputs selects between a storage element output and any of the control inputs. This bypass is sometimes used by the automated router to repower internal signals.

## **Control Signals**

Multiplexers in the CLB map the four control inputs (C1 - C4 in Figure 1) into the four internal control signals (H1, DIN/H2, SR/H0, and EC). Any of these inputs can drive any of the four internal control signals.

When the logic function is enabled, the four inputs are:

- EC Enable Clock
- SR/H0 Asynchronous Set/Reset or H function generator Input 0
- DIN/H2 Direct In or H function generator Input 2
- H1 H function generator Input 1.

When the memory function is enabled, the four inputs are:

- EC Enable Clock
- WE Write Enable
- D0 Data Input to F and/or G function generator
- D1 Data input to G function generator (16x1 and 16x2 modes) or 5th Address bit (32x1 mode).

## Using FPGA Flip-Flops and Latches

The abundance of flip-flops in the XC4000 Series invites pipelined designs. This is a powerful way of increasing performance by breaking the function into smaller subfunctions and executing them in parallel, passing on the results through pipeline flip-flops. This method should be seriously considered wherever throughput is more important than latency.

To include a CLB flip-flop, place the appropriate library symbol. For example, FDCE is a D-type flip-flop with clock enable and asynchronous clear. The corresponding latch symbol (for the XC4000X only) is called LDCE.

In XC4000 Series devices, the flip flops can be used as registers or shift registers without blocking the function generators from performing a different, perhaps unrelated task. This ability increases the functional capacity of the devices.

The CLB setup time is specified between the function generator inputs and the clock input K. Therefore, the specified CLB flip-flop setup time includes the delay through the function generator.

## Using Function Generators as RAM

Optional modes for each CLB make the memory look-up tables in the F' and G' function generators usable as an array of Read/Write memory cells. Available modes are level-sensitive (similar to the XC4000/A/H families), edge-triggered, and dual-port edge-triggered. Depending on the selected mode, a single CLB can be configured as either a 16x2, 32x1, or 16x1 bit array.



Figure 4: 16x2 (or 16x1) Edge-Triggered Single-Port RAM



Figure 5: 32x1 Edge-Triggered Single-Port RAM (F and G addresses are identical)

### Additional Input Latch for Fast Capture (XC4000X only)

The XC4000X IOB has an additional optional latch on the input. This latch, as shown in Figure 16, is clocked by the output clock — the clock used for the output flip-flop — rather than the input clock. Therefore, two different clocks can be used to clock the two input storage elements. This additional latch allows the very fast capture of input data, which is then synchronized to the internal clock by the IOB flip-flop or latch.

To use this Fast Capture technique, drive the output clock pin (the Fast Capture latching signal) from the output of one of the Global Early buffers supplied in the XC4000X. The second storage element should be clocked by a Global Low-Skew buffer, to synchronize the incoming data to the internal logic. (See Figure 17.) These special buffers are described in "Global Nets and Buffers (XC4000X only)" on page 37.

The Fast Capture latch (FCL) is designed primarily for use with a Global Early buffer. For Fast Capture, a single clock signal is routed through both a Global Early buffer and a Global Low-Skew buffer. (The two buffers share an input pad.) The Fast Capture latch is clocked by the Global Early buffer, and the standard IOB flip-flop or latch is clocked by the Global Low-Skew buffer. This mode is the safest way to use the Fast Capture latch, because the clock buffers on both storage elements are driven by the same pad. There is no external skew between clock pads to create potential problems.

To place the Fast Capture latch in a design, use one of the special library symbols, ILFFX or ILFLX. ILFFX is a transparent-Low Fast Capture latch followed by an active-High input flip-flop. ILFLX is a transparent-Low Fast Capture latch followed by a transparent-High input latch. Any of the clock inputs can be inverted before driving the library element, and the inverter is absorbed into the IOB. If a single BUFG output is used to drive both clock inputs, the software automatically runs the clock through both a Global Low-Skew buffer and a Global Early buffer, and clocks the Fast Capture latch appropriately.

Figure 16 on page 21 also shows a two-tap delay on the input. By default, if the Fast Capture latch is used, the Xilinx software assumes a Global Early buffer is driving the clock, and selects MEDDELAY to ensure a zero hold time. Select





the desired delay based on the discussion in the previous subsection.

### **IOB Output Signals**

Output signals can be optionally inverted within the IOB, and can pass directly to the pad or be stored in an edge-triggered flip-flop. The functionality of this flip-flop is shown in Table 11.

An active-High 3-state signal can be used to place the output buffer in a high-impedance state, implementing 3-state outputs or bidirectional I/O. Under configuration control, the output (OUT) and output 3-state (T) signals can be inverted. The polarity of these signals is independently configured for each IOB.

The 4-mA maximum output current specification of many FPGAs often forces the user to add external buffers, which are especially cumbersome on bidirectional I/O lines. The XC4000E and XC4000EX/XL devices solve many of these problems by providing a guaranteed output sink current of 12 mA. Two adjacent outputs can be interconnected externally to sink up to 24 mA. The XC4000E and XC4000EX/XL FPGAs can thus directly drive buses on a printed circuit board.

By default, the output pull-up structure is configured as a TTL-like totem-pole. The High driver is an n-channel pull-up transistor, pulling to a voltage one transistor threshold below Vcc. Alternatively, the outputs can be globally configured as CMOS drivers, with p-channel pull-up transistors pulling to Vcc. This option, applied using the bitstream generation software, applies to all outputs on the device. It is not individually programmable. In the XC4000XL, all outputs are pulled to the positive supply rail.

| Mode               | Clock      | Clock<br>Enable | т  | D | Q  |
|--------------------|------------|-----------------|----|---|----|
| Power-Up<br>or GSR | X          | Х               | 0* | Х | SR |
|                    | Х          | 0               | 0* | Х | Q  |
| Flip-Flop          |            | 1*              | 0* | D | D  |
|                    | Х          | Х               | 1  | Х | Z  |
|                    | 0          | Х               | 0* | Х | Q  |
| Legend:<br>X       | Don't care |                 |    |   |    |

 Table 11: Output Flip-Flop Functionality (active rising edge is shown)

\_\_/ Rising edge SR Set or Rese

0\*

1\*

Ζ

Set or Reset value. Reset is default.

Input is Low or unconnected (default value) Input is High or unconnected (default value)

3-state



or clear on reset and after configuration. Other than the global GSR net, no user-controlled set/reset signal is available to the I/O flip-flops. The choice of set or clear applies to both the initial state of the flip-flop and the response to the Global Set/Reset pulse. See "Global Set/Reset" on page 11 for a description of how to use GSR.

## JTAG Support

Embedded logic attached to the IOBs contains test structures compatible with IEEE Standard 1149.1 for boundary scan testing, permitting easy chip and board-level testing. More information is provided in "Boundary Scan" on page 42.

## **Three-State Buffers**

A pair of 3-state buffers is associated with each CLB in the array. (See Figure 27 on page 30.) These 3-state buffers can be used to drive signals onto the nearest horizontal longlines above and below the CLB. They can therefore be used to implement multiplexed or bidirectional buses on the horizontal longlines, saving logic resources. Programmable pull-up resistors attached to these longlines help to implement a wide wired-AND function.

The buffer enable is an active-High 3-state (i.e. an active-Low enable), as shown in Table 13.

Another 3-state buffer with similar access is located near each I/O block along the right and left edges of the array. (See Figure 33 on page 34.)

The horizontal longlines driven by the 3-state buffers have a weak keeper at each end. This circuit prevents undefined floating levels. However, it is overridden by any driver, even a pull-up resistor.

Special longlines running along the perimeter of the array can be used to wire-AND signals coming from nearby IOBs or from internal longlines. These longlines form the wide edge decoders discussed in "Wide Edge Decoders" on page 27.

## Three-State Buffer Modes

The 3-state buffers can be configured in three modes:

- Standard 3-state buffer
- Wired-AND with input on the I pin
- Wired OR-AND

#### Standard 3-State Buffer

All three pins are used. Place the library element BUFT. Connect the input to the I pin and the output to the O pin. The T pin is an active-High 3-state (i.e. an active-Low enable). Tie the T pin to Ground to implement a standard buffer.

### Wired-AND with Input on the I Pin

The buffer can be used as a Wired-AND. Use the WAND1 library symbol, which is essentially an open-drain buffer. WAND4, WAND8, and WAND16 are also available. See the *XACT Libraries Guide* for further information.

The T pin is internally tied to the I pin. Connect the input to the I pin and the output to the O pin. Connect the outputs of all the WAND1s together and attach a PULLUP symbol.

## Wired OR-AND

The buffer can be configured as a Wired OR-AND. A High level on either input turns off the output. Use the WOR2AND library symbol, which is essentially an open-drain 2-input OR gate. The two input pins are functionally equivalent. Attach the two inputs to the I0 and I1 pins and tie the output to the O pin. Tie the outputs of all the WOR2ANDs together and attach a PULLUP symbol.

## Three-State Buffer Examples

Figure 21 shows how to use the 3-state buffers to implement a wired-AND function. When all the buffer inputs are High, the pull-up resistor(s) provide the High output.

Figure 22 shows how to use the 3-state buffers to implement a multiplexer. The selection is accomplished by the buffer 3-state signal.

Pay particular attention to the polarity of the T pin when using these buffers in a design. Active-High 3-state (T) is identical to an active-Low output enable, as shown in Table 13.

#### Table 13: Three-State Buffer Functionality

| IN | Т | OUT |
|----|---|-----|
| Х  | 1 | Z   |
| IN | 0 | IN  |



Figure 21: Open-Drain Buffers Implement a Wired-AND Function

X6465



Figure 28: Single- and Double-Length Lines, with Programmable Switch Matrices (PSMs)

## **Double-Length Lines**

The double-length lines consist of a grid of metal segments, each twice as long as the single-length lines: they run past two CLBs before entering a switch matrix. Double-length lines are grouped in pairs with the switch matrices staggered, so that each line goes through a switch matrix at every other row or column of CLBs (see Figure 28).

There are four vertical and four horizontal double-length lines associated with each CLB. These lines provide faster signal routing over intermediate distances, while retaining routing flexibility. Double-length lines are connected by way of the programmable switch matrices. Routing connectivity is shown in Figure 27.

## Quad Lines (XC4000X only)

XC4000X devices also include twelve vertical and twelve horizontal quad lines per CLB row and column. Quad lines are four times as long as the single-length lines. They are interconnected via buffered switch matrices (shown as diamonds in Figure 27 on page 30). Quad lines run past four CLBs before entering a buffered switch matrix. They are grouped in fours, with the buffered switch matrices staggered, so that each line goes through a buffered switch matrix at every fourth CLB location in that row or column. (See Figure 29.)

The buffered switch matrixes have four pins, one on each edge. All of the pins are bidirectional. Any pin can drive any or all of the other pins.

Each buffered switch matrix contains one buffer and six pass transistors. It resembles the programmable switch matrix shown in Figure 26, with the addition of a programmable buffer. There can be up to two independent inputs



Figure 29: Quad Lines (XC4000X only)

and up to two independent outputs. Only one of the independent inputs can be buffered.

The place and route software automatically uses the timing requirements of the design to determine whether or not a quad line signal should be buffered. A heavily loaded signal is typically buffered, while a lightly loaded one is not. One scenario is to alternate buffers and pass transistors. This allows both vertical and horizontal quad lines to be buffered at alternating buffered switch matrices.

Due to the buffered switch matrices, quad lines are very fast. They provide the fastest available method of routing heavily loaded signals for long distances across the device.

## Longlines

Longlines form a grid of metal interconnect segments that run the entire length or width of the array. Longlines are intended for high fan-out, time-critical signal nets, or nets that are distributed over long distances. In XC4000X devices, quad lines are preferred for critical nets, because the buffered switch matrices make them faster for high fan-out nets.

Two horizontal longlines per CLB can be driven by 3-state or open-drain drivers (TBUFs). They can therefore implement unidirectional or bidirectional buses, wide multiplexers, or wired-AND functions. (See "Three-State Buffers" on page 26 for more details.)

Each horizontal longline driven by TBUFs has either two (XC4000E) or eight (XC4000X) pull-up resistors. To activate these resistors, attach a PULLUP symbol to the long-line net. The software automatically activates the appropriate number of pull-ups. There is also a weak keeper at each end of these two horizontal longlines. This



XC4000X only



XILINX<sup>®</sup>



Figure 36: Any BUFGLS (GCK1 - GCK8) Can Drive Any or All Clock Inputs on the Device

## **Global Early Buffers**

Each corner of the XC4000X device has two Global Early buffers. The primary purpose of the Global Early buffers is to provide an earlier clock access than the potentially heavily-loaded Global Low-Skew buffers. A clock source applied to both buffers will result in the Global Early clock edge occurring several nanoseconds earlier than the Global Low-Skew buffer clock edge, due to the lighter loading.

Global Early buffers also facilitate the fast capture of device inputs, using the Fast Capture latches described in "IOB Input Signals" on page 20. For Fast Capture, take a single clock signal, and route it through both a Global Early buffer and a Global Low-Skew buffer. (The two buffers share an input pad.) Use the Global Early buffer to clock the Fast Capture latch, and the Global Low-Skew buffer to clock the normal input flip-flop or latch, as shown in Figure 17 on page 23.

The Global Early buffers can also be used to provide a fast Clock-to-Out on device output pins. However, an early clock in the output flip-flop IOB must be taken into consideration when calculating the internal clock speed for the design.

The Global Early buffers at the left and right edges of the chip have slightly different capabilities than the ones at the top and bottom. Refer to Figure 37, Figure 38, and Figure 35 on page 36 while reading the following explanation.

Each Global Early buffer can access the eight vertical Global lines for all CLBs in the quadrant. Therefore, only one-fourth of the CLB clock pins can be accessed. This restriction is in large part responsible for the faster speed of the buffers, relative to the Global Low-Skew buffers.



Figure 37: Left and Right BUFGEs Can Drive Any or All Clock Inputs in Same Quadrant or Edge (GCK1 is shown. GCK2, GCK5 and GCK6 are similar.)

The left-side Global Early buffers can each drive two of the four vertical lines accessing the IOBs on the entire left edge of the device. The right-side Global Early buffers can each drive two of the eight vertical lines accessing the IOBs on the entire right edge of the device. (See Figure 37.)

Each left and right Global Early buffer can also drive half of the IOBs along either the top or bottom edge of the device, using a dedicated line that can only be accessed through the Global Early buffers.

The top and bottom Global Early buffers can drive half of the IOBs along either the left or right edge of the device, as shown in Figure 38. They can only access the top and bottom IOBs via the CLB global lines.



Figure 38: Top and Bottom BUFGEs Can Drive Any or All Clock Inputs in Same Quadrant (GCK8 is shown. GCK3, GCK4 and GCK7 are similar.)

## Product Obsolete or Under Obsolescence XC4000E and XC4000X Series Field Programmable Gate Arrays



## Table 16: Pin Descriptions

| Pin Name                  | I/O<br>During | I/O<br>After<br>Config.      | Pin Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------------------|---------------|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin Name<br>Permanently [ | Config.       | -                            | Pin Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| VCC                       | 1             | 1                            | Eight or more (depending on package) connections to the nominal +5 V supply voltage (+3.3 V for low-voltage devices). All must be connected, and each must be decoupled with a 0.01 - 0.1 $\mu$ F capacitor to Ground.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| GND                       | I             | I                            | Eight or more (depending on package type) connections to Ground. All must be con-<br>nected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| CCLK                      | l or O        | I                            | During configuration, Configuration Clock (CCLK) is an output in Master modes or Asyn-<br>chronous Peripheral mode, but is an input in Slave mode and Synchronous Peripheral<br>mode. After configuration, CCLK has a weak pull-up resistor and can be selected as the<br>Readback Clock. There is no CCLK High or Low time restriction on XC4000 Series de-<br>vices, except during Readback. See "Violating the Maximum High and Low Time Spec-<br>ification for the Readback Clock" on page 56 for an explanation of this exception.                                                                                                                                                                                                                                                                                                                             |
| DONE                      | I/O           | 0                            | DONE is a bidirectional signal with an optional internal pull-up resistor. As an output, it indicates the completion of the configuration process. As an input, a Low level on DONE can be configured to delay the global logic initialization and the enabling of outputs. The optional pull-up resistor is selected as an option in the XACT <i>step</i> program that creates the configuration bitstream. The resistor is included by default.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| PROGRAM                   | 1             | I                            | PROGRAM is an active Low input that forces the FPGA to clear its configuration mem-<br>ory. It is used to initiate a configuration cycle. When PROGRAM goes High, the FPGA<br>finishes the current clear cycle and executes another complete clear cycle, before it<br>goes into a WAIT state and releases INIT.<br>The PROGRAM pin has a permanent weak pull-up, so it need not be externally pulled<br>up to Vcc.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| User I/O Pins             | That Can      | Have Sp                      | ecial Functions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| RDY/BUSY                  | о             | I/O                          | During Peripheral mode configuration, this pin indicates when it is appropriate to write<br>another byte of data into the FPGA. The same status is also available on D7 in Asyn-<br>chronous Peripheral mode, if a read operation is performed when the device is selected.<br>After configuration, RDY/BUSY is a user-programmable I/O pin.<br>RDY/BUSY is pulled High with a high-impedance pull-up prior to INIT going High.                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| RCLK                      | 0             | I/O                          | During Master Parallel configuration, each change on the A0-A17 outputs (A0 - A21 for XC4000X) is preceded by a rising edge on $\overline{RCLK}$ , a redundant output signal. $\overline{RCLK}$ is useful for clocked PROMs. It is rarely used during configuration. After configuration, $\overline{RCLK}$ is a user-programmable I/O pin.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| M0, M1, M2                | 1             | I (M0),<br>O (M1),<br>I (M2) | As Mode inputs, these pins are sampled after INIT goes High to determine the configuration mode to be used. After configuration, M0 and M2 can be used as inputs, and M1 can be used as a 3-state output. These three pins have no associated input or output registers. During configuration, these pins have weak pull-up resistors. For the most popular configuration mode, Slave Serial, the mode pins can thus be left unconnected. The three mode inputs can be individually configured with or without weak pull-up or pull-down resistors. A pull-down resistor value of 4.7 k $\Omega$ is recommended. These pins can only be used as inputs or outputs when called out by special schematic definitions. To use these pins, place the library components MD0, MD1, and MD2 instead of the usual pad symbols. Input or output buffers must still be used. |
| TDO                       | 0             | 0                            | If boundary scan is used, this pin is the Test Data Output. If boundary scan is not used, this pin is a 3-state output without a register, after configuration is completed. This pin can be user output only when called out by special schematic definitions. To use this pin, place the library component TDO instead of the usual pad symbol. An output buffer must still be used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |



## Table 16: Pin Descriptions (Continued)

| Pin Name                               | I/O<br>During<br>Config. | I/O<br>After<br>Config. | Pin Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------------------------------|--------------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CS0, CS1,<br>WS, RS                    | I                        | I/O                     | These four inputs are used in Asynchronous Peripheral mode. The chip is selected when $\overline{CS0}$ is Low and CS1 is High. While the chip is selected, a Low on Write Strobe $(\overline{WS})$ loads the data present on the D0 - D7 inputs into the internal data buffer. A Low on Read Strobe $(\overline{RS})$ changes D7 into a status output — High if Ready, Low if Busy — and drives D0 - D6 High.<br>In Express mode, CS1 is used as a serial-enable signal for daisy-chaining.<br>$\overline{WS}$ and $\overline{RS}$ should be mutually exclusive, but if both are Low simultaneously, the Write Strobe overrides. After configuration, these are user-programmable I/O pins. |
| A0 - A17                               | 0                        | I/O                     | During Master Parallel configuration, these 18 output pins address the configuration EPROM. After configuration, they are user-programmable I/O pins.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| A18 - A21<br>(XC4003XL to<br>XC4085XL) | ο                        | I/O                     | During Master Parallel configuration with an XC4000X master, these 4 output pins add 4 more bits to address the configuration EPROM. After configuration, they are user-pro-<br>grammable I/O pins. (See Master Parallel Configuration section for additional details.)                                                                                                                                                                                                                                                                                                                                                                                                                     |
| D0 - D7                                | I                        | I/O                     | During Master Parallel and Peripheral configuration, these eight input pins receive con-<br>figuration data. After configuration, they are user-programmable I/O pins.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| DIN                                    | I                        | I/O                     | During Slave Serial or Master Serial configuration, DIN is the serial configuration data input receiving data on the rising edge of CCLK. During Parallel configuration, DIN is the D0 input. After configuration, DIN is a user-programmable I/O pin.                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| DOUT                                   | Ο                        | I/O                     | During configuration in any mode but Express mode, DOUT is the serial configuration data output that can drive the DIN of daisy-chained slave FPGAs. DOUT data changes on the falling edge of CCLK, one-and-a-half CCLK periods after it was received at the DIN input.<br>In Express modefor XC4000E and XC4000X only, DOUT is the status output that can drive the CS1 of daisy-chained FPGAs, to enable and disable downstream devices.<br>After configuration, DOUT is a user-programmable I/O pin.                                                                                                                                                                                     |
| Unrestricted U                         | lser-Prog                | rammabl                 | e I/O Pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| I/O                                    | Weak<br>Pull-up          | I/O                     | These pins can be configured to be input and/or output after configuration is completed. Before configuration is completed, these pins have an internal high-value pull-up resistor (25 k $\Omega$ - 100 k $\Omega$ ) that defines the logic level as High.                                                                                                                                                                                                                                                                                                                                                                                                                                 |

## **Boundary Scan**

The 'bed of nails' has been the traditional method of testing electronic assemblies. This approach has become less appropriate, due to closer pin spacing and more sophisticated assembly methods like surface-mount technology and multi-layer boards. The IEEE Boundary Scan Standard 1149.1 was developed to facilitate board-level testing of electronic assemblies. Design and test engineers can imbed a standard test logic structure in their device to achieve high fault coverage for I/O and internal logic. This structure is easily implemented with a four-pin interface on any boundary scan-compatible IC. IEEE 1149.1-compatible devices may be serial daisy-chained together, connected in parallel, or a combination of the two.

The XC4000 Series implements IEEE 1149.1-compatible BYPASS, PRELOAD/SAMPLE and EXTEST boundary scan instructions. When the boundary scan configuration option is selected, three normal user I/O pins become dedicated inputs for these functions. Another user output pin becomes the dedicated boundary scan output. The details of how to enable this circuitry are covered later in this section.

By exercising these input signals, the user can serially load commands and data into these devices to control the driving of their outputs and to examine their inputs. This method is an improvement over bed-of-nails testing. It avoids the need to over-drive device outputs, and it reduces the user interface to four pins. An optional fifth pin, a reset for the control logic, is described in the standard but is not implemented in Xilinx devices.

The dedicated on-chip logic implementing the IEEE 1149.1 functions includes a 16-state machine, an instruction register and a number of data registers. The functional details can be found in the IEEE 1149.1 specification and are also discussed in the Xilinx application note XAPP 017: "*Boundary Scan in XC4000 Devices.*"

Figure 40 on page 43 shows a simplified block diagram of the XC4000E Input/Output Block with boundary scan implemented. XC4000X boundary scan logic is identical.

is passed through and is captured by each FPGA when it recognizes the 0010 preamble. Following the length-count data, each FPGA outputs a High on DOUT until it has received its required number of data frames.

After an FPGA has received its configuration data, it passes on any additional frame start bits and configuration data on DOUT. When the total number of configuration clocks applied after memory initialization equals the value of the 24-bit length count, the FPGAs begin the start-up sequence and become operational together. FPGA I/O are normally released two CCLK cycles after the last configuration bit is received. Figure 47 on page 53 shows the start-up timing for an XC4000 Series device.

The daisy-chained bitstream is not simply a concatenation of the individual bitstreams. The PROM file formatter must be used to combine the bitstreams for a daisy-chained configuration.

## **Multi-Family Daisy Chain**

All Xilinx FPGAs of the XC2000, XC3000, and XC4000 Series use a compatible bitstream format and can, therefore, be connected in a daisy chain in an arbitrary sequence. There is, however, one limitation. The lead device must belong to the highest family in the chain. If the chain contains XC4000 Series devices, the master normally cannot be an XC2000 or XC3000 device.

The reason for this rule is shown in Figure 47 on page 53. Since all devices in the chain store the same length count value and generate or receive one common sequence of CCLK pulses, they all recognize length-count match on the same CCLK edge, as indicated on the left edge of Figure 47. The master device then generates additional CCLK pulses until it reaches its finish point F. The different families generate or require different numbers of additional CCLK pulses until they reach F. Not reaching F means that the device does not really finish its configuration, although DONE may have gone High, the outputs became active, and the internal reset was released. For the XC4000 Series device, not reaching F means that readback cannot be ini-

tiated and most boundary scan instructions cannot be used.

The user has some control over the relative timing of these events and can, therefore, make sure that they occur at the proper time and the finish point F is reached. Timing is controlled using options in the bitstream generation software.

## XC3000 Master with an XC4000 Series Slave

Some designers want to use an inexpensive lead device in peripheral mode and have the more precious I/O pins of the XC4000 Series devices all available for user I/O. Figure 44 provides a solution for that case.

This solution requires one CLB, one IOB and pin, and an internal oscillator with a frequency of up to 5 MHz as a clock source. The XC3000 master device must be configured with late Internal Reset, which is the default option.

One CLB and one IOB in the lead XC3000-family device are used to generate the additional CCLK pulse required by the XC4000 Series devices. When the lead device removes the internal RESET signal, the 2-bit shift register responds to its clock input and generates an active Low output signal for the duration of the subsequent clock period. An external connection between this output and CCLK thus creates the extra CCLK pulse.



Figure 44: CCLK Generation for XC3000 Master Driving an XC4000 Series Slave



## Start-up from a User Clock (STARTUP.CLK)

When, instead of CCLK, a user-supplied start-up clock is selected, Q1 is used to bridge the unknown phase relationship between CCLK and the user clock. This arbitration causes an unavoidable one-cycle uncertainty in the timing of the rest of the start-up sequence.

## DONE Goes High to Signal End of Configuration

XC4000 Series devices read the expected length count from the bitstream and store it in an internal register. The length count varies according to the number of devices and the composition of the daisy chain. Each device also counts the number of CCLKs during configuration.

Two conditions have to be met in order for the DONE pin to go high:

- the chip's internal memory must be full, and
- the configuration length count must be met, exactly.

This is important because the counter that determines when the length count is met begins with the very first CCLK, not the first one after the preamble.

Therefore, if a stray bit is inserted before the preamble, or the data source is not ready at the time of the first CCLK, the internal counter that holds the number of CCLKs will be one ahead of the actual number of data bits read. At the end of configuration, the configuration memory will be full, but the number of bits in the internal counter will not match the expected length count.

As a consequence, a Master mode device will continue to send out CCLKs until the internal counter turns over to zero, and then reaches the correct length count a second time. This will take several seconds  $[2^{24} * CCLK \text{ period}]$  — which is sometimes interpreted as the device not configuring at all.

If it is not possible to have the data ready at the time of the first CCLK, the problem can be avoided by increasing the number in the length count by the appropriate value. The *XACT User Guide* includes detailed information about manually altering the length count.

Note that DONE is an open-drain output and does not go High unless an internal pull-up is activated or an external pull-up is attached. The internal pull-up is activated as the default by the bitstream generation software.

## Release of User I/O After DONE Goes High

By default, the user I/O are released one CCLK cycle after the DONE pin goes High. If CCLK is not clocked after DONE goes High, the outputs remain in their initial state — 3-stated, with a 50 k $\Omega$  - 100 k $\Omega$  pull-up. The delay from DONE High to active user I/O is controlled by an option to the bitstream generation software.

## Release of Global Set/Reset After DONE Goes High

By default, Global Set/Reset (GSR) is released two CCLK cycles after the DONE pin goes High. If CCLK is not clocked twice after DONE goes High, all flip-flops are held in their initial set or reset state. The delay from DONE High to GSR inactive is controlled by an option to the bitstream generation software.

## **Configuration Complete After DONE Goes High**

Three full CCLK cycles are required after the DONE pin goes High, as shown in Figure 47 on page 53. If CCLK is not clocked three times after DONE goes High, readback cannot be initiated and most boundary scan instructions cannot be used.

# Configuration Through the Boundary Scan Pins

XC4000 Series devices can be configured through the boundary scan pins. The basic procedure is as follows:

- Power up the FPGA with INIT held Low (or drive the PROGRAM pin Low for more than 300 ns followed by a High while holding INIT Low). Holding INIT Low allows enough time to issue the CONFIG command to the FPGA. The pin can be used as I/O after configuration if a resistor is used to hold INIT Low.
- · Issue the CONFIG command to the TMS input
- Wait for INIT to go High
- Sequence the boundary scan Test Access Port to the SHIFT-DR state
- Toggle TCK to clock data into TDI pin.

The user must account for all TCK clock cycles after INIT goes High, as all of these cycles affect the Length Count compare.

For more detailed information, refer to the Xilinx application note XAPP017, "*Boundary Scan in XC4000 Devices.*" This application note also applies to XC4000E and XC4000X devices.



Figure 49: Readback Schematic Example

## **Readback Options**

Readback options are: Read Capture, Read Abort, and Clock Select. They are set with the bitstream generation software.

## **Read Capture**

When the Read Capture option is selected, the readback data stream includes sampled values of CLB and IOB signals. The rising edge of RDBK.TRIG latches the inverted values of the four CLB outputs, the IOB output flip-flops and the input signals I1 and I2. Note that while the bits describing configuration (interconnect, function generators, and RAM content) are *not* inverted, the CLB and IOB output signals *are* inverted.

When the Read Capture option is not selected, the values of the capture bits reflect the configuration data originally written to those memory locations.

If the RAM capability of the CLBs is used, RAM data are available in readback, since they directly overwrite the F and G function-table configuration of the CLB.

RDBK.TRIG is located in the lower-left corner of the device, as shown in Figure 50.

## **Read Abort**

When the Read Abort option is selected, a High-to-Low transition on RDBK.TRIG terminates the readback operation and prepares the logic to accept another trigger.

After an aborted readback, additional clocks (up to one readback clock per configuration frame) may be required to re-initialize the control logic. The status of readback is indicated by the output control net RDBK.RIP. RDBK.RIP is High whenever a readback is in progress.

## **Clock Select**

CCLK is the default clock. However, the user can insert another clock on RDBK.CLK. Readback control and data are clocked on rising edges of RDBK.CLK. If readback must be inhibited for security reasons, the readback control nets are simply not connected.

RDBK.CLK is located in the lower right chip corner, as shown in Figure 50.



S. XILINX®

Figure 50: READBACK Symbol in Graphical Editor

# Violating the Maximum High and Low Time Specification for the Readback Clock

The readback clock has a maximum High and Low time specification. In some cases, this specification cannot be met. For example, if a processor is controlling readback, an interrupt may force it to stop in the middle of a readback. This necessitates stopping the clock, and thus violating the specification.

The specification is mandatory only on clocking data at the end of a frame prior to the next start bit. The transfer mechanism will load the data to a shift register during the last six clock cycles of the frame, prior to the start bit of the following frame. This loading process is dynamic, and is the source of the maximum High and Low time requirements.

Therefore, the specification only applies to the six clock cycles prior to and including any start bit, including the clocks before the first start bit in the readback data stream. At other times, the frame data is already in the register and the register is not dynamic. Thus, it can be shifted out just like a regular shift register.

The user must precisely calculate the location of the readback data relative to the frame. The system must keep track of the position within a data frame, and disable interrupts before frame boundaries. Frame lengths and data formats are listed in Table 19, Table 20 and Table 21.

## Readback with the XChecker Cable

The XChecker Universal Download/Readback Cable and Logic Probe uses the readback feature for bitstream verification. It can also display selected internal signals on the PC or workstation screen, functioning as a low-cost in-circuit emulator.



## Table 22: Pin Functions During Configuration

|                            |                             | CONFIGURATION                   | MODE <m2:m1:m< th=""><th>10&gt;</th><th></th><th></th></m2:m1:m<> | 10>                                |                                  |                   |  |  |
|----------------------------|-----------------------------|---------------------------------|-------------------------------------------------------------------|------------------------------------|----------------------------------|-------------------|--|--|
| SLAVE<br>SERIAL<br><1:1:1> | MASTER<br>SERIAL<br><0:0:0> | SYNCH.<br>PERIPHERAL<br><0:1:1> | ASYNCH.<br>PERIPHERAL<br><1:0:1>                                  | MASTER<br>PARALLEL DOWN<br><1:1:0> | MASTER<br>PARALLEL UP<br><1:0:0> | USER<br>OPERATION |  |  |
| M2(HIGH) (I)               | M2(LOW) (I)                 | M2(LOW) (I)                     | M2(HIGH) (I)                                                      | M2(HIGH) (I)                       | M2(HIGH) (I)                     | (I)               |  |  |
| M1(HIGH) (I)               | M1(LOW) (I)                 | M1(HIGH) (I)                    | M1(LOW) (I)                                                       | M1(HIGH) (I)                       | M1(LOW) (I)                      | (O)               |  |  |
| M0(HIGH) (I)               | M0(LOW) (I)                 | M0(HIGH) (I)                    | M0(HIGH) (I)                                                      | M0(LOW) (I)                        | M0(LOW) (I)                      | (I)               |  |  |
| HDC (HIGH)                 | HDC (HIGH)                  | HDC (HIGH)                      | HDC (HIGH)                                                        | HDC (HIGH)                         | HDC (HIGH)                       | I/O               |  |  |
| LDC (LOW)                  | LDC (LOW)                   | LDC (LOW)                       | LDC (LOW)                                                         | LDC (LOW)                          | LDC (LOW)                        | I/O               |  |  |
|                            |                             |                                 |                                                                   | INIT                               |                                  | I/O               |  |  |
| DONE                       | DONE                        | DONE                            | DONE                                                              | DONE                               | DONE                             | DONE              |  |  |
| PROGRAM (I)                | PROGRAM (I)                 | PROGRAM (I)                     | PROGRAM (I)                                                       | PROGRAM (I)                        | PROGRAM (I)                      | PROGRAM           |  |  |
| CCLK (I)                   | CCLK (O)                    | CCLK (I)                        | CCLK (O)                                                          | CCLK (O)                           | CCLK (O)                         | CCLK (I)          |  |  |
|                            |                             | RDY/BUSY (0)                    | RDY/BUSY (O)                                                      | RCLK (0)                           | RCLK (0)                         | I/O               |  |  |
|                            |                             | KD1/6031 (0)                    | RS (I)                                                            |                                    | KOLK (O)                         | I/O               |  |  |
|                            |                             |                                 | $\overline{\text{CS0}}$ (I)                                       |                                    |                                  | I/O               |  |  |
|                            |                             |                                 |                                                                   |                                    |                                  | 1/0<br>1/0        |  |  |
|                            |                             | DATA 7 (I)                      | DATA 7 (I)                                                        | DATA 7 (I)                         | DATA 7 (I)                       |                   |  |  |
|                            |                             | DATA 6 (I)                      | DATA 6 (I)                                                        | DATA 6 (I)                         | DATA 6 (I)                       | I/O               |  |  |
|                            |                             | DATA 5 (I)                      | DATA 5 (I)                                                        | DATA 5 (I)                         | DATA 5 (I)                       | I/O               |  |  |
|                            |                             | DATA 4 (I)                      | DATA 4 (I)                                                        | DATA 4 (I)                         | DATA 4 (I)                       | I/O               |  |  |
|                            |                             | DATA 3 (I)                      | DATA 3 (I)                                                        | DATA 3 (I)                         | DATA 3 (I)                       | I/O               |  |  |
|                            |                             | DATA 2 (I)                      | DATA 2 (I)                                                        | DATA 2 (I)                         | DATA 2 (I)                       | I/O               |  |  |
|                            |                             | DATA 1 (I)                      | DATA 1 (I)                                                        | DATA 1 (I)                         | DATA 1 (I)                       | I/O               |  |  |
| DIN (I)                    | DIN (I)                     | DATA 0 (I)                      | DATA 0 (I)                                                        | DATA 0 (I)                         | DATA 0 (I)                       | I/O               |  |  |
| DOUT                       | DOUT                        | DOUT                            | DOUT                                                              | DOUT                               | DOUT                             | SGCK4-GCK6-I/O    |  |  |
| TDI                        | TDI                         | TDI                             | TDI                                                               | TDI                                | TDI                              | TDI-I/O           |  |  |
| TCK                        | TCK                         | TCK                             | TCK                                                               | TCK                                | TCK                              | TCK-I/O           |  |  |
| TMS                        | TMS                         | TMS                             | TMS                                                               | TMS                                | TMS                              | TMS-I/O           |  |  |
| TDO                        | TDO                         | TDO                             | TDO                                                               | TDO                                | TDO                              | TDO-(O)           |  |  |
|                            | •                           | •                               | WS (I)                                                            | A0                                 | A0                               | I/O               |  |  |
|                            |                             |                                 | •                                                                 | A1                                 | A1                               | PGCK4-GCK7-I/O    |  |  |
|                            |                             |                                 | CS1                                                               | A2                                 | A2                               | I/O               |  |  |
|                            |                             |                                 |                                                                   | A3                                 | A3                               | I/O               |  |  |
|                            |                             |                                 |                                                                   | A4                                 | A4                               | I/O               |  |  |
|                            |                             |                                 |                                                                   | A5                                 | A5                               | I/O               |  |  |
|                            |                             |                                 |                                                                   | A6                                 | A6                               | I/O               |  |  |
|                            |                             |                                 |                                                                   | A7                                 | A7                               | I/O               |  |  |
|                            |                             |                                 |                                                                   | A8                                 | A8                               | I/O               |  |  |
|                            |                             |                                 |                                                                   | A9                                 | A9                               | I/O               |  |  |
|                            |                             |                                 |                                                                   | A10                                | A10                              | I/O               |  |  |
|                            |                             |                                 |                                                                   | A11                                | A11                              | I/O               |  |  |
|                            |                             |                                 |                                                                   | A12                                | A12                              | I/O               |  |  |
|                            |                             |                                 |                                                                   | A13                                | A13                              | I/O               |  |  |
|                            |                             |                                 |                                                                   | A14                                | A14                              | I/O               |  |  |
|                            |                             |                                 |                                                                   | A15                                | A15                              | SGCK1-GCK8-I/O    |  |  |
|                            |                             |                                 |                                                                   | A15                                | A16                              | PGCK1-GCK1-I/O    |  |  |
|                            |                             |                                 |                                                                   | A10                                | A10                              | I/O               |  |  |
|                            |                             |                                 |                                                                   | A17<br>A18*                        | A17<br>A18*                      | I/O               |  |  |
|                            |                             |                                 |                                                                   | A19*                               | A18<br>A19*                      | I/O               |  |  |
|                            |                             |                                 |                                                                   | A19<br>A20*                        | A19*<br>A20*                     | 1/0<br>1/0        |  |  |
|                            |                             |                                 |                                                                   |                                    |                                  | 1/0<br>1/0        |  |  |
|                            |                             |                                 |                                                                   | A21*                               | A21*                             |                   |  |  |
|                            |                             |                                 |                                                                   |                                    |                                  | ALL OTHERS        |  |  |

The seven configuration modes are discussed in detail in this section. Timing specifications are included.

## **Slave Serial Mode**

In Slave Serial mode, an external signal drives the CCLK input of the FPGA. The serial configuration bitstream must be available at the DIN input of the lead FPGA a short setup time before each rising CCLK edge.

The lead FPGA then presents the preamble data—and all data that overflows the lead device—on its DOUT pin.

There is an internal delay of 0.5 CCLK periods, which means that DOUT changes on the falling CCLK edge, and the next FPGA in the daisy chain accepts data on the subsequent rising CCLK edge.

ST XILINX®

Figure 51 shows a full master/slave system. An XC4000 Series device in Slave Serial mode should be connected as shown in the third device from the left.

Slave Serial mode is selected by a <111> on the mode pins (M2, M1, M0). Slave Serial is the default mode if the mode pins are left unconnected, as they have weak pull-up resistors during configuration.



Figure 51: Master/Slave Serial Mode Circuit Diagram



|      | Description |   | Symbol           | Min | Max | Units |  |  |
|------|-------------|---|------------------|-----|-----|-------|--|--|
|      | DIN setup   | 1 | T <sub>DCC</sub> | 20  |     | ns    |  |  |
|      | DIN hold    | 2 | T <sub>CCD</sub> | 0   |     | ns    |  |  |
| CCLK | DIN to DOUT | 3 | T <sub>CCO</sub> |     | 30  | ns    |  |  |
| COLK | High time   | 4 | Т <sub>ССН</sub> | 45  |     | ns    |  |  |
|      | Low time    | 5 | T <sub>CCL</sub> | 45  |     | ns    |  |  |
|      | Frequency   |   | F <sub>cc</sub>  |     | 10  | MHz   |  |  |

Note: Configuration must be delayed until the INIT pins of all daisy-chained FPGAs are High.

Figure 52: Slave Serial Mode Programming Switching Characteristics



|      | Description            |   | Symbol           | Min | Max | Units |
|------|------------------------|---|------------------|-----|-----|-------|
|      | Delay to Address valid | 1 | T <sub>RAC</sub> | 0   | 200 | ns    |
| RCLK | Data setup time        | 2 | T <sub>DRC</sub> | 60  |     | ns    |
|      | Data hold time         | 3 | T <sub>RCD</sub> | 0   |     | ns    |

Notes: 1. At power-up, Vcc must rise from 2.0 V to Vcc min in less than 25 ms, otherwise delay configuration by pulling PROGRAM Low until Vcc is valid.

2. The first Data byte is loaded and CCLK starts at the end of the first RCLK active cycle (rising edge).

This timing diagram shows that the EPROM requirements are extremely relaxed. EPROM access time can be longer than 500 ns. EPROM data output has no hold-time requirements.

#### Figure 55: Master Parallel Mode Programming Switching Characteristics



X6096

|      | Description            | Symbol           | Min | Max | Units |
|------|------------------------|------------------|-----|-----|-------|
|      | INIT (High) setup time | T <sub>IC</sub>  | 5   |     | μs    |
|      | D0 - D7 setup time     | T <sub>DC</sub>  | 60  |     | ns    |
| CCLK | D0 - D7 hold time      | T <sub>CD</sub>  | 0   |     | ns    |
| COLK | CCLK High time         | Т <sub>ССН</sub> | 50  |     | ns    |
|      | CCLK Low time          | T <sub>CCL</sub> | 60  |     | ns    |
|      | CCLK Frequency         | F <sub>CC</sub>  |     | 8   | MHz   |

Notes: 1. Peripheral Synchronous mode can be considered Slave Parallel mode. An external CCLK provides timing, clocking in the **first** data byte on the **second** rising edge of CCLK after INIT goes High. Subsequent data bytes are clocked in on every eighth consecutive rising edge of CCLK.

2. The RDY/BUSY line goes High for one CCLK period after data has been clocked in, although synchronous operation does not require such a response.

3. The pin name RDY/BUSY is a misnomer. In Synchronous Peripheral mode this is really an ACKNOWLEDGE signal.

4. Note that data starts to shift out serially on the DOUT pin 0.5 CCLK periods after it was loaded in parallel. Therefore, additional CCLK pulses are clearly required after the last byte has been loaded.

### Figure 57: Synchronous Peripheral Mode Programming Switching Characteristics

## **Asynchronous Peripheral Mode**

## Write to FPGA

Asynchronous Peripheral mode uses the trailing edge of the logic AND condition of  $\overline{WS}$  and  $\overline{CS0}$  being Low and  $\overline{RS}$ and CS1 being High to accept byte-wide data from a microprocessor bus. In the lead FPGA, this data is loaded into a double-buffered UART-like parallel-to-serial converter and is serially shifted into the internal logic.

The lead FPGA presents the preamble data (and all data that overflows the lead device) on its DOUT pin. The RDY/BUSY output from the lead FPGA acts as a hand-shake signal to the microprocessor. RDY/BUSY goes Low when a byte has been received, and goes High again when the byte-wide input buffer has transferred its information into the shift register, and the buffer is ready to receive new data. A new write may be started immediately, as soon as the RDY/BUSY output has gone Low, acknowledging receipt of the previous data. Write may not be terminated until RDY/BUSY is High again for one CCLK period. Note that RDY/BUSY is pulled High with a high-impedance pull-up prior to INIT going High.

The length of the  $\overline{\text{BUSY}}$  signal depends on the activity in the UART. If the shift register was empty when the new byte was received, the  $\overline{\text{BUSY}}$  signal lasts for only two CCLK periods. If the shift register was still full when the new byte was received, the  $\overline{\text{BUSY}}$  signal can be as long as nine CCLK periods.

Note that after the last byte has been entered, only seven of its bits are shifted out. CCLK remains High with DOUT equal to bit 6 (the next-to-last bit) of the last byte entered.

The READY/BUSY handshake can be ignored if the delay from any one Write to the end of the next Write is guaranteed to be longer than 10 CCLK periods.

## Status Read

The logic AND condition of the  $\overline{CS0}$ , CS1and  $\overline{RS}$  inputs puts the device status on the Data bus.

- D7 High indicates Ready
- D7 Low indicates Busy
- D0 through D6 go unconditionally High

It is mandatory that the whole start-up sequence be started and completed by one byte-wide input. Otherwise, the pins used as Write Strobe or Chip Enable might become active outputs and interfere with the final byte transfer. If this transfer does not occur, the start-up sequence is not completed all the way to the finish (point F in Figure 47 on page 53).

In this case, at worst, the internal reset is not released. At best, Readback and Boundary Scan are inhibited. The length-count value, as generated by the XACT*step* software, ensures that these problems never occur.

Although RDY/ $\overline{BUSY}$  is brought out as a separate signal, microprocessors can more easily read this information on one of the data lines. For this purpose, D7 represents the RDY/ $\overline{BUSY}$  status when  $\overline{RS}$  is Low,  $\overline{WS}$  is High, and the two chip select lines are both active.

Asynchronous Peripheral mode is selected by a <101> on the mode pins (M2, M1, M0).



Figure 58: Asynchronous Peripheral Mode Circuit Diagram

# **User I/O Per Package**

Table 27, Table 28, and Table 29 show the number of user I/Os available in each package for XC4000-Series devices. Call your local sales office for the latest availability information, or see the Xilinx website at http://www.xilinx.com for the latest revision of the specifications.

| Table 27: User I/O Char | t for XC4000XL FPGAs |
|-------------------------|----------------------|
|-------------------------|----------------------|

|          |     |      |       |       |       |       |       | Maxiı | mum   | Use   | r Acc | essil | ole I/ | Э by  | Pack | kage  | Туре  | ;    |      |      |      |      |       |
|----------|-----|------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|--------|-------|------|-------|-------|------|------|------|------|------|-------|
|          | Max | PC84 | PQ100 | VQ100 | TQ144 | HT144 | HQ160 | PQ160 | тQ176 | HT176 | HQ208 | Q208  | HQ240  | PQ240 | G256 | PG299 | HQ304 | G352 | G411 | G432 | G475 | G559 | BG560 |
| Device   | I/O | ٩    | Ы     | 5     | μĔ    | Ľ     | Ĭ     | ЫĞ    | Ĕ     | Ľ     | Ξ     | Ы     | ΗĔ     | Ы     | Ы    | Ы     | Ξ     | Ы    | Ы    | Ы    | Ы    | Ы    | ы     |
| XC4002XL | 64  | 61   | 64    | 64    |       |       |       |       |       |       |       |       |        |       |      |       |       |      |      |      |      |      |       |
| XC4005XL | 112 | 61   | 77    | 77    | 112   |       |       | 112   |       |       |       | 112   |        |       |      |       |       |      |      |      |      |      |       |
| XC4010XL | 160 | 61   | 77    |       | 113   |       |       | 129   | 145   |       |       | 160   |        |       | 160  |       |       |      |      |      |      |      |       |
| XC4013XL | 192 |      |       |       |       | 113   |       | 129   |       | 145   |       | 160   |        | 192   | 192  |       |       |      |      |      |      |      |       |
| XC4020XL | 224 |      |       |       |       | 113   |       | 129   |       | 145   |       | 160   |        | 192   | 205  |       |       |      |      |      |      |      |       |
| XC4028XL | 256 |      |       |       |       |       | 129   |       |       |       | 160   |       | 193    |       | 205  | 256   | 256   | 256  |      |      |      |      |       |
| XC4036XL | 288 |      |       |       |       |       | 129   |       |       |       | 160   |       | 193    |       |      |       | 256   | 288  | 288  | 288  |      |      |       |
| XC4044XL | 320 |      |       |       |       |       | 129   |       |       |       | 160   |       | 193    |       |      |       | 256   | 289  | 320  | 320  |      |      |       |
| XC4052XL | 352 |      |       |       |       |       |       |       |       |       |       |       | 193    |       |      |       | 256   |      | 352  | 352  |      |      | 352   |
| XC4062XL | 384 |      |       |       |       |       |       |       |       |       |       |       | 193    |       |      |       | 256   |      |      | 352  | 384  |      | 384   |
| XC4085XL | 448 |      |       |       |       |       |       |       |       |       |       |       |        |       |      |       |       |      |      | 352  |      | 448  | 448   |

1/29/99

## Table 28: User I/O Chart for XC4000E FPGAs

|         |            |      | Maximum User Accessible I/O by Package Type |       |       |       |       |       |       |       |       |       |       |       |       |       |       |
|---------|------------|------|---------------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| Device  | Max<br>I/O | PC84 | PQ100                                       | VQ100 | PG120 | TQ144 | PG156 | PQ160 | PG191 | HQ208 | PQ208 | PG223 | BG225 | HQ240 | PQ240 | PG299 | HQ304 |
| XC4003E | 80         | 61   | 77                                          | 77    | 80    |       |       |       |       |       |       |       |       |       |       |       |       |
| XC4005E | 112        | 61   | 77                                          |       |       | 112   | 112   | 112   |       |       | 112   |       |       |       |       |       |       |
| XC4006E | 128        | 61   |                                             |       |       | 113   | 125   | 128   |       |       | 128   |       |       |       |       |       |       |
| XC4008E | 144        | 61   |                                             |       |       |       |       | 129   | 144   |       | 144   |       |       |       |       |       |       |
| XC4010E | 160        | 61   |                                             |       |       |       |       | 129   | 160   | 160   | 160   |       | 160   |       |       |       |       |
| XC4013E | 192        |      |                                             |       |       |       |       | 129   |       | 160   | 160   | 192   | 192   | 192   | 192   |       |       |
| XC4020E | 224        |      |                                             |       |       |       |       |       |       | 160   |       | 192   |       | 193   |       |       |       |
| XC4025E | 256        |      |                                             |       |       |       |       |       |       |       |       | 192   |       | 193   |       | 256   | 256   |

1/29/99

## Table 29: User I/O Chart for XC4000EX FPGAs

|          | Max | Maximum User Accessible I/O by Package Type |       |       |       |       |       |       |
|----------|-----|---------------------------------------------|-------|-------|-------|-------|-------|-------|
| Device   | I/O | HQ208                                       | HQ240 | PG299 | HQ304 | BG352 | PG411 | BG432 |
| XC4028EX | 256 | 160                                         | 193   | 256   | 256   | 256   |       |       |
| XC4036EX | 288 |                                             | 193   |       | 256   | 288   | 288   | 288   |

1/29/99



## **XC4000 Series Electrical Characteristics and Device-Specific Pinout Table**

For the latest Electrical Characteristics and package/pinout information for each XC4000 Family, see the Xilinx web site at

http://www.xilinx.com/xlnx/xweb/xil\_publications\_index.jsp

# **Ordering Information**



X9020

# **Revision Control**

| Version       | Description                                                                                                                                                                |  |  |  |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 3/30/98 (1.5) | Updated XC4000XL timing and added XC4002XL                                                                                                                                 |  |  |  |
| 1/29/99 (1.5) | Updated pin diagrams                                                                                                                                                       |  |  |  |
|               | Replaced Electrical Specification and pinout pages for E, EX, and XL families with separate updates and added URL link for electrical specifications/pinouts for Web users |  |  |  |