



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            | 1936                                                         |
| Number of Logic Elements/Cells | 4598                                                         |
| Total RAM Bits                 | 61952                                                        |
| Number of I/O                  | 352                                                          |
| Number of Gates                | 52000                                                        |
| Voltage - Supply               | 3V ~ 3.6V                                                    |
| Mounting Type                  | Surface Mount                                                |
| Operating Temperature          | -40°C ~ 100°C (TJ)                                           |
| Package / Case                 | 432-LBGA Exposed Pad, Metal                                  |
| Supplier Device Package        | 432-MBGA (40x40)                                             |
| Purchase URL                   | https://www.e-xfl.com/product-detail/xilinx/xc4052xl-3bg432i |

Email: info@E-XFL.COM

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



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

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)





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



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

6-14 May 14, 1999 (Version 1.6)





Figure 9: 16x2 (or 16x1) Level-Sensitive Single-Port RAM



Figure 10: 32x1 Level-Sensitive Single-Port RAM (F and G addresses are identical)



Figure 14: Detail of XC4000E Dedicated Carry Logic

# Input/Output Blocks (IOBs)

User-configurable input/output blocks (IOBs) provide the interface between external package pins and the internal logic. Each IOB controls one package pin and can be configured for input, output, or bidirectional signals.

Figure 15 shows a simplified block diagram of the XC4000E IOB. A more complete diagram which includes the boundary scan logic of the XC4000E IOB can be found in Figure 40 on page 43, in the "Boundary Scan" section.

The XC4000X IOB contains some special features not included in the XC4000E IOB. These features are highlighted in a simplified block diagram found in Figure 16, and discussed throughout this section. When XC4000X special features are discussed, they are clearly identified in the text. Any feature not so identified is present in both XC4000E and XC4000X devices.

#### IOB Input Signals

Two paths, labeled I1 and I2 in Figure 15 and Figure 16, bring input signals into the array. Inputs also connect to an input register that can be programmed as either an edge-triggered flip-flop or a level-sensitive latch.

The choice is made by placing the appropriate library symbol. For example, IFD is the basic input flip-flop (rising edge triggered), and ILD is the basic input latch (transparent-High). Variations with inverted clocks are available, and some combinations of latches and flip-flops can be implemented in a single IOB, as described in the *XACT Libraries Guide*.

The XC4000E inputs can be globally configured for either TTL (1.2V) or 5.0 volt CMOS thresholds, using an option in the bitstream generation software. There is a slight input hysteresis of about 300mV. The XC4000E output levels are also configurable; the two global adjustments of input threshold and output level are independent.

Inputs on the XC4000XL are TTL compatible and 3.3V CMOS compatible. Outputs on the XC4000XL are pulled to the 3.3V positive supply.

The inputs of XC4000 Series 5-Volt devices can be driven by the outputs of any 3.3-Volt device, if the 5-Volt inputs are in TTL mode.

Supported sources for XC4000 Series device inputs are shown in Table 8.

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



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

#### **JTAG Support**

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

#### **Three-State Buffers**

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

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

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

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

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

## Three-State Buffer Modes

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

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

#### **Standard 3-State Buffer**

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

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

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

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

#### Wired OR-AND

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

## Three-State Buffer Examples

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

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

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

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

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



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





Figure 25: High-Level Routing Diagram of XC4000 Series CLB (shaded arrows indicate XC4000X only)

Table 14: Routing per CLB in XC4000 Series Devices

|             | XC4      | 1000E      | XC       | 4000X      |  |
|-------------|----------|------------|----------|------------|--|
|             | Vertical | Horizontal | Vertical | Horizontal |  |
| Singles     | 8        | 8          | 8        | 8          |  |
| Doubles     | 4        | 4          | 4        | 4          |  |
| Quads       | 0        | 0          | 12       | 12         |  |
| Longlines   | 6        | 6          | 10       | 6          |  |
| Direct      | 0        | 0          | 2        | 2          |  |
| Connects    |          |            |          |            |  |
| Globals     | 4        | 0          | 8        | 0          |  |
| Carry Logic | 2        | 0          | 1        | 0          |  |
| Total       | 24       | 18         | 45       | 32         |  |

# Programmable Switch Matrices

The horizontal and vertical single- and double-length lines intersect at a box called a programmable switch matrix (PSM). Each switch matrix consists of programmable pass transistors used to establish connections between the lines (see Figure 26).

For example, a single-length signal entering on the right side of the switch matrix can be routed to a single-length line on the top, left, or bottom sides, or any combination thereof, if multiple branches are required. Similarly, a double-length signal can be routed to a double-length line on any or all of the other three edges of the programmable switch matrix.



Figure 26: Programmable Switch Matrix (PSM)

### Single-Length Lines

Single-length lines provide the greatest interconnect flexibility and offer fast routing between adjacent blocks. There are eight vertical and eight horizontal single-length lines associated with each CLB. These lines connect the switching matrices that are located in every row and a column of CLBs.

Single-length lines are connected by way of the programmable switch matrices, as shown in Figure 28. Routing connectivity is shown in Figure 27.

Single-length lines incur a delay whenever they go through a switching matrix. Therefore, they are not suitable for routing signals for long distances. They are normally used to conduct signals within a localized area and to provide the branching for nets with fanout greater than one.





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



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

IOB inputs and outputs interface with the octal lines via the single-length interconnect lines. Single-length lines are also used for communication between the octals and double-length lines, quads, and longlines within the CLB array.

Segmentation into buffered octals was found to be optimal for distributing signals over long distances around the device.

### **Global Nets and Buffers**

Both the XC4000E and the XC4000X have dedicated global networks. These networks are designed to distribute clocks and other high fanout control signals throughout the devices with minimal skew. The global buffers are described in detail in the following sections. The text descriptions and diagrams are summarized in Table 15. The table shows which CLB and IOB clock pins can be sourced by which global buffers.

In both XC4000E and XC4000X devices, placement of a library symbol called BUFG results in the software choosing the appropriate clock buffer, based on the timing requirements of the design. The detailed information in these sections is included only for reference.

### Global Nets and Buffers (XC4000E only)

Four vertical longlines in each CLB column are driven exclusively by special global buffers. These longlines are in addition to the vertical longlines used for standard interconnect. The four global lines can be driven by either of two types of global buffers. The clock pins of every CLB and IOB can also be sourced from local interconnect.

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

- Primary Global Buffers (BUFGP)
- Secondary Global Buffers (BUFGS)

Four Primary Global buffers offer the shortest delay and negligible skew. Four Secondary Global buffers have slightly longer delay and slightly more skew due to potentially heavier loading, but offer greater flexibility when used to drive non-clock CLB inputs.

The Primary Global buffers must be driven by the semi-dedicated pads. The Secondary Global buffers can be sourced by either semi-dedicated pads or internal nets.

Each CLB column has four dedicated vertical Global lines. Each of these lines can be accessed by one particular Primary Global buffer, or by any of the Secondary Global buffers, as shown in Figure 34. Each corner of the device has one Primary buffer and one Secondary buffer.

IOBs along the left and right edges have four vertical global longlines. Top and bottom IOBs can be clocked from the global lines in the adjacent CLB column.

A global buffer should be specified for all timing-sensitive global signal distribution. To use a global buffer, place a BUFGP (primary buffer), BUFGS (secondary buffer), or BUFG (either primary or secondary buffer) 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=L attribute or property to a BUFGS symbol to direct that a buffer be placed in one of the two Secondary Global buffers on the left edge of the device, or a LOC=BL to indicate the Secondary Global buffer on the bottom edge of the device, on the left.

**Table 15: Clock Pin Access** 

|                                                                | XC4         | 000E |        | XC4000X        |                | Local             |  |
|----------------------------------------------------------------|-------------|------|--------|----------------|----------------|-------------------|--|
|                                                                | BUFGP BUFGS |      | BUFGLS | L & R<br>BUFGE | T & B<br>BUFGE | Inter-<br>connect |  |
| All CLBs in Quadrant                                           | √           | √    | V      | V              | V              | V                 |  |
| All CLBs in Device                                             | V           | √    | V      |                |                | V                 |  |
| IOBs on Adjacent Vertical<br>Half Edge                         | √           | V    | 1      | V              | √              | V                 |  |
| IOBs on Adjacent Vertical<br>Full Edge                         | V           | V    | V      | V              |                | V                 |  |
| IOBs on Adjacent Horizontal<br>Half Edge (Direct)              |             |      |        | V              |                | V                 |  |
| IOBs on Adjacent Horizontal<br>Half Edge (through CLB globals) | V           | V    | V      | V              | V              | V                 |  |
| IOBs on Adjacent Horizontal<br>Full Edge (through CLB globals) | V           | V    | V      |                |                | V                 |  |

L = Left, R = Right, T = Top, B = Bottom



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



Figure 41 on page 44 is a diagram of the XC4000 Series boundary scan logic. It includes three bits of Data Register per IOB, the IEEE 1149.1 Test Access Port controller, and the Instruction Register with decodes.

XC4000 Series devices can also be configured through the boundary scan logic. See "Readback" on page 55.

## **Data Registers**

The primary data register is the boundary scan register. For each IOB pin in the FPGA, bonded or not, it includes three bits for In, Out and 3-State Control. Non-IOB pins have appropriate partial bit population for In or Out only. PROGRAM, CCLK and DONE are not included in the boundary scan register. Each EXTEST CAPTURE-DR state captures all In, Out, and 3-state pins.

The data register also includes the following non-pin bits: TDO.T, and TDO.O, which are always bits 0 and 1 of the

data register, respectively, and BSCANT.UPD, which is always the last bit of the data register. These three boundary scan bits are special-purpose Xilinx test signals.

The other standard data register is the single flip-flop BYPASS register. It synchronizes data being passed through the FPGA to the next downstream boundary scan device.

The FPGA provides two additional data registers that can be specified using the BSCAN macro. The FPGA provides two user pins (BSCAN.SEL1 and BSCAN.SEL2) which are the decodes of two user instructions. For these instructions, two corresponding pins (BSCAN.TDO1 and BSCAN.TDO2) allow user scan data to be shifted out on TDO. The data register clock (BSCAN.DRCK) is available for control of test logic which the user may wish to implement with CLBs. The NAND of TCK and RUN-TEST-IDLE is also provided (BSCAN.IDLE).



Figure 40: Block Diagram of XC4000E IOB with Boundary Scan (some details not shown). XC4000X Boundary Scan Logic is Identical.



**Table 17: Boundary Scan Instructions** 

|   | uction |   | Test<br>Selected   | TDO Source         | I/O Data<br>Source |
|---|--------|---|--------------------|--------------------|--------------------|
| 0 | 0      | 0 | EXTEST             | DR                 | DR                 |
| 0 | 0      | 1 | SAMPLE/PR<br>ELOAD | DR                 | Pin/Logic          |
| 0 | 1      | 0 | USER 1             | BSCAN.<br>TDO1     | User Logic         |
| 0 | 1      | 1 | USER 2             | BSCAN.<br>TDO2     | User Logic         |
| 1 | 0      | 0 | READBACK           | Readback<br>Data   | Pin/Logic          |
| 1 | 0      | 1 | CONFIGURE          | DOUT               | Disabled           |
| 1 | 1      | 0 | Reserved           |                    |                    |
| 1 | 1      | 1 | BYPASS             | Bypass<br>Register | _                  |



X6075

Figure 42: Boundary Scan Bit Sequence

# **Avoiding Inadvertent Boundary Scan**

If TMS or TCK is used as user I/O, care must be taken to ensure that at least one of these pins is held constant during configuration. In some applications, a situation may occur where TMS or TCK is driven during configuration. This may cause the device to go into boundary scan mode and disrupt the configuration process.

To prevent activation of boundary scan during configuration, do either of the following:

- TMS: Tie High to put the Test Access Port controller in a benign RESET state
- TCK: Tie High or Low—don't toggle this clock input.

For more information regarding boundary scan, refer to the Xilinx Application Note XAPP 017.001, "Boundary Scan in XC4000E Devices."



Figure 43: Boundary Scan Schematic Example

# Configuration

Configuration is the process of loading design-specific programming data into one or more FPGAs to define the functional operation of the internal blocks and their interconnections. This is somewhat like loading the command registers of a programmable peripheral chip. XC4000 Series devices use several hundred bits of configuration data per CLB and its associated interconnects. Each configuration bit defines the state of a static memory cell that controls either a function look-up table bit, a multiplexer input, or an interconnect pass transistor. The XACT step development system translates the design into a netlist file. It automatically partitions, places and routes the logic and generates the configuration data in PROM format.

# **Special Purpose Pins**

Three configuration mode pins (M2, M1, M0) are sampled prior to configuration to determine the configuration mode. After configuration, these pins can be used as auxiliary connections. M2 and M0 can be used as inputs, and M1 can be used as an output. The XACT step development system does not use these resources unless they are explicitly specified in the design entry. This is done by placing a special pad symbol called MD2, MD1, or MD0 instead of the input or output pad symbol.

In XC4000 Series devices, the mode pins have weak pull-up resistors during configuration. With all three mode pins High, Slave Serial mode is selected, which is the most popular configuration mode. Therefore, for the most common configuration mode, the mode pins can be left unconnected. (Note, however, that the internal pull-up resistor value can be as high as 100 k $\Omega$ .) After configuration, these pins can individually have weak pull-up or pull-down resistors, as specified in the design. A pull-down resistor value of 4.7 k $\Omega$  is recommended.

These pins are located in the lower left chip corner and are near the readback nets. This location allows convenient routing if compatibility with the XC2000 and XC3000 family conventions of M0/RT, M1/RD is desired.



Table 20: XC4000E Program Data

| Device              | XC4003E   | XC4005E   | XC4006E   | XC4008E   | XC4010E   | XC4013E   | XC4020E   | XC4025E   |
|---------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| Max Logic Gates     | 3,000     | 5,000     | 6,000     | 8,000     | 10,000    | 13,000    | 20,000    | 25,000    |
| CLBs                | 100       | 196       | 256       | 324       | 400       | 576       | 784       | 1,024     |
| (Row x Col.)        | (10 x 10) | (14 x 14) | (16 x 16) | (18 x 18) | (20 x 20) | (24 x 24) | (28 x 28) | (32 x 32) |
| IOBs                | 80        | 112       | 128       | 144       | 160       | 192       | 224       | 256       |
| Flip-Flops          | 360       | 616       | 768       | 936       | 1,120     | 1,536     | 2,016     | 2,560     |
| Bits per Frame      | 126       | 166       | 186       | 206       | 226       | 266       | 306       | 346       |
| Frames              | 428       | 572       | 644       | 716       | 788       | 932       | 1,076     | 1,220     |
| Program Data        | 53,936    | 94,960    | 119,792   | 147,504   | 178,096   | 247,920   | 329,264   | 422,128   |
| PROM Size<br>(bits) | 53,984    | 95,008    | 119,840   | 147,552   | 178,144   | 247,968   | 329,312   | 422,176   |

Notes: 1. Bits per Frame = (10 x number of rows) + 7 for the top + 13 for the bottom + 1 + 1 start bit + 4 error check bits

Number of Frames = (36 x number of columns) + 26 for the left edge + 41 for the right edge + 1

Program Data = (Bits per Frame x Number of Frames) + 8 postamble bits

PROM Size = Program Data + 40 (header) + 8

2. The user can add more "one" bits as leading dummy bits in the header, or, if CRC = off, as trailing dummy bits at the end of any frame, following the four error check bits. However, the Length Count value must be adjusted for all such extra "one" bits, even for extra leading ones at the beginning of the header.

Table 21: XC4000EX/XL Program Data

| Device                    | XC4002XL      | XC4005           | XC4010           | XC4013           | XC4020           | XC4028             | XC4036             | XC4044             | XC4052             | XC4062             | XC4085             |
|---------------------------|---------------|------------------|------------------|------------------|------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|
| Max Logic<br>Gates        | 2,000         | 5,000            | 10,000           | 13,000           | 20,000           | 28,000             | 36,000             | 44,000             | 52,000             | 62,000             | 85,000             |
| CLBs<br>(Row x<br>Column) | 64<br>(8 x 8) | 196<br>(14 x 14) | 400<br>(20 x 20) | 576<br>(24 x 24) | 784<br>(28 x 28) | 1,024<br>(32 x 32) | 1,296<br>(36 x 36) | 1,600<br>(40 x 40) | 1,936<br>(44 x 44) | 2,304<br>(48 x 48) | 3,136<br>(56 x 56) |
| IOBs                      | 64            | 112              | 160              | 192              | 224              | 256                | 288                | 320                | 352                | 384                | 448                |
| Flip-Flops                | 256           | 616              | 1,120            | 1,536            | 2,016            | 2,560              | 3,168              | 3,840              | 4,576              | 5,376              | 7,168              |
| Bits per<br>Frame         | 133           | 205              | 277              | 325              | 373              | 421                | 469                | 517                | 565                | 613                | 709                |
| Frames                    | 459           | 741              | 1,023            | 1,211            | 1,399            | 1,587              | 1,775              | 1,963              | 2,151              | 2,339              | 2,715              |
| Program Data              | 61,052        | 151,910          | 283,376          | 393,580          | 521,832          | 668,124            | 832,480            | 1,014,876          | 1,215,320          | 1,433,804          | 1,924,940          |
| PROM Size<br>(bits)       | 61,104        | 151,960          | 283,424          | 393,632          | 521,880          | 668,172            | 832,528            | 1,014,924          | 1,215,368          | 1,433,852          | 1,924,992          |

Notes: 1. Bits per frame = (13 x number of rows) + 9 for the top + 17 for the bottom + 8 + 1 start bit + 4 error check bits. Frames = (47 x number of columns) + 27 for the left edge + 52 for the right edge + 4.

Program data = (bits per frame x number of frames) + 5 postamble bits.

PROM size = (program data + 40 header bits + 8 start bits) rounded up to the nearest byte.

2. The user can add more "one" bits as leading dummy bits in the header, or, if CRC = off, as trailing dummy bits at the end of any frame, following the four error check bits. However, the Length Count value must be adjusted for all such extra "one" bits, even for extra leading "ones" at the beginning of the header.

# Cyclic Redundancy Check (CRC) for Configuration and Readback

The Cyclic Redundancy Check is a method of error detection in data transmission applications. Generally, the transmitting system performs a calculation on the serial bitstream. The result of this calculation is tagged onto the data stream as additional check bits. The receiving system performs an identical calculation on the bitstream and compares the result with the received checksum.

Each data frame of the configuration bitstream has four error bits at the end, as shown in Table 19. If a frame data error is detected during the loading of the FPGA, the con-

figuration process with a potentially corrupted bitstream is terminated. The FPGA pulls the  $\overline{\text{INIT}}$  pin Low and goes into a Wait state.

During Readback, 11 bits of the 16-bit checksum are added to the end of the Readback data stream. The checksum is computed using the CRC-16 CCITT polynomial, as shown in Figure 45. The checksum consists of the 11 most significant bits of the 16-bit code. A change in the checksum indicates a change in the Readback bitstream. A comparison to a previous checksum is meaningful only if the readback data is independent of the current device state. CLB outputs should not be included (Read Capture option not





Figure 47: Start-up Timing



# 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  $\overline{\text{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

6-64





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



## **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 handshake 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{CSO}$ , 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{\text{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{\text{BUSY}}$  status when  $\overline{\text{RS}}$  is Low,  $\overline{\text{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

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



Table 25: Component Availability Chart for XC4000E FPGAs

| Р         | 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 |
| CC        | 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             |               |                   | CI             |               |               |                   |                |               |                  |
| XC4005E   | -3   | СІ             | СІ             |                |               | СІ             | СІ            | СІ             |               |                   | СІ             |               |               |                   |                |               |                  |
| AC4005E   | -2   | CI             | СІ             |                |               | CI             | СІ            | СІ             |               |                   | СІ             |               |               |                   |                |               |                  |
|           | -1   | С              | С              |                |               | С              | С             | С              |               |                   | С              |               |               |                   |                |               |                  |
|           | -4   | CI             |                |                |               | 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             |               |                  |
| NO-OTOL [ | -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     |    | 208               | 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 |
| CODE     |    | 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