



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            | 400                                                          |
| Number of Logic Elements/Cells | 950                                                          |
| Total RAM Bits                 | 12800                                                        |
| Number of I/O                  | 77                                                           |
| Number of Gates                | 10000                                                        |
| Voltage - Supply               | 3V ~ 3.6V                                                    |
| Mounting Type                  | Surface Mount                                                |
| Operating Temperature          | -40°C ~ 100°C (TJ)                                           |
| Package / Case                 | 100-BQFP                                                     |
| Supplier Device Package        | 100-PQFP (20x14)                                             |
| Purchase URL                   | https://www.e-xfl.com/product-detail/xilinx/xc4010xl-3pq100i |

Email: info@E-XFL.COM

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



Table 1: XC4000E and XC4000X Series Field Programmable Gate Arrays

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

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

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

## Description

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

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

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

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

#### Taking Advantage of Re-configuration

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

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

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

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



### Input Thresholds

The input thresholds of 5V devices can be globally configured for either TTL (1.2 V threshold) or CMOS (2.5 V threshold), just like XC2000 and XC3000 inputs. The two global adjustments of input threshold and output level are independent of each other. The XC4000XL family has an input threshold of 1.6V, compatible with both 3.3V CMOS and TTL levels.

#### Global Signal Access to Logic

There is additional access from global clocks to the F and G function generator inputs.

## Configuration Pin Pull-Up Resistors

During configuration, these pins have weak pull-up resistors. For the most popular configuration mode, Slave Serial, the mode pins can thus be left unconnected. The three mode inputs can be individually configured with or without weak pull-up or pull-down resistors. A pull-down resistor value of  $4.7~\mathrm{k}\Omega$  is recommended.

The three mode inputs can be individually configured with or without weak pull-up or pull-down resistors after configuration.

The PROGRAM input pin has a permanent weak pull-up.

#### Soft Start-up

Like the XC3000A, XC4000 Series devices have "Soft Start-up." When the configuration process is finished and the device starts up, the first activation of the outputs is automatically slew-rate limited. This feature avoids potential ground bounce when all outputs are turned on simultaneously. Immediately after start-up, the slew rate of the individual outputs is, as in the XC4000 family, determined by the individual configuration option.

## XC4000 and XC4000A Compatibility

Existing XC4000 bitstreams can be used to configure an XC4000E device. XC4000A bitstreams must be recompiled for use with the XC4000E due to improved routing resources, although the devices are pin-for-pin compatible.

## Additional Improvements in XC4000X Only

## Increased Routing

New interconnect in the XC4000X includes twenty-two additional vertical lines in each column of CLBs and twelve new horizontal lines in each row of CLBs. The twelve "Quad Lines" in each CLB row and column include optional repowering buffers for maximum speed. Additional high-performance routing near the IOBs enhances pin flexibility.

#### Faster Input and Output

A fast, dedicated early clock sourced by global clock buffers is available for the IOBs. To ensure synchronization with the regular global clocks, a Fast Capture latch driven by the early clock is available. The input data can be initially loaded into the Fast Capture latch with the early clock, then transferred to the input flip-flop or latch with the low-skew global clock. A programmable delay on the input can be used to avoid hold-time requirements. See "IOB Input Signals" on page 20 for more information.

## Latch Capability in CLBs

Storage elements in the XC4000X CLB can be configured as either flip-flops or latches. This capability makes the FPGA highly synthesis-compatible.

#### IOB Output MUX From Output Clock

A multiplexer in the IOB allows the output clock to select either the output data or the IOB clock enable as the output to the pad. Thus, two different data signals can share a single output pad, effectively doubling the number of device outputs without requiring a larger, more expensive package. This multiplexer can also be configured as an AND-gate to implement a very fast pin-to-pin path. See "IOB Output Signals" on page 23 for more information.

## Additional Address Bits

Larger devices require more bits of configuration data. A daisy chain of several large XC4000X devices may require a PROM that cannot be addressed by the eighteen address bits supported in the XC4000E. The XC4000X Series therefore extends the addressing in Master Parallel configuration mode to 22 bits.



#### **Dual-Port Edge-Triggered Mode**

In dual-port mode, both the F and G function generators are used to create a single 16x1 RAM array with one write port and two read ports. The resulting RAM array can be read and written simultaneously at two independent addresses. Simultaneous read and write operations at the same address are also supported.

Dual-port mode always has edge-triggered write timing, as shown in Figure 3.

Figure 6 shows a simple model of an XC4000 Series CLB configured as dual-port RAM. One address port, labeled A[3:0], supplies both the read and write address for the F function generator. This function generator behaves the same as a 16x1 single-port edge-triggered RAM array. The RAM output, Single Port Out (SPO), appears at the F function generator output. SPO, therefore, reflects the data at address A[3:0].

The other address port, labeled DPRA[3:0] for Dual Port Read Address, supplies the read address for the G function generator. The write address for the G function generator, however, comes from the address A[3:0]. The output from this 16x1 RAM array, Dual Port Out (DPO), appears at the G function generator output. DPO, therefore, reflects the data at address DPRA[3:0].

Therefore, by using A[3:0] for the write address and DPRA[3:0] for the read address, and reading only the DPO output, a FIFO that can read and write simultaneously is easily generated. Simultaneous access doubles the effective throughput of the FIFO.

The relationships between CLB pins and RAM inputs and outputs for dual-port, edge-triggered mode are shown in Table 6. See Figure 7 on page 16 for a block diagram of a CLB configured in this mode.



Figure 6: XC4000 Series Dual-Port RAM, Simple Model

Table 6: Dual-Port Edge-Triggered RAM Signals

| RAM Signal | CLB Pin | Function                  |
|------------|---------|---------------------------|
| D          | D0      | Data In                   |
| A[3:0]     | F1-F4   | Read Address for F,       |
|            |         | Write Address for F and G |
| DPRA[3:0]  | G1-G4   | Read Address for G        |
| WE         | WE      | Write Enable              |
| WCLK       | K       | Clock                     |
| SPO        | F'      | Single Port Out           |
|            |         | (addressed by A[3:0])     |
| DPO        | G'      | Dual Port Out             |
|            |         | (addressed by DPRA[3:0])  |

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

#### Single-Port Level-Sensitive Timing Mode

**Note:** Edge-triggered mode is recommended for all new designs. Level-sensitive mode, also called asynchronous mode, is still supported for XC4000 Series backward-compatibility with the XC4000 family.

Level-sensitive RAM timing is simple in concept but can be complicated in execution. Data and address signals are presented, then a positive pulse on the write enable pin (WE) performs a write into the RAM at the designated address. As indicated by the "level-sensitive" label, this RAM acts like a latch. During the WE High pulse, changing the data lines results in new data written to the old address. Changing the address lines while WE is High results in spurious data written to the new address—and possibly at other addresses as well, as the address lines inevitably do not all change simultaneously.

The user must generate a carefully timed WE signal. The delay on the WE signal and the address lines must be carefully verified to ensure that WE does not become active until after the address lines have settled, and that WE goes inactive before the address lines change again. The data must be stable before and after the falling edge of WE.

In practical terms, WE is usually generated by a 2X clock. If a 2X clock is not available, the falling edge of the system clock can be used. However, there are inherent risks in this approach, since the WE pulse must be guaranteed inactive before the next rising edge of the system clock. Several older application notes are available from Xilinx that discuss the design of level-sensitive RAMs.

However, the edge-triggered RAM available in the XC4000 Series is superior to level-sensitive RAM for almost every application.





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



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

Table 8: Supported Sources for XC4000 Series Device Inputs

|                                                                         |             | 00E/EX<br>Inputs | XC4000XL<br>Series Inputs |
|-------------------------------------------------------------------------|-------------|------------------|---------------------------|
| Source                                                                  | 5 V,<br>TTL | 5 V,<br>CMOS     | 3.3 V<br>CMOS             |
| Any device, Vcc = 3.3 V,<br>CMOS outputs                                | V           | Unreli           | √                         |
| XC4000 Series, Vcc = 5 V, TTL outputs                                   | V           | -able<br>Data    | √                         |
| Any device, $Vcc = 5 \text{ V}$ , TTL outputs $(Voh \le 3.7 \text{ V})$ | √           | Data             | √                         |
| Any device, Vcc = 5 V,<br>CMOS outputs                                  | V           | √                | √                         |

#### XC4000XL 5-Volt Tolerant I/Os

The I/Os on the XC4000XL are fully 5-volt tolerant even though the  $V_{\rm CC}$  is 3.3 volts. This allows 5 V signals to directly connect to the XC4000XL inputs without damage, as shown in Table 8. In addition, the 3.3 volt  $V_{\rm CC}$  can be applied before or after 5 volt signals are applied to the I/Os. This makes the XC4000XL immune to power supply sequencing problems.

#### **Registered Inputs**

The I1 and I2 signals that exit the block can each carry either the direct or registered input signal.

The input and output storage elements 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 Series CLB. It cannot be inverted within the IOB.

The storage element behavior is shown in Table 9.

Table 9: Input Register Functionality (active rising edge is shown)

| Mode            | Clock | Clock<br>Enable | D | Q  |
|-----------------|-------|-----------------|---|----|
| Power-Up or GSR | X     | X               | Х | SR |
| Flip-Flop       |       | 1*              | D | D  |
|                 | 0     | Х               | Х | Q  |
| Latch           | 1     | 1*              | Х | Q  |
|                 | 0     | 1*              | D | D  |
| Both            | Χ     | 0               | Х | Q  |

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)

#### **Optional Delay Guarantees Zero Hold Time**

The data input to the register can optionally be delayed by several nanoseconds. With the delay enabled, the setup time of the input flip-flop is increased so that normal clock routing does not result in a positive hold-time requirement. A positive hold time requirement can lead to unreliable, temperature- or processing-dependent operation.

The input flip-flop setup time is defined between the data measured at the device I/O pin and the clock input at the IOB (not at the clock pin). Any routing delay from the device clock pin to the clock input of the IOB must, therefore, be subtracted from this setup time to arrive at the real setup time requirement relative to the device pins. A short specified setup time might, therefore, result in a negative setup time at the device pins, i.e., a positive hold-time requirement.

When a delay is inserted on the data line, more clock delay can be tolerated without causing a positive hold-time requirement. Sufficient delay eliminates the possibility of a data hold-time requirement at the external pin. The maximum delay is therefore inserted as the default.

The XC4000E IOB has a one-tap delay element: either the delay is inserted (default), or it is not. The delay guarantees a zero hold time with respect to clocks routed through any of the XC4000E global clock buffers. (See "Global Nets and Buffers (XC4000E only)" on page 35 for a description of the global clock buffers in the XC4000E.) For a shorter input register setup time, with non-zero hold, attach a NODELAY attribute or property to the flip-flop.

The XC4000X IOB has a two-tap delay element, with choices of a full delay, a partial delay, or no delay. The attributes or properties used to select the desired delay are shown in Table 10. The choices are no added attribute, MEDDELAY, and NODELAY. The default setting, with no added attribute, ensures no hold time with respect to any of the XC4000X clock buffers, including the Global Low-Skew buffers. MEDDELAY ensures no hold time with respect to the Global Early buffers. Inputs with NODELAY may have a positive hold time with respect to all clock buffers. For a description of each of these buffers, see "Global Nets and Buffers (XC4000X only)" on page 37.

Table 10: XC4000X IOB Input Delay Element

| Value            | When to Use                            |
|------------------|----------------------------------------|
| full delay       | Zero Hold with respect to Global       |
| (default, no     | Low-Skew Buffer, Global Early Buffer   |
| attribute added) |                                        |
| MEDDELAY         | Zero Hold with respect to Global Early |
|                  | Buffer                                 |
| NODELAY          | Short Setup, positive Hold time        |



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

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

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

Table 12: Supported Destinations for XC4000 Series Outputs

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

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



Figure 18: Open-Drain Output

#### **Output Slew Rate**

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

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

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

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

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

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

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

GTS can be driven from any user-programmable pin as a global 3-state input. To use this global net, place an input pad and input buffer in the schematic or HDL code, driving the GTS pin of the STARTUP symbol. A specific pin location can be assigned to this input using a LOC attribute or property, just as with any other user-programmable pad. An inverter can optionally be inserted after the input buffer to invert the sense of the Global 3-State signal. Using GTS is similar to GSR. See Figure 2 on page 11 for details.

Alternatively, GTS can be driven from any internal node.

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



## 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   | XC4000E |        | 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       | V      | V              | √              | V                 |
| IOBs on Adjacent Vertical<br>Full Edge                         | V     | V       | V      | <b>V</b>       |                | V                 |
| IOBs on Adjacent Horizontal<br>Half Edge (Direct)              |       |         |        | <b>V</b>       |                | V                 |
| IOBs on Adjacent Horizontal<br>Half Edge (through CLB globals) | V     | V       | V      | 1              | V              | V                 |
| IOBs on Adjacent Horizontal<br>Full Edge (through CLB globals) | V     | V       | V      |                |                | V                 |

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



## **Setting CCLK Frequency**

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

Table 19: XC4000 Series Data Stream Formats

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

#### **Data Stream Format**

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

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

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

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

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



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

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



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

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

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

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

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

#### Start-up Sequence

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

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

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

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

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

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

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

#### **Start-up from CCLK**

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





Figure 47: Start-up Timing



**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. PERIPHERAL <1:0:1> | MASTER<br>PARALLEL DOWN<br><1:1:0> | MASTER<br>PARALLEL UP<br><1:0:0> | USER<br>OPERATION |  |  |  |  |  |  |
| M2(HIGH) (I)                             | M2(LOW) (I)                                  | M2(LOW) (I)                     | M2(HIGH) (I)               | M2(HIGH) (I)                       | M2(HIGH) (I)                     | (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               |  |  |  |  |  |  |
| ĪNIT                                     | ĪNIT                                         | ĪNĪT                            | ĪNIT                       | ĪNIT                               | ĪNIT                             | I/O               |  |  |  |  |  |  |
| DONE                                     | DONE                                         | DONE                            | DONE                       | DONE                               | DONE                             | DONE              |  |  |  |  |  |  |
| PROGRAM (I)                              | GRAM (I) PROGRAM (I) PROGRAM (I) PROGRAM (I) |                                 | PROGRAM (I)                | PROGRAM (I)                        | PROGRAM (I)                      | PROGRAM           |  |  |  |  |  |  |
| CCLK (I)                                 | CCLK (O)                                     | CCLK (I)                        | CCLK (O)                   | CCLK (O)                           | CCLK (O)                         | CCLK (I)          |  |  |  |  |  |  |
|                                          |                                              | RDY/BUSY (O)                    | RDY/BUSY (O)               | RCLK (O)                           | RCLK (O)                         | I/O               |  |  |  |  |  |  |
|                                          |                                              |                                 | RS (I)                     |                                    |                                  | I/O               |  |  |  |  |  |  |
|                                          |                                              |                                 | CSO (I)                    |                                    |                                  | I/O               |  |  |  |  |  |  |
|                                          |                                              | DATA 7 (I)                      | DATA 7 (I)                 | DATA 7 (I)                         | DATA 7 (I)                       | I/O               |  |  |  |  |  |  |
|                                          |                                              | DATA 6 (I)                      | DATA 6 (I)                 | DATA 6 (I)                         | DATA 6 (I)                       | I/O               |  |  |  |  |  |  |
|                                          |                                              | DATA 5 (I)                      | DATA 5 (I)                 | DATA 5 (I)                         | DATA 5 (I)                       | I/O               |  |  |  |  |  |  |
|                                          |                                              | DATA 4 (I)                      | DATA 4 (I)                 | DATA 4 (I)                         | DATA 4 (I)                       | I/O               |  |  |  |  |  |  |
|                                          |                                              | DATA 3 (I)                      | DATA 3 (I)                 | DATA 3 (I)                         | DATA 3 (I)                       | I/O               |  |  |  |  |  |  |
|                                          |                                              | DATA 2 (I)                      | DATA 2 (I)                 | DATA 2 (I)                         | DATA 2 (I)                       | I/O               |  |  |  |  |  |  |
|                                          |                                              | DATA 1 (I)                      | DATA 1 (I)                 | DATA 1 (I)                         | DATA 1 (I)                       | I/O               |  |  |  |  |  |  |
| DIN (I)                                  | DIN (I)                                      | DATA 0 (I)                      | DATA 0 (I)                 | DATA 0 (I)                         | DATA 0 (I)                       | I/O               |  |  |  |  |  |  |
| DOUT                                     | DOUT                                         | DOUT                            | DOUT                       | DOUT                               | DOUT                             | SGCK4-GCK6-I/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    |  |  |  |  |  |  |
|                                          |                                              |                                 |                            | A17                                | A17                              | I/O               |  |  |  |  |  |  |
|                                          |                                              |                                 |                            | A18*                               | A18*                             | I/O               |  |  |  |  |  |  |
|                                          |                                              |                                 |                            | A19*                               | A19*                             | I/O               |  |  |  |  |  |  |
|                                          |                                              |                                 |                            | A20*                               | A20*                             | I/O               |  |  |  |  |  |  |
|                                          |                                              |                                 |                            | A21*                               | A21*                             | I/O               |  |  |  |  |  |  |
|                                          |                                              |                                 |                            |                                    |                                  | ALL OTHERS        |  |  |  |  |  |  |



#### **Master Parallel Modes**

In the two Master Parallel modes, the lead FPGA directly addresses an industry-standard byte-wide EPROM, and accepts eight data bits just before incrementing or decrementing the address outputs.

The eight data bits are serialized in the lead FPGA, which then 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, after the rising CCLK edge that accepts a byte of data (and also changes the EPROM address) until the falling CCLK edge that makes the LSB (D0) of this byte appear at DOUT. This 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.

The PROM address pins can be incremented or decremented, depending on the mode pin settings. This option allows the FPGA to share the PROM with a wide variety of microprocessors and micro controllers. Some processors must boot from the bottom of memory (all zeros) while others must boot from the top. The FPGA is flexible and can load its configuration bitstream from either end of the memory.

Master Parallel Up mode is selected by a <100> on the mode pins (M2, M1, M0). The EPROM addresses start at 00000 and increment.

Master Parallel Down mode is selected by a <110> on the mode pins. The EPROM addresses start at 3FFFF and decrement.

#### Additional Address lines in XC4000 devices

The XC4000X devices have additional address lines (A18-A21) allowing the additional address space required to daisy-chain several large devices.

The extra address lines are programmable in XC4000EX devices. By default these address lines are not activated. In the default mode, the devices are compatible with existing XC4000 and XC4000E products. If desired, the extra address lines can be used by specifying the address lines option in bitgen as 22 (bitgen -g AddressLines:22). The lines (A18-A21) are driven when a master device detects, via the bitstream, that it should be using all 22 address lines. Because these pins will initially be pulled high by internal pull-ups, designers using Master Parallel Up mode should use external pull down resistors on pins A18-A21. If Master Parallel Down mode is used external resistors are not necessary.

All 22 address lines are always active in Master Parallel modes with XC4000XL devices. The additional address lines behave identically to the lower order address lines. If the Address Lines option in bitgen is set to 18, it will be ignored by the XC4000XL device.

The additional address lines (A18-A21) are not available in the PC84 package.



Figure 54: Master Parallel Mode Circuit Diagram



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



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





|                | Description                                      | , | Symbol            | Min | Max | Units           |
|----------------|--------------------------------------------------|---|-------------------|-----|-----|-----------------|
| \\\ / \c'.   - | Effective Write time (CSO, WS=Low; RS, CS1=High) | 1 | T <sub>CA</sub>   | 100 |     | ns              |
| Write          | DIN setup time                                   | 2 | T <sub>DC</sub>   | 60  |     | ns              |
|                | DIN hold time                                    | 3 | T <sub>CD</sub>   | 0   |     | ns              |
| RDY            | RDY/BUSY delay after end of Write or Read        | 4 | T <sub>WTRB</sub> |     | 60  | ns              |
|                | RDY/BUSY active after beginning of Read          | 7 |                   |     | 60  | ns              |
|                | RDY/BUSY Low output (Note 4)                     | 6 | T <sub>BUSY</sub> | 2   | 9   | CCLK<br>periods |

- Notes: 1. Configuration must be delayed until the NIT pins of all daisy-chained FPGAs are High.
  - 2. The time from the end of WS to CCLK cycle for the new byte of data depends on the completion of previous byte processing and the phase of the internal timing generator for CCLK.
  - 3. CCLK and DOUT timing is tested in slave mode.
  - 4. T<sub>RUSY</sub> indicates that the double-buffered parallel-to-serial converter is not yet ready to receive new data. The shortest T<sub>BUSY</sub> occurs when a byte is loaded into an empty parallel-to-serial converter. The longest T<sub>BUSY</sub> occurs when a new word is loaded into the input register before the second-level buffer has started shifting out data

This timing diagram shows very relaxed requirements. Data need not be held beyond the rising edge of WS. RDY/BUSY will go active within 60 ns after the end of WS. A new write may be asserted immediately after RDY/BUSY goes Low, but write may not be terminated until RDY/BUSY has been High for one CCLK period.

Figure 59: Asynchronous Peripheral Mode Programming Switching Characteristics



## **Product Availability**

Table 24, Table 25, and Table 26 show the planned packages and speed grades for XC4000-Series devices. Call your local sales office for the latest availability information, or see the Xilinx website at http://www.xilinx.com for the latest revision of the specifications.

Table 24: Component Availability Chart for XC4000XL FPGAs

|              | NS           | 84             | 100            | 100            | 144            | 144                | 160               | 160            | 176            | 176                | 208               | 208            | 240               | 240            | 256           | 299           | 304               | 352           | 411           | 432           | 475           | 559                                      | 560           |
|--------------|--------------|----------------|----------------|----------------|----------------|--------------------|-------------------|----------------|----------------|--------------------|-------------------|----------------|-------------------|----------------|---------------|---------------|-------------------|---------------|---------------|---------------|---------------|------------------------------------------|---------------|
|              |              |                |                |                |                |                    |                   |                |                |                    |                   |                |                   |                |               |               |                   |               |               |               |               |                                          |               |
| TYPE<br>CODE |              | Plast.<br>PLCC | Plast.<br>PQFP | Plast.<br>VQFP | Plast.<br>TQFP | High-Perf.<br>TQFP | High-Perf.<br>QFP | Plast.<br>PQFP | Plast.<br>TQFP | High-Perf.<br>TQFP | High-Perf.<br>QFP | Plast.<br>PQFP | High-Perf.<br>QFP | Plast.<br>PQFP | Plast.<br>BGA | Ceram.<br>PGA | High-Perf.<br>QFP | Plast.<br>BGA | Ceram.<br>PGA | Plast.<br>BGA | Ceram.<br>PGA | Ceram.<br>PGA                            | Plast.<br>BGA |
|              |              | PC84           | PQ100          | VQ100          | TQ144          | HT144              | HQ160             | PQ160          | TQ176          | HT176              | HQ208             | PQ208          | HQ240             | PQ240          | BG256         | PG299         | HQ304             | BG352         | PG411         | BG432         | PG475         | PG559                                    | BG560         |
|              | -3           | СІ             | СІ             | СІ             |                |                    |                   |                |                |                    |                   |                |                   |                |               |               |                   |               |               |               |               |                                          |               |
| XC4002XL     | -2           | СІ             | СІ             | СІ             |                |                    |                   |                |                |                    |                   |                |                   |                |               |               |                   |               |               |               |               |                                          |               |
| XO4002XL     | -1           | СІ             | СІ             | СІ             |                |                    |                   |                |                |                    |                   |                |                   |                |               |               |                   |               |               |               |               |                                          |               |
| -            | -09C         | С              | С              | С              |                |                    |                   |                |                |                    |                   |                |                   |                |               |               |                   |               |               |               |               |                                          |               |
|              | -3           | СІ             | СІ             | СІ             | СІ             |                    |                   | СІ             |                |                    |                   | СІ             |                   |                |               |               |                   |               |               |               |               |                                          |               |
| XC4005XL -   | -2           | CI             | С              | CI             | CI             |                    |                   | CI             |                |                    |                   | CI             |                   |                |               |               |                   |               |               |               |               |                                          |               |
| <u> </u>     | -1<br>-09C   | C I            | C I            | C I            | C I            |                    |                   | C I            |                |                    |                   | C I            |                   |                |               |               |                   |               |               |               |               |                                          |               |
|              | -3           | CI             | CI             |                | CI             |                    |                   | CI             | СІ             |                    |                   | CI             |                   |                | СІ            |               |                   |               |               |               |               | PG559                                    |               |
| XC4010XL     | -2           | СІ             | СІ             |                | СІ             |                    |                   | СІ             | СІ             |                    |                   | СІ             |                   |                | СІ            |               |                   |               |               |               |               |                                          |               |
|              | -1           | СІ             | СІ             |                | СІ             |                    |                   | СІ             | СІ             |                    |                   | СІ             |                   |                | СІ            |               |                   |               |               |               |               |                                          |               |
| -            | -09C         | С              | С              |                | С              |                    |                   | С              | С              |                    |                   | С              |                   |                | С             |               |                   |               |               |               |               |                                          |               |
| _            | -3<br>-2     |                |                |                |                | CI                 |                   | CI             |                | CI                 |                   | CI<br>CI       |                   | CI             | CI            |               |                   |               |               |               |               |                                          |               |
| XC4013XL     | - <u>-</u> 2 |                |                |                |                | CI                 |                   | CI             |                | CI                 |                   | CI             |                   | CI             | CI            |               |                   |               |               |               |               |                                          |               |
|              | -09C         |                |                |                |                | C                  |                   | C              |                | C                  |                   | C              |                   | C              | C             |               |                   |               |               |               |               |                                          |               |
|              | -08C         |                |                |                |                | С                  |                   | С              |                | С                  |                   | С              |                   | С              | С             |               |                   |               |               |               |               |                                          |               |
|              | -3           |                |                |                |                | СІ                 |                   | CI             |                | CI                 |                   | СІ             |                   | CI             | СІ            |               |                   |               |               |               |               |                                          |               |
| XC4020XL     | -2           |                |                |                |                | СІ                 |                   | СІ             |                | СІ                 |                   | СІ             |                   | СІ             | СІ            |               |                   |               |               |               |               |                                          |               |
| AC4020AL     | -1           |                |                |                |                | СІ                 |                   | СІ             |                | СІ                 |                   | СІ             |                   | CI             | СІ            |               |                   |               |               |               |               |                                          |               |
| -            | -09C         |                |                |                |                | С                  |                   | С              |                | С                  |                   | С              |                   | С              | С             |               |                   |               |               |               |               |                                          |               |
|              | -3           |                |                |                |                |                    | CI                |                |                |                    | CI                |                | CI                |                | CI            | CI            | CI                | CI            |               |               |               |                                          |               |
| XC4028XL -   | -2<br>-1     |                |                |                |                |                    | CI                |                |                |                    | CI                |                | CI                |                | CI            | CI            | CI                | CI            |               |               |               |                                          |               |
| _            | -09C         |                |                |                |                |                    | C                 |                |                |                    | C                 |                | С                 |                | С             | C             | C                 | C             |               |               |               |                                          |               |
|              | -3           |                |                |                |                |                    | CI                |                |                |                    | CI                |                | CI                |                |               |               | CI                | CI            | СІ            | СІ            |               |                                          |               |
|              | -2           |                |                |                |                |                    | CI                |                |                |                    | CI                |                | С                 |                |               |               | CI                | CI            | CI            | CI            |               |                                          |               |
| XC4036XL     | -1           |                |                |                |                |                    | СІ                |                |                |                    | СІ                |                | СІ                |                |               |               | СІ                | СІ            | СІ            | СІ            |               |                                          |               |
| -            | -09C         |                |                |                |                |                    | O                 |                |                |                    | С                 |                | С                 |                |               |               | С                 | С             | С             | С             |               | C1 (C1 (C1 (C1 (C1 (C1 (C1 (C1 (C1 (C1 ( |               |
| -            | -08C         |                |                |                |                |                    | С                 |                |                |                    | С                 |                | С                 |                |               |               | С                 | С             | С             | С             |               |                                          |               |
|              | -3           |                |                |                |                |                    | CI                |                |                |                    | CI                |                | CI                |                |               |               | CI                | CI            | CI            | CI            |               |                                          |               |
| XC4044XL     | -2<br>-1     |                |                |                |                |                    | CI                |                |                |                    | CI                |                | CI                |                |               |               | CI                | CI            | CI            | CI            |               |                                          |               |
| l -          | -09C         |                |                |                |                |                    | С                 |                |                |                    | С                 |                | С                 |                |               |               | С                 | C             | С             | С             |               |                                          |               |
|              | -3           |                |                |                |                |                    |                   |                |                |                    |                   |                | CI                |                |               |               | CI                | <u> </u>      | CI            | CI            |               |                                          | СІ            |
| VC4050VI     | -2           |                |                |                |                |                    |                   |                |                |                    |                   |                | СІ                |                |               |               | СІ                |               | СІ            | СІ            |               |                                          | СІ            |
| XC4052XL     | -1           |                |                |                |                |                    |                   |                |                |                    |                   |                | СІ                |                |               |               | CI                |               | СI            | СІ            |               |                                          | СI            |
| -            | -09C         |                |                |                |                |                    |                   |                |                |                    |                   |                | С                 |                |               |               | С                 |               | С             | С             |               |                                          | С             |
|              | -3           |                |                |                |                |                    |                   |                |                |                    |                   |                | CI                |                |               |               | CI                |               |               | CI            | CI            |                                          | CI            |
| VC4000VI     | -2           |                |                |                |                |                    |                   |                |                |                    |                   |                | CI                |                |               |               | CI                |               |               | CI            | CI            |                                          | CI            |
| //O 1002//L  | -1<br>-09C   |                |                |                |                |                    |                   |                |                |                    |                   |                | C1                |                |               |               | CI                |               |               | C I           | C I           |                                          | C             |
|              | -08C         |                |                |                |                |                    |                   |                |                |                    |                   |                | С                 |                |               |               | С                 |               |               | С             | С             |                                          | С             |
|              | -3           |                |                |                |                |                    |                   |                |                |                    |                   |                | Ť                 |                |               |               | ۲                 |               |               | CI            | بّ            | CI                                       | CI            |
| V04005\(\(\) | -2           |                |                |                |                |                    |                   |                |                |                    |                   |                |                   |                |               |               |                   |               |               | CI            |               |                                          | CI            |
| XC4085XL     | -1           |                |                |                |                |                    |                   |                |                |                    |                   |                |                   |                |               |               |                   |               |               | СІ            |               | СІ                                       | СІ            |
| I -          | -09C         |                |                |                |                |                    |                   |                |                |                    |                   |                |                   |                |               |               |                   |               |               | С             |               | С                                        | С             |

1/29/99

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

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