# E·XFL

#### AMD Xilinx - XC4006E-2PQ160I Datasheet



Welcome to <u>E-XFL.COM</u>

#### Understanding <u>Embedded - FPGAs (Field</u> <u>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

| Details                        |                                                             |
|--------------------------------|-------------------------------------------------------------|
| Product Status                 | Obsolete                                                    |
| Number of LABs/CLBs            | 256                                                         |
| Number of Logic Elements/Cells | 608                                                         |
| Total RAM Bits                 | 8192                                                        |
| Number of I/O                  | 128                                                         |
| Number of Gates                | 6000                                                        |
| Voltage - Supply               | 4.5V ~ 5.5V                                                 |
| Mounting Type                  | Surface Mount                                               |
| Operating Temperature          | -40°C ~ 100°C (TJ)                                          |
| Package / Case                 | 160-BQFP                                                    |
| Supplier Device Package        | 160-PQFP (28x28)                                            |
| Purchase URL                   | https://www.e-xfl.com/product-detail/xilinx/xc4006e-2pq160i |
|                                |                                                             |

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.

# **Detailed Functional Description**

XC4000 Series devices achieve high speed through advanced semiconductor technology and improved architecture. The XC4000E and XC4000X support system clock rates of up to 80 MHz and internal performance in excess of 150 MHz. Compared to older Xilinx FPGA families, XC4000 Series devices are more powerful. They offer on-chip edge-triggered and dual-port RAM, clock enables on I/O flip-flops, and wide-input decoders. They are more versatile in many applications, especially those involving RAM. Design cycles are faster due to a combination of increased routing resources and more sophisticated software.

## **Basic Building Blocks**

Xilinx user-programmable gate arrays include two major configurable elements: configurable logic blocks (CLBs) and input/output blocks (IOBs).

- CLBs provide the functional elements for constructing the user's logic.
- IOBs provide the interface between the package pins and internal signal lines.

Three other types of circuits are also available:

- 3-State buffers (TBUFs) driving horizontal longlines are associated with each CLB.
- Wide edge decoders are available around the periphery of each device.
- An on-chip oscillator is provided.

Programmable interconnect resources provide routing paths to connect the inputs and outputs of these configurable elements to the appropriate networks.

The functionality of each circuit block is customized during configuration by programming internal static memory cells. The values stored in these memory cells determine the logic functions and interconnections implemented in the FPGA. Each of these available circuits is described in this section.

# Configurable Logic Blocks (CLBs)

Configurable Logic Blocks implement most of the logic in an FPGA. The principal CLB elements are shown in Figure 1. Two 4-input function generators (F and G) offer unrestricted versatility. Most combinatorial logic functions need four or fewer inputs. However, a third function generator (H) is provided. The H function generator has three inputs. Either zero, one, or two of these inputs can be the outputs of F and G; the other input(s) are from outside the CLB. The CLB can, therefore, implement certain functions of up to nine variables, like parity check or expandable-identity comparison of two sets of four inputs. Each CLB contains two storage elements that can be used to store the function generator outputs. However, the storage elements and function generators can also be used independently. These storage elements can be configured as flip-flops in both XC4000E and XC4000X devices; in the XC4000X they can optionally be configured as latches. DIN can be used as a direct input to either of the two storage elements. H1 can drive the other through the H function generator. Function generator outputs can also drive two outputs independent of the storage element outputs. This versatility increases logic capacity and simplifies routing.

Thirteen CLB inputs and four CLB outputs provide access to the function generators and storage elements. These inputs and outputs connect to the programmable interconnect resources outside the block.

#### **Function Generators**

Four independent inputs are provided to each of two function generators (F1 - F4 and G1 - G4). These function generators, with outputs labeled F' and G', are each capable of implementing any arbitrarily defined Boolean function of four inputs. The function generators are implemented as memory look-up tables. The propagation delay is therefore independent of the function implemented.

A third function generator, labeled H', can implement any Boolean function of its three inputs. Two of these inputs can optionally be the F' and G' functional generator outputs. Alternatively, one or both of these inputs can come from outside the CLB (H2, H0). The third input must come from outside the block (H1).

Signals from the function generators can exit the CLB on two outputs. F' or H' can be connected to the X output. G' or H' can be connected to the Y output.

A CLB can be used to implement any of the following functions:

- any function of up to four variables, plus any second function of up to four unrelated variables, plus any third function of up to three unrelated variables<sup>1</sup>
- any single function of five variables
- any function of four variables together with some functions of six variables
- some functions of up to nine variables.

Implementing wide functions in a single block reduces both the number of blocks required and the delay in the signal path, achieving both increased capacity and speed.

The versatility of the CLB function generators significantly improves system speed. In addition, the design-software tools can deal with each function generator independently. This flexibility improves cell usage.

<sup>1.</sup> When three separate functions are generated, one of the function outputs must be captured in a flip-flop internal to the CLB. Only two unregistered function generator outputs are available from the CLB.



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.

| (uotiro noing      | euge le | ,  |    |   |    |
|--------------------|---------|----|----|---|----|
| Mode               | K       | EC | SR | D | Q  |
| Power-Up or<br>GSR | Х       | Х  | x  | Х | SR |
|                    | Х       | Х  | 1  | Х | SR |
| Flip-Flop          |         | 1* | 0* | D | D  |
|                    | 0       | Х  | 0* | Х | Q  |
| Latch              | 1 1     |    | 0* | Х | Q  |
| Laton              | 0       | 1* | 0* | D | D  |
| Both               | Х       | 0  | 0* | Х | Q  |

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

Legend:

X Don't care

\_/ Rising edge SR Set or Reset v

R Set or Reset value. Reset is default.

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

XILINX<sup>®</sup>



Supported CLB memory configurations and timing modes for single- and dual-port modes are shown in Table 3.

XC4000 Series devices are the first programmable logic devices with edge-triggered (synchronous) and dual-port RAM accessible to the user. Edge-triggered RAM simplifies system timing. Dual-port RAM doubles the effective throughput of FIFO applications. These features can be individually programmed in any XC4000 Series CLB.

#### Advantages of On-Chip and Edge-Triggered RAM

The on-chip RAM is extremely fast. The read access time is the same as the logic delay. The write access time is slightly slower. Both access times are much faster than any off-chip solution, because they avoid I/O delays.

Edge-triggered RAM, also called synchronous RAM, is a feature never before available in a Field Programmable Gate Array. The simplicity of designing with edge-triggered RAM, and the markedly higher achievable performance, add up to a significant improvement over existing devices with on-chip RAM.

Three application notes are available from Xilinx that discuss edge-triggered RAM: "*XC4000E Edge-Triggered and Dual-Port RAM Capability*," "*Implementing FIFOs in XC4000E RAM*," and "*Synchronous and Asynchronous FIFO Designs*." All three application notes apply to both XC4000E and XC4000X RAM.

#### Table 3: Supported RAM Modes

|             | 16<br>x<br>1 | 16<br>x<br>2 | 32<br>x<br>1 | Edge-<br>Triggered<br>Timing | Level-<br>Sensitive<br>Timing |
|-------------|--------------|--------------|--------------|------------------------------|-------------------------------|
| Single-Port |              | $\checkmark$ |              | $\checkmark$                 |                               |
| Dual-Port   |              |              |              | $\checkmark$                 |                               |

#### **RAM Configuration Options**

The function generators in any CLB can be configured as RAM arrays in the following sizes:

- Two 16x1 RAMs: two data inputs and two data outputs with identical or, if preferred, different addressing for each RAM
- One 32x1 RAM: one data input and one data output.

One F or G function generator can be configured as a 16x1 RAM while the other function generators are used to implement any function of up to 5 inputs.

Additionally, the XC4000 Series RAM may have either of two timing modes:

- Edge-Triggered (Synchronous): data written by the designated edge of the CLB clock. WE acts as a true clock enable.
- Level-Sensitive (Asynchronous): an external WE signal acts as the write strobe.

The selected timing mode applies to both function generators within a CLB when both are configured as RAM.

The number of read ports is also programmable:

- Single Port: each function generator has a common read and write port
- Dual Port: both function generators are configured together as a single 16x1 dual-port RAM with one write port and two read ports. Simultaneous read and write operations to the same or different addresses are supported.

RAM configuration options are selected by placing the appropriate library symbol.

#### **Choosing a RAM Configuration Mode**

The appropriate choice of RAM mode for a given design should be based on timing and resource requirements, desired functionality, and the simplicity of the design process. Recommended usage is shown in Table 4.

The difference between level-sensitive, edge-triggered, and dual-port RAM is only in the write operation. Read operation and timing is identical for all modes of operation.

#### Table 4: RAM Mode Selection

|                            | Level-Sens<br>itive | Edge-Trigg<br>ered | Dual-Port<br>Edge-Trigg<br>ered |
|----------------------------|---------------------|--------------------|---------------------------------|
| Use for New<br>Designs?    | No                  | Yes                | Yes                             |
| Size (16x1,<br>Registered) | 1/2 CLB             | 1/2 CLB            | 1 CLB                           |
| Simultaneous<br>Read/Write | No                  | No                 | Yes                             |
| Relative<br>Performance    | Х                   | 2X                 | 2X (4X<br>effective)            |

#### **RAM Inputs and Outputs**

The F1-F4 and G1-G4 inputs to the function generators act as address lines, selecting a particular memory cell in each look-up table.

The functionality of the CLB control signals changes when the function generators are configured as RAM. The DIN/H2, H1, and SR/H0 lines become the two data inputs (D0, D1) and the Write Enable (WE) input for the 16x2 memory. When the 32x1 configuration is selected, D1 acts as the fifth address bit and D0 is the data input.

The contents of the memory cell(s) being addressed are available at the F' and G' function-generator outputs. They can exit the CLB through its X and Y outputs, or can be captured in the CLB flip-flop(s).

Configuring the CLB function generators as Read/Write memory does not affect the functionality of the other por-



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



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

# Output Multiplexer/2-Input Function Generator (XC4000X only)

As shown in Figure 16 on page 21, the output path in the XC4000X IOB contains an additional multiplexer not available in the XC4000E IOB. The multiplexer can also be configured as a 2-input function generator, implementing a pass-gate, AND-gate, OR-gate, or XOR-gate, with 0, 1, or 2 inverted inputs. The logic used to implement these functions is shown in the upper gray area of Figure 16.

When configured as a multiplexer, this feature allows two output signals to time-share the same output pad; effectively doubling the number of device outputs without requiring a larger, more expensive package.

When the MUX is configured as a 2-input function generator, logic can be implemented within the IOB itself. Combined with a Global Early buffer, this arrangement allows very high-speed gating of a single signal. For example, a wide decoder can be implemented in CLBs, and its output gated with a Read or Write Strobe Driven by a BUFGE buffer, as shown in Figure 19. The critical-path pin-to-pin delay of this circuit is less than 6 nanoseconds.

As shown in Figure 16, the IOB input pins Out, Output Clock, and Clock Enable have different delays and different flexibilities regarding polarity. Additionally, Output Clock sources are more limited than the other inputs. Therefore, the Xilinx software does not move logic into the IOB function generators unless explicitly directed to do so.

The user can specify that the IOB function generator be used, by placing special library symbols beginning with the letter "O." For example, a 2-input AND-gate in the IOB function generator is called OAND2. Use the symbol input pin labelled "F" for the signal on the critical path. This signal is placed on the OK pin — the IOB input with the shortest delay to the function generator. Two examples are shown in Figure 20.



X9019







### Other IOB Options

There are a number of other programmable options in the XC4000 Series IOB.

#### Pull-up and Pull-down Resistors

Programmable pull-up and pull-down resistors are useful for tying unused pins to Vcc or Ground to minimize power consumption and reduce noise sensitivity. The configurable pull-up resistor is a p-channel transistor that pulls to Vcc. The configurable pull-down resistor is an n-channel transistor that pulls to Ground.

The value of these resistors is 50 k $\Omega$  – 100 k $\Omega$ . This high value makes them unsuitable as wired-AND pull-up resistors.

The pull-up resistors for most user-programmable IOBs are active during the configuration process. See Table 22 on page 58 for a list of pins with pull-ups active before and during configuration.

After configuration, voltage levels of unused pads, bonded or un-bonded, must be valid logic levels, to reduce noise sensitivity and avoid excess current. Therefore, by default, unused pads are configured with the internal pull-up resistor active. Alternatively, they can be individually configured with the pull-down resistor, or as a driven output, or to be driven by an external source. To activate the internal pull-up, attach the PULLUP library component to the net attached to the pad. To activate the internal pull-down, attach the PULLDOWN library component to the net attached to the pad.

#### **Independent Clocks**

Separate clock signals are provided for the input and output flip-flops. The clock can be independently inverted for each flip-flop within the IOB, generating either falling-edge or rising-edge triggered flip-flops. The clock inputs for each IOB are independent, except that in the XC4000X, the Fast Capture latch shares an IOB input with the output clock pin.

#### Early Clock for IOBs (XC4000X only)

Special early clocks are available for IOBs. These clocks are sourced by the same sources as the Global Low-Skew buffers, but are separately buffered. They have fewer loads and therefore less delay. The early clock can drive either the IOB output clock or the IOB input clock, or both. The early clock allows fast capture of input data, and fast clock-to-output on output data. The Global Early buffers that drive these clocks are described in "Global Nets and Buffers (XC4000X only)" on page 37.

#### **Global Set/Reset**

As with the CLB registers, the Global Set/Reset signal (GSR) can be used to set or clear the input and output registers, depending on the value of the INIT attribute or property. The two flip-flops can be individually configured to set 6





Common to XC4000E and XC4000X

Programmable Switch Matrix

XC4000X only



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 31: High-Level Routing Diagram of XC4000 Series VersaRing (Left Edge) WED = Wide Edge Decoder, IOB = I/O Block (shaded arrows indicate XC4000X only)



Figure 32: XC4000X Octal I/O Routing

#### Global Nets and Buffers (XC4000X only)

Eight vertical longlines in each CLB column are driven by special global buffers. These longlines are in addition to the vertical longlines used for standard interconnect. The global lines are broken in the center of the array, to allow faster distribution and to minimize skew across the whole array. Each half-column global line has its own buffered multiplexer, as shown in Figure 35. The top and bottom global lines cannot be connected across the center of the device, as this connection might introduce unacceptable skew. The top and bottom halves of the global lines must be separately driven — although they can be driven by the same global buffer.

The eight global lines in each CLB column can be driven by either of two types of global buffers. They can also be driven by internal logic, because they can be accessed by single, double, and quad lines at the top, bottom, half, and quarter points. Consequently, the number of different clocks that can be used simultaneously in an XC4000X device is very large.

There are four global lines feeding the IOBs at the left edge of the device. IOBs along the right edge have eight global lines. There is a single global line along the top and bottom edges with access to the IOBs. All IOB global lines are broken at the center. They cannot be connected across the center of the device, as this connection might introduce unacceptable skew.

IOB global lines can be driven from two types of global buffers, or from local interconnect. Alternatively, top and bottom IOBs can be clocked from the global lines in the adjacent CLB column.

Two different types of clock buffers are available in the XC4000X:

- Global Low-Skew Buffers (BUFGLS)
- Global Early Buffers (BUFGE)

Global Low-Skew Buffers are the standard clock buffers. They should be used for most internal clocking, whenever a large portion of the device must be driven.

Global Early Buffers are designed to provide a faster clock access, but CLB access is limited to one-fourth of the device. They also facilitate a faster I/O interface.

Figure 35 is a conceptual diagram of the global net structure in the XC4000X.

Global Early buffers and Global Low-Skew buffers share a single pad. Therefore, the same IPAD symbol can drive one buffer of each type, in parallel. This configuration is particularly useful when using the Fast Capture latches, as described in "IOB Input Signals" on page 20. Paired Global

Early and Global Low-Skew buffers share a common input; they cannot be driven by two different signals.

#### Choosing an XC4000X Clock Buffer

The clocking structure of the XC4000X provides a large variety of features. However, it can be simple to use, without understanding all the details. The software automatically handles clocks, along with all other routing, when the appropriate clock buffer is placed in the design. In fact, if a buffer symbol called BUFG is placed, rather than a specific type of buffer, the software even chooses the buffer most appropriate for the design. The detailed information in this section is provided for those users who want a finer level of control over their designs.

If fine control is desired, use the following summary and Table 15 on page 35 to choose an appropriate clock buffer.

- The simplest thing to do is to use a Global Low-Skew buffer.
- If a faster clock path is needed, try a BUFG. The software will first try to use a Global Low-Skew Buffer. If timing requirements are not met, a faster buffer will automatically be used.
- If a single quadrant of the chip is sufficient for the clocked logic, and the timing requires a faster clock than the Global Low-Skew buffer, use a Global Early buffer.

#### **Global Low-Skew Buffers**

Each corner of the XC4000X device has two Global Low-Skew buffers. Any of the eight Global Low-Skew buffers can drive any of the eight vertical Global lines in a column of CLBs. In addition, any of the buffers can drive any of the four vertical lines accessing the IOBs on the left edge of the device, and any of the eight vertical lines accessing the IOBs on the right edge of the device. (See Figure 36 on page 38.)

IOBs at the top and bottom edges of the device are accessed through the vertical Global lines in the CLB array, as in the XC4000E. Any Global Low-Skew buffer can, therefore, access every IOB and CLB in the device.

The Global Low-Skew buffers can be driven by either semi-dedicated pads or internal logic.

To use a Global Low-Skew buffer, instantiate a BUFGLS element in a schematic or in HDL code. If desired, attach a LOC attribute or property to direct placement to the designated location. For example, attach a LOC=T attribute or property to direct that a BUFGLS be placed in one of the two Global Low-Skew buffers on the top edge of the device, or a LOC=TR to indicate the Global Low-Skew buffer on the top edge of the device, on the right.

The top and bottom Global Early buffers are about 1 ns slower clock to out than the left and right Global Early buffers.

The Global Early buffers can be driven by either semi-dedicated pads or internal logic. They share pads with the Global Low-Skew buffers, so a single net can drive both global buffers, as described above.

To use a Global Early buffer, place a BUFGE element in a schematic or in HDL code. If desired, attach a LOC attribute or property to direct placement to the designated location. For example, attach a LOC=T attribute or property to direct that a BUFGE be placed in one of the two Global Early buffers on the top edge of the device, or a LOC=TR to indicate the Global Early buffer on the top edge of the device, on the right.

# **Power Distribution**

Power for the FPGA is distributed through a grid to achieve high noise immunity and isolation between logic and I/O. Inside the FPGA, a dedicated Vcc and Ground ring surrounding the logic array provides power to the I/O drivers, as shown in Figure 39. An independent matrix of Vcc and Ground lines supplies the interior logic of the device.

This power distribution grid provides a stable supply and ground for all internal logic, providing the external package power pins are all connected and appropriately de-coupled. Typically, a 0.1  $\mu$ F capacitor connected between each Vcc pin and the board's Ground plane will provide adequate de-coupling.

Output buffers capable of driving/sinking the specified 12 mA loads under specified worst-case conditions may be capable of driving/sinking up to 10 times as much current under best case conditions.

Noise can be reduced by minimizing external load capacitance and reducing simultaneous output transitions in the same direction. It may also be beneficial to locate heavily loaded output buffers near the Ground pads. The I/O Block output buffers have a slew-rate limited mode (default) which should be used where output rise and fall times are not speed-critical.



Figure 39: XC4000 Series Power Distribution

# **Pin Descriptions**

There are three types of pins in the XC4000 Series devices:

- Permanently dedicated pins
- User I/O pins that can have special functions
- Unrestricted user-programmable I/O pins.

Before and during configuration, all outputs not used for the configuration process are 3-stated with a 50 k $\Omega$  - 100 k $\Omega$  pull-up resistor.

After configuration, if an IOB is unused it is configured as an input with a 50 k $\Omega$  - 100 k $\Omega$  pull-up resistor.

XC4000 Series devices have no dedicated Reset input. Any user I/O can be configured to drive the Global Set/Reset net, GSR. See "Global Set/Reset" on page 11 for more information on GSR.

XC4000 Series devices have no Powerdown control input, as the XC3000 and XC2000 families do. The XC3000/XC2000 Powerdown control also 3-stated all of the device

I/O pins. For XC4000 Series devices, use the global 3-state net, GTS, instead. This net 3-states all outputs, but does not place the device in low-power mode. See "IOB Output Signals" on page 23 for more information on GTS.

Device pins for XC4000 Series devices are described in Table 16. Pin functions during configuration for each of the seven configuration modes are summarized in Table 22 on page 58, in the "Configuration Timing" section.

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

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.





Figure 48: Start-up Logic

# Readback

The user can read back the content of configuration memory and the level of certain internal nodes without interfering with the normal operation of the device.

Readback not only reports the downloaded configuration bits, but can also include the present state of the device, represented by the content of all flip-flops and latches in CLBs and IOBs, as well as the content of function generators used as RAMs.

Note that in XC4000 Series devices, configuration data is *not* inverted with respect to configuration as it is in XC2000 and XC3000 families.

XC4000 Series Readback does not use any dedicated pins, but uses four internal nets (RDBK.TRIG, RDBK.DATA, RDBK.RIP and RDBK.CLK) that can be routed to any IOB. To access the internal Readback signals, place the READ- BACK library symbol and attach the appropriate pad symbols, as shown in Figure 49.

After Readback has been initiated by a High level on RDBK.TRIG after configuration, the RDBK.RIP (Read In Progress) output goes High on the next rising edge of RDBK.CLK. Subsequent rising edges of this clock shift out Readback data on the RDBK.DATA net.

Readback data does not include the preamble, but starts with five dummy bits (all High) followed by the Start bit (Low) of the first frame. The first two data bits of the first frame are always High.

Each frame ends with four error check bits. They are read back as High. The last seven bits of the last frame are also read back as High. An additional Start bit (Low) and an 11-bit Cyclic Redundancy Check (CRC) signature follow, before RDBK.RIP returns Low.



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:m0></m2:m1:m0> |                             |                                 |                                  |                                    |                                  |                   |  |  |  |  |  |
|------------------------------------------|-----------------------------|---------------------------------|----------------------------------|------------------------------------|----------------------------------|-------------------|--|--|--|--|--|
| 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                            |                                  | 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/B031 (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    |  |  |  |  |  |
|                                          |                             |                                 |                                  | A16                                | 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        |  |  |  |  |  |

### Synchronous Peripheral Mode

Synchronous Peripheral mode can also be considered Slave Parallel mode. An external signal drives the CCLK input(s) of the FPGA(s). The first byte of parallel configuration data must be available at the Data inputs of the lead FPGA a short setup time before the rising CCLK edge. Subsequent data bytes are clocked in on every eighth consecutive rising CCLK edge.

The same CCLK edge that accepts data, also causes the RDY/BUSY output to go High for one CCLK period. The pin name is a misnomer. In Synchronous Peripheral mode it is really an ACKNOWLEDGE signal. Synchronous operation does not require this response, but it is a meaningful signal for test purposes. Note that RDY/BUSY is pulled High with a high-impedance pullup prior to INIT going High.

The lead FPGA serializes the data and presents the preamble data (and all data that overflows the lead device) on its DOUT pin. There is an internal delay of 1.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.

In order to complete the serial shift operation, 10 additional CCLK rising edges are required after the last data byte has been loaded, plus one more CCLK cycle for each daisy-chained device.

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



Figure 56: Synchronous Peripheral Mode Circuit Diagram

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



# **Configuration Switching Characteristics**



# Master Modes (XC4000E/EX)

| Description                |                     | Symbol            | Min  | Max                  | Units |
|----------------------------|---------------------|-------------------|------|----------------------|-------|
|                            | M0 = High           | T <sub>POR</sub>  | 10   | 40                   | ms    |
| Power-On Reset             | M0 = Low            | T <sub>POR</sub>  | 40   | 130                  | ms    |
| Program Latency            | T <sub>PI</sub>     | 30                | 200  | μs per<br>CLB column |       |
| CCLK (output) Delay        | CCLK (output) Delay |                   |      | 250                  | μs    |
| CCLK (output) Period, slow | T <sub>CCLK</sub>   | 640               | 2000 | ns                   |       |
| CCLK (output) Period, fast |                     | T <sub>CCLK</sub> | 80   | 250                  | ns    |

### Master Modes (XC4000XL)

| Description                |                   | Symbol            | Min  | Max                  | Units |
|----------------------------|-------------------|-------------------|------|----------------------|-------|
|                            | M0 = High         | T <sub>POR</sub>  | 10   | 40                   | ms    |
| Power-On Reset             | M0 = Low          | T <sub>POR</sub>  | 40   | 130                  | ms    |
| Program Latency            | T <sub>PI</sub>   | 30                | 200  | μs per<br>CLB column |       |
| CCLK (output) Delay        | Т <sub>ІССК</sub> | 40                | 250  | μs                   |       |
| CCLK (output) Period, slow | T <sub>CCLK</sub> | 540               | 1600 | ns                   |       |
| CCLK (output) Period, fast |                   | T <sub>CCLK</sub> | 67   | 200                  | ns    |

# Slave and Peripheral Modes (All)

| Description                    | Symbol            | Min | Max | Units                |
|--------------------------------|-------------------|-----|-----|----------------------|
| Power-On Reset                 | T <sub>POR</sub>  | 10  | 33  | ms                   |
| Program Latency                | T <sub>PI</sub>   | 30  | 200 | μs per<br>CLB column |
| CCLK (input) Delay (required)  | T <sub>ICCK</sub> | 4   |     | μs                   |
| CCLK (input) Period (required) | T <sub>CCLK</sub> | 100 |     | ns                   |



| 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 |
| C       | DDE  | PC84           | PQ100          | VQ100          | PG120         | ТQ144          | PG156         | PQ160          | PG191         | HQ208             | PQ208          | PG223         | BG225         | HQ240             | PQ240          | PG299         | HQ304            |
|         | -4   | CI             | CI             | CI             | CI            |                |               |                |               |                   |                |               |               |                   |                |               |                  |
| VC4002F | -3   | CI             | CI             | CI             | CI            |                |               |                |               |                   |                |               |               |                   |                |               |                  |
| XC4003E | -2   | CI             | СІ             | CI             | CI            |                |               |                |               |                   |                |               |               |                   |                |               |                  |
|         | -1   | C              | C              | C              | C             |                |               |                |               |                   |                |               |               |                   |                |               |                  |
|         | -4   | CI             | CI             |                |               | CI             | CI            | CI             |               |                   | CI             |               |               |                   |                |               |                  |
| XC4005E | -3   | CI             | CI             |                |               | CI             | CI            | CI             |               |                   | CI             |               |               |                   |                |               |                  |
| AC4005E | -2   | CI             | CI             |                |               | CI             | CI            | CI             |               |                   | СІ             |               |               |                   |                |               |                  |
|         | -1   | С              | С              |                |               | С              | С             | С              |               |                   | С              |               |               |                   |                |               |                  |
|         | -4   | CI             |                |                |               | CI             | CI            | CI             |               |                   | CI             |               |               |                   |                |               |                  |
| XC4006E | -3   | CI             |                |                |               | CI             | CI            | CI             |               |                   | CI             |               |               |                   |                |               |                  |
| XC4006E | -2   | CI             |                |                |               | CI             | CI            | CI             |               |                   | CI             |               |               |                   |                |               |                  |
|         | -1   | С              |                |                |               | С              | С             | С              |               |                   | С              |               |               |                   |                |               |                  |
|         | -4   | CI             |                |                |               |                |               | CI             | CI            |                   | CI             |               |               |                   |                |               |                  |
| XC4008E | -3   | CI             |                |                |               |                |               | CI             | CI            |                   | CI             |               |               |                   |                |               |                  |
| X04000L | -2   | CI             |                |                |               |                |               | CI             | CI            |                   | CI             |               |               |                   |                |               |                  |
|         | -1   | С              |                |                |               |                |               | С              | С             |                   | С              |               |               |                   |                |               |                  |
|         | -4   | CI             |                |                |               |                |               | CI             | CI            | CI                | CI             |               | CI            |                   |                |               |                  |
| XC4010E | -3   | CI             |                |                |               |                |               | CI             | CI            | CI                | CI             |               | CI            |                   |                |               |                  |
| XOHOTOL | -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             |               |                  |
|         | -2   |                |                |                |               |                |               | CI             |               | CI                | CI             | CI            | CI            | CI                | CI             |               |                  |
|         | -1   |                |                |                |               |                |               | С              |               | С                 | С              | С             | С             | С                 | С              |               |                  |
|         | -4   |                |                |                |               |                |               |                |               | CI                |                | CI            |               | CI                |                |               |                  |
| XC4020E | -3   |                |                |                |               |                |               |                |               | CI                |                | CI            |               | CI                |                |               |                  |
|         | -2   |                |                |                |               |                |               |                |               | CI                |                | CI            |               | CI                |                |               |                  |
|         | -1   |                |                |                |               |                |               |                |               | С                 |                | С             |               | С                 |                |               |                  |
| VCADOFE | -4   |                |                |                |               |                |               |                |               |                   |                | CI            |               | CI                |                | CI            | CI               |
| XC4025E | -3   |                |                |                |               |                |               |                |               |                   |                | CI<br>C       |               | CI                |                | CI<br>C       | CI               |
| 1/29/99 | -2   |                |                |                |               |                |               |                |               |                   |                | ر<br>د        |               | С                 |                | L L           | С                |

#### Table 25: Component Availability Chart for XC4000E FPGAs

1/29/99

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 208 240 299 304 352 411 432 High-Perf. QFP High-Perf. QFP Ceram. PGA High-Perf. QFP Plast. Ceram. PGA Plast. BGA TYPE BGA HQ240 PG299 HQ304 BG352 PG411 BG432 HQ208 CODE -4 СΙ СІ СΙ СІ СІ XC4028EX -3 СІ СΙ СΙ СІ СІ -2 С С С С С -4 СI CI СІ CI CI XC4036EX -3 СΙ СІ СΙ СІ СΙ -2 С С С С С

1/29/99

C = Commercial  $T_J = 0^{\circ}$  to +85°C

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