



Welcome to **E-XFL.COM** 

# Understanding <u>Embedded - FPGAs (Field Programmable Gate Array)</u>

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            | 324                                                         |
| Number of Logic Elements/Cells | 770                                                         |
| Total RAM Bits                 | 10368                                                       |
| Number of I/O                  | 129                                                         |
| Number of Gates                | 8000                                                        |
| Voltage - Supply               | 4.75V ~ 5.25V                                               |
| Mounting Type                  | Surface Mount                                               |
| Operating Temperature          | 0°C ~ 85°C (TJ)                                             |
| Package / Case                 | 160-BQFP                                                    |
| Supplier Device Package        | 160-PQFP (28x28)                                            |
| Purchase URL                   | https://www.e-xfl.com/product-detail/xilinx/xc4008e-4pq160c |

Email: info@E-XFL.COM

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



Table 1: XC4000E and XC4000X Series Field Programmable Gate Arrays

|             |       | Max Logic | Max. RAM   | Typical          |         |       | Number     |          |
|-------------|-------|-----------|------------|------------------|---------|-------|------------|----------|
|             | Logic | Gates     | Bits       | Gate Range       | CLB     | Total | of         | Max.     |
| Device      | Cells | (No RAM)  | (No Logic) | (Logic and RAM)* | Matrix  | CLBs  | Flip-Flops | User I/O |
| XC4002XL    | 152   | 1,600     | 2,048      | 1,000 - 3,000    | 8 x 8   | 64    | 256        | 64       |
| XC4003E     | 238   | 3,000     | 3,200      | 2,000 - 5,000    | 10 x 10 | 100   | 360        | 80       |
| XC4005E/XL  | 466   | 5,000     | 6,272      | 3,000 - 9,000    | 14 x 14 | 196   | 616        | 112      |
| XC4006E     | 608   | 6,000     | 8,192      | 4,000 - 12,000   | 16 x 16 | 256   | 768        | 128      |
| XC4008E     | 770   | 8,000     | 10,368     | 6,000 - 15,000   | 18 x 18 | 324   | 936        | 144      |
| XC4010E/XL  | 950   | 10,000    | 12,800     | 7,000 - 20,000   | 20 x 20 | 400   | 1,120      | 160      |
| XC4013E/XL  | 1368  | 13,000    | 18,432     | 10,000 - 30,000  | 24 x 24 | 576   | 1,536      | 192      |
| XC4020E/XL  | 1862  | 20,000    | 25,088     | 13,000 - 40,000  | 28 x 28 | 784   | 2,016      | 224      |
| XC4025E     | 2432  | 25,000    | 32,768     | 15,000 - 45,000  | 32 x 32 | 1,024 | 2,560      | 256      |
| XC4028EX/XL | 2432  | 28,000    | 32,768     | 18,000 - 50,000  | 32 x 32 | 1,024 | 2,560      | 256      |
| XC4036EX/XL | 3078  | 36,000    | 41,472     | 22,000 - 65,000  | 36 x 36 | 1,296 | 3,168      | 288      |
| XC4044XL    | 3800  | 44,000    | 51,200     | 27,000 - 80,000  | 40 x 40 | 1,600 | 3,840      | 320      |
| XC4052XL    | 4598  | 52,000    | 61,952     | 33,000 - 100,000 | 44 x 44 | 1,936 | 4,576      | 352      |
| XC4062XL    | 5472  | 62,000    | 73,728     | 40,000 - 130,000 | 48 x 48 | 2,304 | 5,376      | 384      |
| XC4085XL    | 7448  | 85,000    | 100,352    | 55,000 - 180,000 | 56 x 56 | 3,136 | 7,168      | 448      |

<sup>\*</sup> Max values of Typical Gate Range include 20-30% of CLBs used as RAM.

**Note:** All functionality in low-voltage families is the same as in the corresponding 5-Volt family, except where numerical references are made to timing or power.

# Description

XC4000 Series devices are implemented with a regular, flexible, programmable architecture of Configurable Logic Blocks (CLBs), interconnected by a powerful hierarchy of versatile routing resources, and surrounded by a perimeter of programmable Input/Output Blocks (IOBs). They have generous routing resources to accommodate the most complex interconnect patterns.

The devices are customized by loading configuration data into internal memory cells. The FPGA can either actively read its configuration data from an external serial or byte-parallel PROM (master modes), or the configuration data can be written into the FPGA from an external device (slave and peripheral modes).

XC4000 Series FPGAs are supported by powerful and sophisticated software, covering every aspect of design from schematic or behavioral entry, floor planning, simulation, automatic block placement and routing of interconnects, to the creation, downloading, and readback of the configuration bit stream.

Because Xilinx FPGAs can be reprogrammed an unlimited number of times, they can be used in innovative designs where hardware is changed dynamically, or where hardware must be adapted to different user applications. FPGAs are ideal for shortening design and development cycles, and also offer a cost-effective solution for production rates well beyond 5,000 systems per month.

# Taking Advantage of Re-configuration

FPGA devices can be re-configured to change logic function while resident in the system. This capability gives the system designer a new degree of freedom not available with any other type of logic.

Hardware can be changed as easily as software. Design updates or modifications are easy, and can be made to products already in the field. An FPGA can even be re-configured dynamically to perform different functions at different times.

Re-configurable logic can be used to implement system self-diagnostics, create systems capable of being re-configured for different environments or operations, or implement multi-purpose hardware for a given application. As an added benefit, using re-configurable FPGA devices simplifies hardware design and debugging and shortens product time-to-market.





Figure 1: Simplified Block Diagram of XC4000 Series CLB (RAM and Carry Logic functions not shown)

# Flip-Flops

The CLB can pass the combinatorial output(s) to the interconnect network, but can also store the combinatorial results or other incoming data in one or two flip-flops, and connect their outputs to the interconnect network as well.

The two edge-triggered D-type flip-flops have common clock (K) and clock enable (EC) inputs. Either or both clock inputs can also be permanently enabled. Storage element functionality is described in Table 2.

### Latches (XC4000X only)

The CLB storage elements can also be configured as latches. The two latches have common clock (K) and clock enable (EC) inputs. Storage element functionality is described in Table 2.

# Clock Input

Each flip-flop can be triggered on either the rising or falling clock edge. The clock pin is shared by both storage elements. However, the clock is individually invertible for each storage element. Any inverter placed on the clock input is automatically absorbed into the CLB.

# Clock Enable

The clock enable signal (EC) is active High. The EC pin is shared by both storage elements. If left unconnected for either, the clock enable for that storage element defaults to the active state. EC is not invertible within the CLB.

Table 2: CLB Storage Element Functionality (active rising edge is shown)

| Mode               | K | EC | SR | D | Q  |
|--------------------|---|----|----|---|----|
| Power-Up or<br>GSR | Х | Х  | Х  | Х | SR |
|                    | Х | Х  | 1  | Х | SR |
| Flip-Flop          |   | 1* | 0* | D | D  |
|                    | 0 | Х  | 0* | Х | Q  |
| Latch              | 1 | 1* | 0* | Х | Q  |
| Lateri             | 0 | 1* | 0* | D | D  |
| Both               | Х | 0  | 0* | Х | Ø  |

Legend:

X Don't care
Rising edge

SR Set or Reset value. Reset is default.

0\* Input is Low or unconnected (default value)
1\* Input is High or unconnected (default value)

6-10 May 14, 1999 (Version 1.6)



#### 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.



tions of the CLB, with the exception of the redefinition of the control signals. In 16x2 and 16x1 modes, the H' function generator can be used to implement Boolean functions of F', G', and D1, and the D flip-flops can latch the F', G', H', or D0 signals.

### Single-Port Edge-Triggered Mode

Edge-triggered (synchronous) RAM simplifies timing requirements. XC4000 Series edge-triggered RAM timing operates like writing to a data register. Data and address are presented. The register is enabled for writing by a logic High on the write enable input, WE. Then a rising or falling clock edge loads the data into the register, as shown in Figure 3.



Figure 3: Edge-Triggered RAM Write Timing

Complex timing relationships between address, data, and write enable signals are not required, and the external write enable pulse becomes a simple clock enable. The active edge of WCLK latches the address, input data, and WE sig-

nals. An internal write pulse is generated that performs the write. See Figure 4 and Figure 5 for block diagrams of a CLB configured as 16x2 and 32x1 edge-triggered, single-port RAM.

The relationships between CLB pins and RAM inputs and outputs for single-port, edge-triggered mode are shown in Table 5.

The Write Clock input (WCLK) can be configured as active on either the rising edge (default) or the falling edge. It uses the same CLB pin (K) used to clock the CLB flip-flops, but it can be independently inverted. Consequently, the RAM output can optionally be registered within the same CLB either by the same clock edge as the RAM, or by the opposite edge of this clock. The sense of WCLK applies to both function generators in the CLB when both are configured as RAM.

The WE pin is active-High and is not invertible within the CLB.

**Note:** The pulse following the active edge of WCLK ( $T_{WPS}$  in Figure 3) must be less than one millisecond wide. For most applications, this requirement is not overly restrictive; however, it must not be forgotten. Stopping WCLK at this point in the write cycle could result in excessive current and even damage to the larger devices if many CLBs are configured as edge-triggered RAM.

Table 5: Single-Port Edge-Triggered RAM Signals

| RAM Signal | CLB Pin          | Function        |
|------------|------------------|-----------------|
| D          | D0 or D1 (16x2,  | Data In         |
|            | 16x1), D0 (32x1) |                 |
| A[3:0]     | F1-F4 or G1-G4   | Address         |
| A[4]       | D1 (32x1)        | Address         |
| WE         | WE               | Write Enable    |
| WCLK       | K                | Clock           |
| SPO        | F' or G'         | Single Port Out |
| (Data Out) |                  | (Data Out)      |



Any XC4000 Series 5-Volt device with its outputs configured in TTL mode can drive the inputs of any typical 3.3-Volt device. (For a detailed discussion of how to interface between 5 V and 3.3 V devices, see the 3V Products section of *The Programmable Logic Data Book*.)

Supported destinations for XC4000 Series device outputs are shown in Table 12.

An output can be configured as open-drain (open-collector) by placing an OBUFT symbol in a schematic or HDL code, then tying the 3-state pin (T) to the output signal, and the input pin (I) to Ground. (See Figure 18.)

Table 12: Supported Destinations for XC4000 Series Outputs

|                                  | XC4000 Series<br>Outputs |             |                   |  |  |  |
|----------------------------------|--------------------------|-------------|-------------------|--|--|--|
| Destination                      | 3.3 V,<br>CMOS           | 5 V,<br>TTL | 5 V,<br>CMOS      |  |  |  |
| Any typical device, Vcc = 3.3 V, | <b>V</b>                 | V           | some <sup>1</sup> |  |  |  |
| CMOS-threshold inputs            |                          |             |                   |  |  |  |
| Any device, Vcc = 5 V,           | V                        | V           | √                 |  |  |  |
| TTL-threshold inputs             |                          |             |                   |  |  |  |
| Any device, Vcc = 5 V,           | Unre                     | liable      | √                 |  |  |  |
| CMOS-threshold inputs            | Da                       | ata         |                   |  |  |  |

1. Only if destination device has 5-V tolerant inputs



Figure 18: Open-Drain Output

### **Output Slew Rate**

The slew rate of each output buffer is, by default, reduced, to minimize power bus transients when switching non-critical signals. For critical signals, attach a FAST attribute or property to the output buffer or flip-flop.

For XC4000E devices, maximum total capacitive load for simultaneous fast mode switching in the same direction is 200 pF for all package pins between each Power/Ground pin pair. For XC4000X devices, additional internal

Power/Ground pin pairs are connected to special Power and Ground planes within the packages, to reduce ground bounce. Therefore, the maximum total capacitive load is 300 pF between each external Power/Ground pin pair. Maximum loading may vary for the low-voltage devices.

For slew-rate limited outputs this total is two times larger for each device type: 400 pF for XC4000E devices and 600 pF for XC4000X devices. This maximum capacitive load should not be exceeded, as it can result in ground bounce of greater than 1.5 V amplitude and more than 5 ns duration. This level of ground bounce may cause undesired transient behavior on an output, or in the internal logic. This restriction is common to all high-speed digital ICs, and is not particular to Xilinx or the XC4000 Series.

XC4000 Series devices have a feature called "Soft Start-up," designed to reduce ground bounce when all outputs are turned on simultaneously at the end of configuration. When the configuration process is finished and the device starts up, the first activation of the outputs is automatically slew-rate limited. Immediately following the initial activation of the I/O, the slew rate of the individual outputs is determined by the individual configuration option for each IOB.

#### **Global Three-State**

A separate Global 3-State line (not shown in Figure 15 or Figure 16) forces all FPGA outputs to the high-impedance state, unless boundary scan is enabled and is executing an EXTEST instruction. This global net (GTS) does not compete with other routing resources; it uses a dedicated distribution network.

GTS can be driven from any user-programmable pin as a global 3-state input. To use this global net, place an input pad and input buffer in the schematic or HDL code, driving the GTS pin of the STARTUP symbol. 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 3-State signal. Using GTS is similar to GSR. See Figure 2 on page 11 for details.

Alternatively, GTS can be driven from any internal node.





Figure 27: Detail of Programmable Interconnect Associated with XC4000 Series CLB

6-30 May 14, 1999 (Version 1.6)





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





Figure 34: XC4000E Global Net Distribution



Figure 35: XC4000X Global Net Distribution

6-36 May 14, 1999 (Version 1.6)



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** 

|               | I/O<br>During | I/O<br>After                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------|---------------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin Name      | Config.       | Config.                      | Pin Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Permanently D | edicated      | Pins                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| VCC           | I             | I                            | 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 connected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| CCLK          | I or O        | I                            | During configuration, Configuration Clock (CCLK) is an output in Master modes or Asynchronous Peripheral mode, but is an input in Slave mode and Synchronous Peripheral mode. After configuration, CCLK has a weak pull-up resistor and can be selected as the Readback Clock. There is no CCLK High or Low time restriction on XC4000 Series devices, except during Readback. See "Violating the Maximum High and Low Time Specification 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 step program that creates the configuration bitstream. The resistor is included by default.                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| PROGRAM       | I             | I                            | PROGRAM is an active Low input that forces the FPGA to clear its configuration memory. It is used to initiate a configuration cycle. When PROGRAM goes High, the FPGA finishes the current clear cycle and executes another complete clear cycle, before it goes into a WAIT state and releases INIT.  The PROGRAM pin has a permanent weak pull-up, so it need not be externally pulled up to Vcc.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| User I/O Pins | That Can      | Have Spe                     | ecial Functions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| RDY/BUSY      | 0             | I/O                          | During Peripheral mode configuration, this pin indicates when it is appropriate to write another byte of data into the FPGA. The same status is also available on D7 in Asynchronous Peripheral mode, if a read operation is performed when the device is selected. After configuration, RDY/BUSY is a user-programmable I/O pin.  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    | I             | I (M0),<br>O (M1),<br>I (M2) | As Mode inputs, these pins are sampled after $\overline{\text{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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |



# Setting CCLK Frequency

For Master modes, CCLK can be generated in either of two frequencies. In the default slow mode, the frequency ranges from 0.5 MHz to 1.25 MHz for XC4000E and XC4000EX devices and from 0.6 MHz to 1.8 MHz for XC4000XL devices. In fast CCLK mode, the frequency ranges from 4 MHz to 10 MHz for XC4000E/EX devices and from 5 MHz to 15 MHz for XC4000XL devices. The frequency is selected by an option when running the bitstream generation software. If an XC4000 Series Master is driving an XC3000- or XC2000-family slave, slow CCLK mode must be used. In addition, an XC4000XL device driving a XC4000E or XC4000EX should use slow mode. Slow mode is the default.

Table 19: XC4000 Series Data Stream Formats

| Data Type          | All Other<br>Modes (D0) |
|--------------------|-------------------------|
| Fill Byte          | 11111111b               |
| Preamble Code      | 0010b                   |
| Length Count       | COUNT(23:0)             |
| Fill Bits          | 1111b                   |
| Start Field        | 0b                      |
| Data Frame         | DATA(n-1:0)             |
| CRC or Constant    | xxxx (CRC)              |
| Field Check        | or 0110b                |
| Extend Write Cycle | _                       |
| Postamble          | 01111111b               |
| Start-Up Bytes     | xxh                     |
| Legend:            |                         |
| Not shaded         | Once per bitstream      |
| Light              | Once per data frame     |
| Dark               | Once per device         |

### **Data Stream Format**

The data stream ("bitstream") format is identical for all configuration modes.

The data stream formats are shown in Table 19. Bit-serial data is read from left to right, and byte-parallel data is effectively assembled from this serial bitstream, with the first bit in each byte assigned to D0.

The configuration data stream begins with a string of eight ones, a preamble code, followed by a 24-bit length count and a separator field of ones. This header is followed by the actual configuration data in frames. The length and number of frames depends on the device type (see Table 20 and Table 21). Each frame begins with a start field and ends with an error check. A postamble code is required to signal the end of data for a single device. In all cases, additional start-up bytes of data are required to provide four clocks for the startup sequence at the end of configuration. Long daisy chains require additional startup bytes to shift the last data through the chain. All startup bytes are don't-cares; these bytes are not included in bitstreams created by the Xilinx software.

A selection of CRC or non-CRC error checking is allowed by the bitstream generation software. The non-CRC error checking tests for a designated end-of-frame field for each frame. For CRC error checking, the software calculates a running CRC and inserts a unique four-bit partial check at the end of each frame. The 11-bit CRC check of the last frame of an FPGA includes the last seven data bits.

Detection of an error results in the suspension of data loading and the pulling down of the  $\overline{\text{INIT}}$  pin. In Master modes, CCLK and address signals continue to operate externally. The user must detect  $\overline{\text{INIT}}$  and initialize a new configuration by pulsing the  $\overline{\text{PROGRAM}}$  pin Low or cycling Vcc.

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



The default option, and the most practical one, is for DONE to go High first, disconnecting the configuration data source and avoiding any contention when the I/Os become active one clock later. Reset/Set is then released another clock period later to make sure that user-operation starts from stable internal conditions. This is the most common sequence, shown with heavy lines in Figure 47, but the designer can modify it to meet particular requirements.

Normally, the start-up sequence is controlled by the internal device oscillator output (CCLK), which is asynchronous to the system clock.

XC4000 Series offers another start-up clocking option, UCLK\_NOSYNC. The three events described above need not be triggered by CCLK. They can, as a configuration option, be triggered by a user clock. This means that the device can wake up in synchronism with the user system.

When the UCLK\_SYNC option is enabled, the user can externally hold the open-drain DONE output Low, and thus stall all further progress in the start-up sequence until DONE is released and has gone High. This option can be used to force synchronization of several FPGAs to a common user clock, or to guarantee that all devices are successfully configured before any I/Os go active.

If either of these two options is selected, and no user clock is specified in the design or attached to the device, the chip could reach a point where the configuration of the device is complete and the Done pin is asserted, but the outputs do not become active. The solution is either to recreate the bitstream specifying the start-up clock as CCLK, or to supply the appropriate user clock.

# Start-up Sequence

The Start-up sequence begins when the configuration memory is full, and the total number of configuration clocks

received since  $\overline{\text{INIT}}$  went High equals the loaded value of the length count.

The next rising clock edge sets a flip-flop Q0, shown in Figure 48. Q0 is the leading bit of a 5-bit shift register. The outputs of this register can be programmed to control three events.

- The release of the open-drain DONE output
- The change of configuration-related pins to the user function, activating all IOBs.
- The termination of the global Set/Reset initialization of all CLB and IOB storage elements.

The DONE pin can also be wire-ANDed with DONE pins of other FPGAs or with other external signals, and can then be used as input to bit Q3 of the start-up register. This is called "Start-up Timing Synchronous to Done In" and is selected by either CCLK SYNC or UCLK SYNC.

When DONE is not used as an input, the operation is called "Start-up Timing Not Synchronous to DONE In," and is selected by either CCLK\_NOSYNC or UCLK\_NOSYNC.

As a configuration option, the start-up control register beyond Q0 can be clocked either by subsequent CCLK pulses or from an on-chip user net called STARTUP.CLK. These signals can be accessed by placing the STARTUP library symbol.

## **Start-up from CCLK**

If CCLK is used to drive the start-up, Q0 through Q3 provide the timing. Heavy lines in Figure 47 show the default timing, which is compatible with XC2000 and XC3000 devices using early DONE and late Reset. The thin lines indicate all other possible timing options.

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



# 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 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.



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 23: Pin Functions During Configuration** 

| CONFIGURATION MODE <m2:m1:m0></m2:m1:m0> |                             |                           |                            |                                    |                                  |                   |  |  |  |  |
|------------------------------------------|-----------------------------|---------------------------|----------------------------|------------------------------------|----------------------------------|-------------------|--|--|--|--|
| SLAVE<br>SERIAL<br><1:1:1>               | MASTER<br>SERIAL<br><0:0:0> | SYNCH. PERIPHERAL <0:1:1> | ASYNCH. PERIPHERAL <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)                     | (1)               |  |  |  |  |
| 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)                      | (1)               |  |  |  |  |
| 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               |  |  |  |  |
| ĪNĪT                                     | ĪNIT                        | ĪNĪT                      | ĪNIT                       | ĪNĪT                               | ĪNĪT                             | 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 (O)              | RDY/BUSY (O)               | RCLK (O)                           | RCLK (O)                         | I/O               |  |  |  |  |
|                                          |                             |                           | RS (I)                     | , ,                                | ` '                              | I/O               |  |  |  |  |
|                                          |                             |                           | CSO (I)                    |                                    |                                  | I/O               |  |  |  |  |
|                                          |                             | DATA 7 (I)                | DATA 7 (I)                 | DATA 7 (I)                         | DATA 7 (I)                       | I/O               |  |  |  |  |
|                                          |                             | 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/C    |  |  |  |  |
| 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)           |  |  |  |  |
| 150                                      |                             | 1.50                      | WS (I)                     | A0                                 | A0                               | I/O               |  |  |  |  |
|                                          |                             |                           | 110 (1)                    | A1                                 | A1                               | PGCK4-GCK7-I/C    |  |  |  |  |
|                                          |                             |                           | CS1                        | A2                                 | A2                               | 1/0               |  |  |  |  |
|                                          |                             |                           | 001                        | 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               |  |  |  |  |
|                                          |                             |                           |                            | A13                                | A14                              | I/O               |  |  |  |  |
|                                          |                             |                           |                            | A15                                | A15                              | SGCK1-GCK8-I/C    |  |  |  |  |
|                                          |                             |                           |                            | A16                                | A16                              | PGCK1-GCK6-I/C    |  |  |  |  |
|                                          |                             |                           |                            | A17                                | A17                              | I/O               |  |  |  |  |
|                                          |                             |                           |                            | A17<br>A18*                        | A17<br>A18*                      | I/O               |  |  |  |  |
|                                          |                             |                           |                            | A18*                               | A18"<br>A19*                     | I/O               |  |  |  |  |
|                                          |                             |                           |                            | A19<br>A20*                        | A19<br>A20*                      | I/O               |  |  |  |  |
|                                          |                             |                           |                            | A20<br>A21*                        | A20<br>A21*                      | I/O               |  |  |  |  |
|                                          |                             |                           |                            | AZT                                | AZT"                             | 1/0               |  |  |  |  |

<sup>\*</sup> XC4000X only

Notes 1. A shaded table cell represents a 50 k $\Omega$  - 100 k $\Omega$  pull-up before and during configuration.

 <sup>(</sup>I) represents an input; (O) represents an output.
 INIT is an open-drain output during configuration.



# **Configuration Timing**

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.

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    |
| CCLR | High time   | 4 | T <sub>CCH</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





|      | 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         | T <sub>CCH</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

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



Table 25: Component Availability Chart for XC4000E FPGAs

| F          | PINS | 84             | 100            | 100            | 120           | 144            | 156           | 160            | 191           | 208               | 208            | 223           | 225           | 240               | 240            | 299           | 304              |
|------------|------|----------------|----------------|----------------|---------------|----------------|---------------|----------------|---------------|-------------------|----------------|---------------|---------------|-------------------|----------------|---------------|------------------|
| Т          | YPE  | Plast.<br>PLCC | Plast.<br>PQFP | Plast.<br>VQFP | Ceram.<br>PGA | Plast.<br>TQFP | Ceram.<br>PGA | Plast.<br>PQFP | Ceram.<br>PGA | High-Perf.<br>QFP | Plast.<br>PQFP | Ceram.<br>PGA | Plast.<br>BGA | High-Perf.<br>QFP | Plast.<br>PQFP | Ceram.<br>PGA | High-Perf.<br>QF |
| co         | DDE  | PC84           | PQ100          | VQ100          | PG120         | TQ144          | PG156         | PQ160          | PG191         | HQ208             | PQ208          | PG223         | BG225         | HQ240             | PQ240          | PG299         | HQ304 High-Perf. |
|            | -4   | CI             | CI             | CI             | CI            |                |               |                |               |                   |                |               |               |                   |                |               |                  |
| XC4003E    | -3   | СІ             | СІ             | СІ             | СІ            |                |               |                |               |                   |                |               |               |                   |                |               |                  |
| AC4003E    | -2   | CI             | СІ             | CI             | CI            |                |               |                |               |                   |                |               |               |                   |                |               |                  |
|            | -1   | С              | С              | С              | С             |                |               |                |               |                   |                |               |               |                   |                |               |                  |
|            | -4   | СІ             | СІ             |                |               | СІ             | СІ            | CI             |               |                   | CI             |               |               |                   |                |               |                  |
| XC4005E    | -3   | СІ             | СІ             |                |               | СІ             | СІ            | СІ             |               |                   | СІ             |               |               |                   |                |               |                  |
| AC4005E    | -2   | CI             | СІ             |                |               | СІ             | СІ            | СІ             |               |                   | СІ             |               |               |                   |                |               |                  |
| İ          | -1   | С              | С              |                |               | С              | С             | С              |               |                   | С              |               |               |                   |                |               |                  |
|            | -4   | CI             |                |                |               | CI             | СІ            | СІ             |               |                   | CI             |               |               |                   |                |               |                  |
| XC4006E    | -3   | СІ             |                |                |               | CI             | СІ            | СІ             |               |                   | CI             |               |               |                   |                |               |                  |
| AC4000E    | -2   | CI             |                |                |               | CI             | CI            | CI             |               |                   | CI             |               |               |                   |                |               |                  |
| Ī          | -1   | С              |                |                |               | С              | С             | С              |               |                   | С              |               |               |                   |                |               |                  |
|            | -4   | СІ             |                |                |               |                |               | CI             | CI            |                   | CI             |               |               |                   |                |               |                  |
| XC4008E    | -3   | СІ             |                |                |               |                |               | СІ             | CI            |                   | CI             |               |               |                   |                |               |                  |
| AC4000L    | -2   | CI             |                |                |               |                |               | CI             | CI            |                   | CI             |               |               |                   |                |               |                  |
|            | -1   | С              |                |                |               |                |               | С              | С             |                   | С              |               |               |                   |                |               |                  |
|            | -4   | CI             |                |                |               |                |               | CI             | CI            | CI                | CI             |               | CI            |                   |                |               |                  |
| XC4010E    | -3   | CI             |                |                |               |                |               | CI             | CI            | CI                | CI             |               | CI            |                   |                |               |                  |
| AC4010L    | -2   | CI             |                |                |               |                |               | CI             | CI            | CI                | CI             |               | CI            |                   |                |               |                  |
|            | -1   | С              |                |                |               |                |               | С              | С             | С                 | С              |               | С             |                   |                |               |                  |
|            | -4   |                |                |                |               |                |               | CI             |               | CI                | CI             | CI            | CI            | CI                | CI             |               |                  |
| XC4013E    | -3   |                |                |                |               |                |               | CI             |               | CI                | CI             | CI            | CI            | CI                | CI             |               |                  |
| , .O 1010L | -2   |                |                |                |               |                |               | CI             |               | CI                | CI             | CI            | CI            | CI                | CI             |               |                  |
|            | -1   |                |                |                |               |                |               | С              |               | С                 | С              | С             | С             | С                 | С              |               |                  |
|            | -4   |                |                |                |               |                |               |                |               | CI                |                | CI            |               | CI                |                |               |                  |
| XC4020E    | -3   |                |                |                |               |                |               |                |               | CI                |                | CI            |               | CI                |                |               |                  |
| 7.0 10202  | -2   |                |                |                |               |                |               |                |               | CI                |                | CI            |               | CI                |                |               |                  |
|            | -1   |                |                |                |               |                |               |                |               | С                 |                | С             |               | С                 |                |               |                  |
| <u>-</u>   | -4   |                |                |                |               |                |               |                |               |                   |                | CI            |               | CI                |                | CI            | CI               |
| XC4025E    | -3   |                |                |                |               |                |               |                |               |                   |                | CI            |               | CI                |                | CI            | CI               |
| 1/29/99    | -2   |                |                |                |               |                |               |                |               |                   |                | С             |               | С                 |                | С             | С                |

C = Commercial  $T_J = 0^{\circ}$  to +85°C I= Industrial  $T_J = -40^{\circ}$ C to +100°C

Table 26: Component Availability Chart for XC4000EX FPGAs

| į        | PINS |                   | 240               | 299           | 304               | 352           | 411           | 432           |
|----------|------|-------------------|-------------------|---------------|-------------------|---------------|---------------|---------------|
| TYPE     |      | High-Perf.<br>QFP | High-Perf.<br>QFP | Ceram.<br>PGA | High-Perf.<br>QFP | Plast.<br>BGA | Ceram.<br>PGA | Plast.<br>BGA |
| С        | ODE  | HQ208             | HQ240             | PG299         | HQ304             | BG352         | PG411         | BG432         |
|          | -4   | CI                | CI                | CI            | CI                | CI            |               |               |
| XC4028EX | -3   | CI                | CI                | CI            | CI                | CI            |               |               |
|          | -2   | С                 | С                 | С             | С                 | С             |               |               |
|          | -4   |                   | CI                |               | CI                | CI            | CI            | CI            |
| XC4036EX | -3   |                   | CI                |               | CI                | CI            | CI            | CI            |
|          | -2   |                   | С                 |               | С                 | С             | С             | С             |

1/29/99

C = Commercial  $T_J = 0^{\circ}$  to +85°C I= Industrial  $T_J = -40^{\circ}$ C to +100°C



# **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 Chart for XC4000XL FPGAs

|            |     |      | Maximum User Accessible I/O by Package Type |       |       |       |       |       |       |       |       |       |       |       |       |      |       |      |       |       |      |      |       |
|------------|-----|------|---------------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|------|-------|------|-------|-------|------|------|-------|
| <b>.</b> . | Max | PC84 | PQ100                                       | VQ100 | TQ144 | HT144 | HQ160 | PQ160 | TQ176 | HT176 | HQ208 | PQ208 | HQ240 | PQ240 | BG256 | G299 | HQ304 | G352 | PG411 | BG432 | G475 | G259 | BG560 |
| Device     | I/O | П    | ď                                           | >     | Ĕ     | I     | Ĭ     | ď     | Ĕ     | I     | Ĭ     | ď     | Ĭ     | ď     | ă     | ď    | Ĭ     | ă    | ď     | ă     | ď    | ď    | ă     |
| 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                                       | /Q100 | G120 | -Q144 | G156 | PQ160    | PG191 | HQ208 | PQ208 | PG223 | BG225 | HQ240 | Q240     | G299     | HQ304 |
| XC4003E | 80         | 61   | 77                                          | 77    | 80   |       | ۵    | <u> </u> | ш.    |       | ш.    | ш     | ш     |       | <u> </u> | <u> </u> |       |
| 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