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 | 576 | | Number of Logic Elements/Cells | 1368 | | Total RAM Bits | 18432 | | Number of I/O | 129 | | Number of Gates | 13000 | | Voltage - Supply | 4.5V ~ 5.5V | | Mounting Type | Surface Mount | | Operating Temperature | -40°C ~ 100°C (TJ) | | Package / Case | 160-BQFP | | Supplier Device Package | 160-PQFP (28x28) | | Purchase URL | https://www.e-xfl.com/product-detail/xilinx/xc4013e-2pq160i | 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. #### **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 7: 16x1 Edge-Triggered Dual-Port RAM Figure 8 shows the write timing for level-sensitive, single-port RAM. The relationships between CLB pins and RAM inputs and outputs for single-port level-sensitive mode are shown in Table 7. Figure 9 and Figure 10 show block diagrams of a CLB configured as 16x2 and 32x1 level-sensitive, single-port RAM. #### Initializing RAM at Configuration Both RAM and ROM implementations of the XC4000 Series devices are initialized during configuration. The initial contents are defined via an INIT attribute or property attached to the RAM or ROM symbol, as described in the schematic library guide. If not defined, all RAM contents are initialized to all zeros, by default. RAM initialization occurs only during configuration. The RAM content is not affected by Global Set/Reset. **Table 7: Single-Port Level-Sensitive RAM Signals** | RAM Signal | CLB Pin | Function | |------------|----------------|--------------| | D | D0 or D1 | Data In | | A[3:0] | F1-F4 or G1-G4 | Address | | WE | WE | Write Enable | | 0 | F' or G' | Data Out | Figure 8: Level-Sensitive RAM Write Timing May 14, 1999 (Version 1.6) Figure 9: 16x2 (or 16x1) Level-Sensitive Single-Port RAM Figure 10: 32x1 Level-Sensitive Single-Port RAM (F and G addresses are identical) Figure 13: Fast Carry Logic in XC4000E CLB (shaded area not present in XC4000X) Figure 15: Simplified Block Diagram of XC4000E IOB Figure 16: Simplified Block Diagram of XC4000X IOB (shaded areas indicate differences from XC4000E) ## Output Multiplexer/2-Input Function Generator (XC4000X only) As shown in Figure 16 on page 21, the output path in the XC4000X IOB contains an additional multiplexer not available in the XC4000E IOB. The multiplexer can also be configured as a 2-input function generator, implementing a pass-gate, AND-gate, OR-gate, or XOR-gate, with 0, 1, or 2 inverted inputs. The logic used to implement these functions is shown in the upper gray area of Figure 16. When configured as a multiplexer, this feature allows two output signals to time-share the same output pad; effectively doubling the number of device outputs without requiring a larger, more expensive package. When the MUX is configured as a 2-input function generator, logic can be implemented within the IOB itself. Combined with a Global Early buffer, this arrangement allows very high-speed gating of a single signal. For example, a wide decoder can be implemented in CLBs, and its output gated with a Read or Write Strobe Driven by a BUFGE buffer, as shown in Figure 19. The critical-path pin-to-pin delay of this circuit is less than 6 nanoseconds. As shown in Figure 16, the IOB input pins Out, Output Clock, and Clock Enable have different delays and different flexibilities regarding polarity. Additionally, Output Clock sources are more limited than the other inputs. Therefore, the Xilinx software does not move logic into the IOB function generators unless explicitly directed to do so. The user can specify that the IOB function generator be used, by placing special library symbols beginning with the letter "O." For example, a 2-input AND-gate in the IOB function generator is called OAND2. Use the symbol input pin labelled "F" for the signal on the critical path. This signal is placed on the OK pin — the IOB input with the shortest delay to the function generator. Two examples are shown in Figure 20. Figure 19: Fast Pin-to-Pin Path in XC4000X Figure 20: AND & MUX Symbols in XC4000X IOB #### Other IOB Options There are a number of other programmable options in the XC4000 Series IOB. #### Pull-up and Pull-down Resistors Programmable pull-up and pull-down resistors are useful for tying unused pins to Vcc or Ground to minimize power consumption and reduce noise sensitivity. The configurable pull-up resistor is a p-channel transistor that pulls to Vcc. The configurable pull-down resistor is an n-channel transistor that pulls to Ground. The value of these resistors is 50 k $\Omega$ – 100 k $\Omega$ . This high value makes them unsuitable as wired-AND pull-up resistors. The pull-up resistors for most user-programmable IOBs are active during the configuration process. See Table 22 on page 58 for a list of pins with pull-ups active before and during configuration. After configuration, voltage levels of unused pads, bonded or un-bonded, must be valid logic levels, to reduce noise sensitivity and avoid excess current. Therefore, by default, unused pads are configured with the internal pull-up resistor active. Alternatively, they can be individually configured with the pull-down resistor, or as a driven output, or to be driven by an external source. To activate the internal pull-up, attach the PULLUP library component to the net attached to the pad. To activate the internal pull-down, attach the PULLDOWN library component to the net attached to the pad. #### Independent Clocks Separate clock signals are provided for the input and output flip-flops. The clock can be independently inverted for each flip-flop within the IOB, generating either falling-edge or rising-edge triggered flip-flops. The clock inputs for each IOB are independent, except that in the XC4000X, the Fast Capture latch shares an IOB input with the output clock pin. #### Early Clock for IOBs (XC4000X only) Special early clocks are available for IOBs. These clocks are sourced by the same sources as the Global Low-Skew buffers, but are separately buffered. They have fewer loads and therefore less delay. The early clock can drive either the IOB output clock or the IOB input clock, or both. The early clock allows fast capture of input data, and fast clock-to-output on output data. The Global Early buffers that drive these clocks are described in "Global Nets and Buffers (XC4000X only)" on page 37. #### **Global Set/Reset** As with the CLB registers, the Global Set/Reset signal (GSR) can be used to set or clear the input and output registers, depending on the value of the INIT attribute or property. The two flip-flops can be individually configured to set ## 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 circuit prevents undefined floating levels. However, it is overridden by any driver, even a pull-up resistor. Each XC4000E longline has a programmable splitter switch at its center, as does each XC4000X longline driven by TBUFs. This switch can separate the line into two independent routing channels, each running half the width or height of the array. Each XC4000X longline not driven by TBUFs has a buffered programmable splitter switch at the 1/4, 1/2, and 3/4 points of the array. Due to the buffering, XC4000X longline performance does not deteriorate with the larger array sizes. If the longline is split, the resulting partial longlines are independent. Routing connectivity of the longlines is shown in Figure 27 on page 30. #### Direct Interconnect (XC4000X only) The XC4000X offers two direct, efficient and fast connections between adjacent CLBs. These nets facilitate a data flow from the left to the right side of the device, or from the top to the bottom, as shown in Figure 30. Signals routed on the direct interconnect exhibit minimum interconnect propagation delay and use no general routing resources. The direct interconnect is also present between CLBs and adjacent IOBs. Each IOB on the left and top device edges has a direct path to the nearest CLB. Each CLB on the right and bottom edges of the array has a direct path to the nearest two IOBs, since there are two IOBs for each row or column of CLBs. The place and route software uses direct interconnect whenever possible, to maximize routing resources and minimize interconnect delays. Figure 30: XC4000X Direct Interconnect #### I/O Routing XC4000 Series devices have additional routing around the IOB ring. This routing is called a VersaRing. The VersaRing facilitates pin-swapping and redesign without affecting board layout. Included are eight double-length lines spanning two CLBs (four IOBs), and four longlines. Global lines and Wide Edge Decoder lines are provided. XC4000X devices also include eight octal lines. A high-level diagram of the VersaRing is shown in Figure 31. The shaded arrows represent routing present only in XC4000X devices. Figure 33 on page 34 is a detailed diagram of the XC4000E and XC4000X VersaRing. The area shown includes two IOBs. There are two IOBs per CLB row or column, therefore this diagram corresponds to the CLB routing diagram shown in Figure 27 on page 30. The shaded areas represent routing and routing connections present only in XC4000X devices. #### Octal I/O Routing (XC4000X only) Between the XC4000X CLB array and the pad ring, eight interconnect tracks provide for versatility in pin assignment and fixed pinout flexibility. (See Figure 32 on page 33.) These routing tracks are called octals, because they can be broken every eight CLBs (sixteen IOBs) by a programmable buffer that also functions as a splitter switch. The buffers are staggered, so each line goes through a buffer at every eighth CLB location around the device edge. The octal lines bend around the corners of the device. The lines cross at the corners in such a way that the segment most recently buffered before the turn has the farthest distance to travel before the next buffer, as shown in Figure 32. 6-32 May 14, 1999 (Version 1.6) #### Global Nets and Buffers (XC4000X only) Eight vertical longlines in each CLB column are driven by special global buffers. These longlines are in addition to the vertical longlines used for standard interconnect. The global lines are broken in the center of the array, to allow faster distribution and to minimize skew across the whole array. Each half-column global line has its own buffered multiplexer, as shown in Figure 35. The top and bottom global lines cannot be connected across the center of the device, as this connection might introduce unacceptable skew. The top and bottom halves of the global lines must be separately driven — although they can be driven by the same global buffer. The eight global lines in each CLB column can be driven by either of two types of global buffers. They can also be driven by internal logic, because they can be accessed by single, double, and quad lines at the top, bottom, half, and quarter points. Consequently, the number of different clocks that can be used simultaneously in an XC4000X device is very large. There are four global lines feeding the IOBs at the left edge of the device. IOBs along the right edge have eight global lines. There is a single global line along the top and bottom edges with access to the IOBs. All IOB global lines are broken at the center. They cannot be connected across the center of the device, as this connection might introduce unacceptable skew. IOB global lines can be driven from two types of global buffers, or from local interconnect. Alternatively, top and bottom IOBs can be clocked from the global lines in the adjacent CLB column. Two different types of clock buffers are available in the XC4000X: - Global Low-Skew Buffers (BUFGLS) - Global Early Buffers (BUFGE) Global Low-Skew Buffers are the standard clock buffers. They should be used for most internal clocking, whenever a large portion of the device must be driven. Global Early Buffers are designed to provide a faster clock access, but CLB access is limited to one-fourth of the device. They also facilitate a faster I/O interface. Figure 35 is a conceptual diagram of the global net structure in the XC4000X. Global Early buffers and Global Low-Skew buffers share a single pad. Therefore, the same IPAD symbol can drive one buffer of each type, in parallel. This configuration is particularly useful when using the Fast Capture latches, as described in "IOB Input Signals" on page 20. Paired Global Early and Global Low-Skew buffers share a common input; they cannot be driven by two different signals. #### Choosing an XC4000X Clock Buffer The clocking structure of the XC4000X provides a large variety of features. However, it can be simple to use, without understanding all the details. The software automatically handles clocks, along with all other routing, when the appropriate clock buffer is placed in the design. In fact, if a buffer symbol called BUFG is placed, rather than a specific type of buffer, the software even chooses the buffer most appropriate for the design. The detailed information in this section is provided for those users who want a finer level of control over their designs. If fine control is desired, use the following summary and Table 15 on page 35 to choose an appropriate clock buffer. - The simplest thing to do is to use a Global Low-Skew buffer. - If a faster clock path is needed, try a BUFG. The software will first try to use a Global Low-Skew Buffer. If timing requirements are not met, a faster buffer will automatically be used. - If a single quadrant of the chip is sufficient for the clocked logic, and the timing requires a faster clock than the Global Low-Skew buffer, use a Global Early buffer. #### **Global Low-Skew Buffers** Each corner of the XC4000X device has two Global Low-Skew buffers. Any of the eight Global Low-Skew buffers can drive any of the eight vertical Global lines in a column of CLBs. In addition, any of the buffers can drive any of the four vertical lines accessing the IOBs on the left edge of the device, and any of the eight vertical lines accessing the IOBs on the right edge of the device. (See Figure 36 on page 38.) IOBs at the top and bottom edges of the device are accessed through the vertical Global lines in the CLB array, as in the XC4000E. Any Global Low-Skew buffer can, therefore, access every IOB and CLB in the device. The Global Low-Skew buffers can be driven by either semi-dedicated pads or internal logic. To use a Global Low-Skew buffer, instantiate a BUFGLS element in a schematic or in HDL code. If desired, attach a LOC attribute or property to direct placement to the designated location. For example, attach a LOC=T attribute or property to direct that a BUFGLS be placed in one of the two Global Low-Skew buffers on the top edge of the device, or a LOC=TR to indicate the Global Low-Skew buffer on the top edge of the device, on the right. #### **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. used), and if RAM is present, the RAM content must be unchanged. Statistically, one error out of 2048 might go undetected. #### **Configuration Sequence** There are four major steps in the XC4000 Series power-up configuration sequence. - Configuration Memory Clear - Initialization - Configuration - Start-Up The full process is illustrated in Figure 46. #### Configuration Memory Clear When power is first applied or is reapplied to an FPGA, an internal circuit forces initialization of the configuration logic. When Vcc reaches an operational level, and the circuit passes the write and read test of a sample pair of configuration bits, a time delay is started. This time delay is nominally 16 ms, and up to 10% longer in the low-voltage devices. The delay is four times as long when in Master Modes (M0 Low), to allow ample time for all slaves to reach a stable Vcc. When all $\overline{\text{INIT}}$ pins are tied together, as recommended, the longest delay takes precedence. Therefore, devices with different time delays can easily be mixed and matched in a daisy chain. This delay is applied only on power-up. It is not applied when re-configuring an FPGA by pulsing the $\overline{\text{PROGRAM}}$ pin Figure 45: Circuit for Generating CRC-16 Figure 46: Power-up Configuration Sequence #### Product Obsolete or Under Obsolescence XC4000E and XC4000X Series Field Programmable Gate Arrays Low. During this time delay, or as long as the PROGRAM input is asserted, the configuration logic is held in a Configuration Memory Clear state. The configuration-memory frames are consecutively initialized, using the internal oscillator. At the end of each complete pass through the frame addressing, the power-on time-out delay circuitry and the level of the PROGRAM pin are tested. If neither is asserted, the logic initiates one additional clearing of the configuration frames and then tests the NIT input. #### Initialization During initialization and configuration, user pins HDC, $\overline{\text{LDC}}$ , $\overline{\text{INIT}}$ and DONE provide status outputs for the system interface. The outputs $\overline{\text{LDC}}$ , $\overline{\text{INIT}}$ and DONE are held Low and HDC is held High starting at the initial application of power. The open drain $\overline{INIT}$ pin is released after the final initialization pass through the frame addresses. There is a deliberate delay of 50 to 250 $\mu s$ (up to 10% longer for low-voltage devices) before a Master-mode device recognizes an inactive $\overline{INIT}$ . Two internal clocks after the $\overline{INIT}$ pin is recognized as High, the FPGA samples the three mode lines to determine the configuration mode. The appropriate interface lines become active and the configuration preamble and data can be loaded.Configuration The 0010 preamble code indicates that the following 24 bits represent the length count. The length count is the total number of configuration clocks needed to load the complete configuration data. (Four additional configuration clocks are required to complete the configuration process, as discussed below.) After the preamble and the length count have been passed through to all devices in the daisy chain, DOUT is held High to prevent frame start bits from reaching any daisy-chained devices. A specific configuration bit, early in the first frame of a master device, controls the configuration-clock rate and can increase it by a factor of eight. Therefore, if a fast configuration clock is selected by the bitstream, the slower clock rate is used until this configuration bit is detected. Each frame has a start field followed by the frame-configuration data bits and a frame error field. If a frame data error is detected, the FPGA halts loading, and signals the error by pulling the open-drain $\overline{\text{INIT}}$ pin Low. After all configuration frames have been loaded into an FPGA, DOUT again follows the input data so that the remaining data is passed on to the next device. #### **Delaying Configuration After Power-Up** There are two methods of delaying configuration after power-up: put a logic Low on the PROGRAM input, or pull the bidirectional INIT pin Low, using an open-collector (open-drain) driver. (See Figure 46 on page 50.) A Low on the PROGRAM input is the more radical approach, and is recommended when the power-supply rise time is excessive or poorly defined. As long as \$\overline{PRO}\$ GRAM is Low, the FPGA keeps clearing its configuration memory. When \$\overline{PROGRAM}\$ goes High, the configuration memory is cleared one more time, followed by the beginning of configuration, provided the \$\overline{INIT}\$ input is not externally held Low. Note that a Low on the \$\overline{PROGRAM}\$ input automatically forces a Low on the \$\overline{INIT}\$ output. The XC4000 Series \$\overline{PROGRAM}\$ pin has a permanent weak pull-up. Using an open-collector or open-drain driver to hold $\overline{INIT}$ Low before the beginning of configuration causes the FPGA to wait after completing the configuration memory clear operation. When $\overline{INIT}$ is no longer held Low externally, the device determines its configuration mode by capturing its mode pins, and is ready to start the configuration process. A master device waits up to an additional 250 $\mu s$ to make sure that any slaves in the optional daisy chain have seen that $\overline{INIT}$ is High. #### Start-Up Start-up is the transition from the configuration process to the intended user operation. This transition involves a change from one clock source to another, and a change from interfacing parallel or serial configuration data where most outputs are 3-stated, to normal operation with I/O pins active in the user-system. Start-up must make sure that the user-logic 'wakes up' gracefully, that the outputs become active without causing contention with the configuration signals, and that the internal flip-flops are released from the global Reset or Set at the right time. Figure 47 describes start-up timing for the three Xilinx families in detail. The configuration modes can use any of the four timing sequences. To access the internal start-up signals, place the STARTUP library symbol. #### **Start-up Timing** Different FPGA families have different start-up sequences. The XC2000 family goes through a fixed sequence. DONE goes High and the internal global Reset is de-activated one CCLK period after the I/O become active. The XC3000A family offers some flexibility. DONE can be programmed to go High one CCLK period before or after the I/O become active. Independent of DONE, the internal global Reset is de-activated one CCLK period before or after the I/O become active. The XC4000 Series offers additional flexibility. The three events — DONE going High, the internal Set/Reset being de-activated, and the user I/O going active — can all occur in any arbitrary sequence. Each of them can occur one CCLK period before or after, or simultaneous with, any of the others. This relative timing is selected by means of software options in the bitstream generation software. #### XC4000E/EX/XL Program Readback Switching Characteristic Guidelines Testing of the switching parameters is modeled after testing methods specified by MIL-M-38510/605. All devices are 100% functionally tested. Internal timing parameters are not measured directly. They are derived from benchmark timing patterns that are taken at device introduction, prior to any process improvements. The following guidelines reflect worst-case values over the recommended operating conditions. #### E/EX | | Description | | scription Symbol | | Max | Units | |-----------|------------------------------------------------|---|-------------------|-----|-----|-------| | rdbk.TRIG | rdbk.TRIG setup to initiate and abort Readback | 1 | T <sub>RTRC</sub> | 200 | - | ns | | | rdbk.TRIG hold to initiate and abort Readback | 2 | T <sub>RCRT</sub> | 50 | - | ns | | rdclk.1 | rdbk.DATA delay | 7 | T <sub>RCRD</sub> | - | 250 | ns | | | rdbk.RIP delay | 6 | T <sub>RCRR</sub> | - | 250 | ns | | | High time | 5 | T <sub>RCH</sub> | 250 | 500 | ns | | | Low time | 4 | T <sub>RCL</sub> | 250 | 500 | ns | Note 1: Timing parameters apply to all speed grades. Note 2: If rdbk.TRIG is High prior to Finished, Finished will trigger the first Readback. #### XL | | Description | | Symbol | Min | Max | Units | |-----------|------------------------------------------------|---|-------------------|-----|-----|-------| | rdbk.TRIG | rdbk.TRIG setup to initiate and abort Readback | 1 | T <sub>RTRC</sub> | 200 | - | ns | | | rdbk.TRIG hold to initiate and abort Readback | 2 | T <sub>RCRT</sub> | 50 | - | ns | | rdclk.1 | rdbk.DATA delay | 7 | T <sub>RCRD</sub> | - | 250 | ns | | | rdbk.RIP delay | 6 | T <sub>RCRR</sub> | - | 250 | ns | | | High time | 5 | T <sub>RCH</sub> | 250 | 500 | ns | | | Low time | 4 | T <sub>RCL</sub> | 250 | 500 | ns | Note 1: Timing parameters apply to all speed grades. Note 2: If rdbk.TRIG is High prior to Finished, Finished will trigger the first Readback. **Table 22: Pin Functions During Configuration** | 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 | ĪNIT | ĪNIT | ĪNIT | ĪNIT | I/O | | DONE | PROGRAM (I) | PROGRAM (I) | PROGRAM (I) | PROGRAM (I) | PROGRAM (I) | PROGRAM (I) | PROGRAM | | CCLK (I) | CCLK (O) | CCLK (I) | CCLK (O) | CCLK (O) | CCLK (O) | CCLK (I) | | | | RDY/BUSY (O) | RDY/BUSY (O) | RCLK (O) | RCLK (O) | I/O | | | | | RS (I) | | | I/O | | | | | CSO (I) | | | I/O | | | | DATA 7 (I) | DATA 7 (I) | DATA 7 (I) | DATA 7 (I) | I/O | | | | DATA 6 (I) | DATA 6 (I) | DATA 6 (I) | DATA 6 (I) | I/O | | | | DATA 5 (I) | DATA 5 (I) | DATA 5 (I) | DATA 5 (I) | I/O | | | | DATA 4 (I) | DATA 4 (I) | DATA 4 (I) | DATA 4 (I) | I/O | | | | DATA 3 (I) | DATA 3 (I) | DATA 3 (I) | DATA 3 (I) | I/O | | | | DATA 2 (I) | DATA 2 (I) | DATA 2 (I) | DATA 2 (I) | I/O | | | | DATA 1 (I) | DATA 1 (I) | DATA 1 (I) | DATA 1 (I) | I/O | | DIN (I) | DIN (I) | DATA 0 (I) | DATA 0 (I) | DATA 0 (I) | DATA 0 (I) | I/O | | DOUT | DOUT | DOUT | DOUT | DOUT | DOUT | SGCK4-GCK6-I/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 | **Table 23: Pin Functions During Configuration** | 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 | 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 | <sup>\*</sup> XC4000X only Notes 1. A shaded table cell represents a 50 k $\Omega$ - 100 k $\Omega$ pull-up before and during configuration. <sup>(</sup>I) represents an input; (O) represents an output. INIT is an open-drain output during configuration. #### Master Serial Mode In Master Serial mode, the CCLK output of the lead FPGA drives a Xilinx Serial PROM that feeds the FPGA DIN input. Each rising edge of the CCLK output increments the Serial PROM internal address counter. The next data bit is put on the SPROM data output, connected to the FPGA DIN pin. The lead FPGA accepts this data on the subsequent rising CCLK edge. The lead FPGA then presents the preamble data—and all data that overflows the lead device—on its DOUT pin. There is an internal pipeline 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 the bitstream generation software, the user can specify Fast ConfigRate, which, starting several bits into the first frame, increases the CCLK frequency by a factor of eight. For actual timing values please refer to "Configuration Switching Characteristics" on page 68. Be sure that the serial PROM and slaves are fast enough to support this data rate. XC2000, XC3000/A, and XC3100A devices do not support the Fast ConfigRate option. The SPROM CE input can be driven from either LDC or DONE. Using LDC avoids potential contention on the DIN pin, if this pin is configured as user-I/O, but LDC is then restricted to be a permanently High user output after configuration. Using DONE can also avoid contention on DIN, provided the early DONE option is invoked. Figure 51 on page 60 shows a full master/slave system. The leftmost device is in Master Serial mode. Master Serial mode is selected by a <000> on the mode pins (M2, M1, M0). | | Description | Symbol | | Min | Max | Units | |-------|-------------|--------|-------------------|-----|-----|-------| | CCLK | DIN setup | 1 | T <sub>DSCK</sub> | 20 | | ns | | COLIN | DIN hold | 2 | T <sub>CKDS</sub> | 0 | | ns | Notes: 1. At power-up, Vcc must rise from 2.0 V to Vcc min in less than 25 ms, otherwise delay configuration by pulling PROGRAM Low until Vcc is valid. 2. Master Serial mode timing is based on testing in slave mode. Figure 53: Master Serial Mode Programming Switching Characteristics | | Description | Symbol | Min | Max | Units | |------|------------------------|------------------|-----|-----|-------| | | INIT (High) setup time | T <sub>IC</sub> | 5 | | μs | | | D0 - D7 setup time | T <sub>DC</sub> | 60 | | ns | | CCLK | D0 - D7 hold time | T <sub>CD</sub> | 0 | | ns | | CCLK | CCLK High time | T <sub>CCH</sub> | 50 | | ns | | | CCLK Low time | T <sub>CCL</sub> | 60 | | ns | | | CCLK Frequency | F <sub>CC</sub> | | 8 | MHz | Notes: 1. Peripheral Synchronous mode can be considered Slave Parallel mode. An external CCLK provides timing, clocking in the **first** data byte on the **second** rising edge of CCLK after INIT goes High. Subsequent data bytes are clocked in on every eighth consecutive rising edge of CCLK. - 2. The RDY/BUSY line goes High for one CCLK period after data has been clocked in, although synchronous operation does not require such a response. - 3. The pin name RDY/BUSY is a misnomer. In Synchronous Peripheral mode this is really an ACKNOWLEDGE signal. - 4. Note that data starts to shift out serially on the DOUT pin 0.5 CCLK periods after it was loaded in parallel. Therefore, additional CCLK pulses are clearly required after the last byte has been loaded. Figure 57: Synchronous Peripheral Mode Programming Switching Characteristics ### **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-P<br>OFF | Plas<br>BG/ | Cerai<br>PG/ | Plas<br>BG/ | ı | 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 | | | СІ | | | | | | | | | | XC4010XL | -2 | СІ | СІ | | СІ | | | СІ | СІ | | | СІ | | | СІ | | C C C C C C C C C C C C C C C C C C C | | | | | | | | | -1 | СІ | СІ | | СІ | | | СІ | СІ | | | СІ | | | СІ | | | | | PG411 Ceram. Ceram. Common of the poly and | | | | | - | -09C | С | С | | С | | | С | С | | | С | | | | | | | | | | | | | | -3<br>-2 | | | | | CI | | CI | | CI | | CI<br>CI | | | | | | | | | | | | | XC4013XL | - <u>-</u> 2 | | | | | CI | | CI | | CI | | CI | | | | | | | | | | | | | | -09C | | | | | C | | C | | C | | C | | | | | | | | | | | | | | -08C | | | | | С | | С | | С | | С | | С | | | | | | | | | | | | -3 | | | | | СІ | | CI | | CI | | СІ | | CI | СІ | | | | | | | | | | XC4020XL | -2 | | | | | СІ | | СІ | | СІ | | СІ | | СІ | СІ | | | | | | | | | | AC4020AL | -1 | | | | | СІ | | СІ | | СІ | | СІ | | CI | СІ | | | | | | | | | | - | -09C | | | | | С | | С | | С | | С | | С | С | | | | | | | | | | | -3 | | | | | | CI | | | | CI | | CI | | | | _ | | | | | | | | XC4028XL - | -2<br>-1 | | | | | | CI | | | | CI | | CI | | | | | | | | | | | | _ | -09C | | | | | | C | | | | C | | С | | | | _ | | | | | | | | | -3 | | | | | | CI | | | | CI | | CI | | | | | | CI | CI | | | | | | -2 | | | | | | CI | | | | CI | | С | | | | | | | | | | | | XC4036XL | -1 | | | | | | СІ | | | | СІ | | СІ | | | | СІ | СІ | СІ | СІ | | | | | - | -09C | | | | | | O | | | | С | | С | C1 C | С | С | | | | | | | | | - | -08C | | | | | | С | | | | С | | С | | | | С | С | С | С | | | | | | -3 | | | | | | CI | | | | CI | | CI | | | | _ | | | | | | | | XC4044XL | -2<br>-1 | | | | | | CI | | | | CI | | CI | | | | | | | | | | | | l - | -09C | | | | | | С | | | | С | | С | | | | | | | | | | | | | -3 | | | | | | | | | | | | CI | | | | | <u> </u> | | | | | СІ | | VC4050VI | -2 | | | | | | | | | | | | СІ | | | | СІ | | СІ | | | | СІ | | XC4052XL | -1 | | | | | | | | | | | | СІ | | | | CI | | CI | СІ | | | СІ | | - | -09C | | | | | | | | | | | | С | | | | | | С | | | | С | | | -3 | | | | | | | | | | | | CI | | | | | | | | | | CI | | VC4000VI | -2 | | | | | | | | | | | | CI | | | | | | | | | | CI | | //O 1002//L | -1<br>-09C | | | | | | | | | | | | C1 | | | | | | | | _ | | C | | | -08C | | | | | | | | | | | | С | | | | | | | | | | С | | | -3 | | | | | | | | | | | | Ť | | | | ۲ | | | | بّ | CI | CI | | V04005\(\(\) | -2 | | | | | | | | | | | | | | | | | | | | | CI | CI | | XC4085XL | -1 | | | | | | | | | | | | | | C C C C C C C C C C | | | СІ | СІ | | | | | | 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$ # Product Obsolete or Under Obsolescence XC4000E and XC4000X Series Field Programmable Gate Arrays Table 25: Component Availability Chart for XC4000E FPGAs | F | PINS | 84 | 100 | 100 | 120 | 144 | 156 | 160 | 191 | 208 | 208 | 223 | 225 | 240 | 240 | 299 | 304 | |----------|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------------|----------------|---------------|----------------|---------------|-------------------|----------------|---------------|---------------|-------------------|----------------|---------------|------------------| | TYPE | | Plast.<br>PLCC | Plast.<br>PQFP | Plast.<br>VQFP | Ceram.<br>PGA | Plast.<br>TQFP | Ceram.<br>PGA | Plast.<br>PQFP | Ceram.<br>PGA | High-Perf.<br>QFP | Plast.<br>PQFP | Ceram.<br>PGA | Plast.<br>BGA | High-Perf.<br>QFP | Plast.<br>PQFP | Ceram.<br>PGA | High-Perf.<br>QF | | CODE | | PC84 | PQ100 | VQ100 | PG120 | TQ144 | PG156 | PQ160 | PG191 | HQ208 | PQ208 | PG223 | BG225 | HQ240 | PQ240 | PG299 | HQ304 High-Perf. | | | -4 | CI | CI | CI | CI | | | | | | | | | | | | | | XC4003E | -3 | СІ | СІ | СІ | СІ | | | | | | | | | | | | | | AC4003E | -2 | CI | СІ | СІ | CI | | | | | | | | | | | | | | | -1 | С | С | С | С | | | | | | | | | | Plast.<br>PQFP | | | | | -4 | СІ | СІ | | | СІ | СІ | СІ | | | CI | | | | | | | | XC4005E | -3 | СІ | СІ | | | СІ | СІ | СІ | | | СІ | | | | | | | | AC4005E | -2 | CI | СІ | | | СІ | СІ | СІ | | | СІ | | | | | | | | İ | -1 | С | С | | | С | С | С | | | С | | | | | | | | | -4 | CI | | | | CI | СІ | СІ | | | CI | | | | | | | | XC4006E | -3 | СІ | | | | CI | СІ | СІ | | | CI | | | | | | | | AC4000E | -2 | CI | | | | CI | CI | CI | | | CI | | | | | | | | Ī | -1 | С | | | | С | С | С | | | С | | | | | | | | | -4 | СІ | | | | | | CI | CI | | CI | | | | | | | | XC4008E | -3 | СІ | | | | | | СІ | CI | | CI | | | | | | | | AC4000L | -2 | CI | C1 C1< | | | | | | | | | | | | | | | | | -1 | С | | | | | | С | С | | С | | C | | | | | | | -4 | CI | | | | | | CI | СІ | CI | CI | | CI | | | | | | XC4010E | -3 | CI | | | | | | CI | CI | CI | CI | | CI | | | | | | AC4010L | -2 | CI | | | | | | CI | CI | CI | CI | | CI | | | | | | | -1 | С | | | | | | С | С | С | С | | | | | | | | | -4 | | | | | | | CI | | CI | CI | CI | | CI | CI | | | | XC4013E | -3 | | | | | | | CI | | CI | CI | CI | 1 | | | | | | NO-1010L | -2 | | | | | | | CI | | CI | CI | CI | CI | CI | | | | | | -1 | | | | | | | С | | С | С | С | С | С | С | | | | | -4 | | | | | | | | | CI | | CI | | CI | | | | | XC4020E | -3 | | | | | | | | | CI | | CI | | CI | | | | | 7.0-020L | -2 | | | | | | | | | CI | | CI | | CI | | | | | | -1 | | | | | | | | | С | | С | | С | | | | | | -4 | | | | | | | | | | | CI | | CI | | CI | CI | | XC4025E | -3 | | | | | | | | | | | CI | | CI | | CI | CI | | 1/29/99 | -2 | | | | | | | | | | | С | | С | | С | С | C = Commercial $T_J = 0^{\circ}$ to +85°C I= Industrial $T_J = -40^{\circ}$ C to +100°C Table 26: Component Availability Chart for XC4000EX FPGAs | PINS | | 208 | 240 | 299 | 304 | 352 | 411 | 432 | |----------|----|-------------------|-------------------|---------------|-------------------|---------------|---------------|---------------| | TYPE | | High-Perf.<br>QFP | High-Perf.<br>QFP | Ceram.<br>PGA | High-Perf.<br>QFP | Plast.<br>BGA | Ceram.<br>PGA | Plast.<br>BGA | | CODE | | HQ208 | HQ240 | PG299 | HQ304 | BG352 | PG411 | BG432 | | | -4 | CI | CI | CI | CI | CI | | | | XC4028EX | -3 | CI | CI | CI | CI | CI | | | | | -2 | С | С | С | С | С | | | | | -4 | | CI | | CI | CI | CI | CI | | XC4036EX | -3 | | CI | | CI | CI | CI | CI | | | -2 | | С | | С | С | С | С | 1/29/99 C = Commercial $T_J = 0^{\circ}$ to +85°C I= Industrial $T_J = -40^{\circ}$ C to +100°C