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 | 61 | | Number of Gates | 10000 | | Voltage - Supply | 3V ~ 3.6V | | Mounting Type | Surface Mount | | Operating Temperature | -40°C ~ 100°C (TJ) | | Package / Case | 84-LCC (J-Lead) | | Supplier Device Package | 84-PLCC (29.31x29.31) | | Purchase URL | https://www.e-xfl.com/product-detail/xilinx/xc4010xl-2pc84i | 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. ## **Detailed Functional Description** XC4000 Series devices achieve high speed through advanced semiconductor technology and improved architecture. The XC4000E and XC4000X support system clock rates of up to 80 MHz and internal performance in excess of 150 MHz. Compared to older Xilinx FPGA families, XC4000 Series devices are more powerful. They offer on-chip edge-triggered and dual-port RAM, clock enables on I/O flip-flops, and wide-input decoders. They are more versatile in many applications, especially those involving RAM. Design cycles are faster due to a combination of increased routing resources and more sophisticated software. ## **Basic Building Blocks** Xilinx user-programmable gate arrays include two major configurable elements: configurable logic blocks (CLBs) and input/output blocks (IOBs). - CLBs provide the functional elements for constructing the user's logic. - IOBs provide the interface between the package pins and internal signal lines. Three other types of circuits are also available: - 3-State buffers (TBUFs) driving horizontal longlines are associated with each CLB. - Wide edge decoders are available around the periphery of each device. - An on-chip oscillator is provided. Programmable interconnect resources provide routing paths to connect the inputs and outputs of these configurable elements to the appropriate networks. The functionality of each circuit block is customized during configuration by programming internal static memory cells. The values stored in these memory cells determine the logic functions and interconnections implemented in the FPGA. Each of these available circuits is described in this section. ## **Configurable Logic Blocks (CLBs)** Configurable Logic Blocks implement most of the logic in an FPGA. The principal CLB elements are shown in Figure 1. Two 4-input function generators (F and G) offer unrestricted versatility. Most combinatorial logic functions need four or fewer inputs. However, a third function generator (H) is provided. The H function generator has three inputs. Either zero, one, or two of these inputs can be the outputs of F and G; the other input(s) are from outside the CLB. The CLB can, therefore, implement certain functions of up to nine variables, like parity check or expandable-identity comparison of two sets of four inputs. Each CLB contains two storage elements that can be used to store the function generator outputs. However, the storage elements and function generators can also be used independently. These storage elements can be configured as flip-flops in both XC4000E and XC4000X devices; in the XC4000X they can optionally be configured as latches. DIN can be used as a direct input to either of the two storage elements. H1 can drive the other through the H function generator. Function generator outputs can also drive two outputs independent of the storage element outputs. This versatility increases logic capacity and simplifies routing. Thirteen CLB inputs and four CLB outputs provide access to the function generators and storage elements. These inputs and outputs connect to the programmable interconnect resources outside the block. #### **Function Generators** Four independent inputs are provided to each of two function generators (F1 - F4 and G1 - G4). These function generators, with outputs labeled F' and G', are each capable of implementing any arbitrarily defined Boolean function of four inputs. The function generators are implemented as memory look-up tables. The propagation delay is therefore independent of the function implemented. A third function generator, labeled H', can implement any Boolean function of its three inputs. Two of these inputs can optionally be the F' and G' functional generator outputs. Alternatively, one or both of these inputs can come from outside the CLB (H2, H0). The third input must come from outside the block (H1). Signals from the function generators can exit the CLB on two outputs. F' or H' can be connected to the X output. G' or H' can be connected to the Y output. A CLB can be used to implement any of the following functions: - any function of up to four variables, plus any second function of up to four unrelated variables, plus any third function of up to three unrelated variables<sup>1</sup> - any single function of five variables - any function of four variables together with some functions of six variables - · some functions of up to nine variables. Implementing wide functions in a single block reduces both the number of blocks required and the delay in the signal path, achieving both increased capacity and speed. The versatility of the CLB function generators significantly improves system speed. In addition, the design-software tools can deal with each function generator independently. This flexibility improves cell usage. <sup>1.</sup> When three separate functions are generated, one of the function outputs must be captured in a flip-flop internal to the CLB. Only two unregistered function generator outputs are available from the CLB. # Product Obsolete or Under Obsolescence XC4000E and XC4000X Series Field Programmable Gate Arrays Supported CLB memory configurations and timing modes for single- and dual-port modes are shown in Table 3. XC4000 Series devices are the first programmable logic devices with edge-triggered (synchronous) and dual-port RAM accessible to the user. Edge-triggered RAM simplifies system timing. Dual-port RAM doubles the effective throughput of FIFO applications. These features can be individually programmed in any XC4000 Series CLB. #### Advantages of On-Chip and Edge-Triggered RAM The on-chip RAM is extremely fast. The read access time is the same as the logic delay. The write access time is slightly slower. Both access times are much faster than any off-chip solution, because they avoid I/O delays. Edge-triggered RAM, also called synchronous RAM, is a feature never before available in a Field Programmable Gate Array. The simplicity of designing with edge-triggered RAM, and the markedly higher achievable performance, add up to a significant improvement over existing devices with on-chip RAM. Three application notes are available from Xilinx that discuss edge-triggered RAM: "XC4000E Edge-Triggered and Dual-Port RAM Capability," "Implementing FIFOs in XC4000E RAM," and "Synchronous and Asynchronous FIFO Designs." All three application notes apply to both XC4000E and XC4000X RAM. **Table 3: Supported RAM Modes** | | 16 | 16 | 32 | Edge- | Level- | |-------------|----|----|----|-----------|-----------| | | х | х | x | Triggered | Sensitive | | | 1 | 2 | 1 | Timing | Timing | | Single-Port | V | 1 | 1 | 1 | <b>V</b> | | Dual-Port | 1 | | | V | | #### **RAM Configuration Options** The function generators in any CLB can be configured as RAM arrays in the following sizes: - Two 16x1 RAMs: two data inputs and two data outputs with identical or, if preferred, different addressing for each RAM - One 32x1 RAM: one data input and one data output. One F or G function generator can be configured as a 16x1 RAM while the other function generators are used to implement any function of up to 5 inputs. Additionally, the XC4000 Series RAM may have either of two timing modes: - Edge-Triggered (Synchronous): data written by the designated edge of the CLB clock. WE acts as a true clock enable. - Level-Sensitive (Asynchronous): an external WE signal acts as the write strobe. The selected timing mode applies to both function generators within a CLB when both are configured as RAM. The number of read ports is also programmable: - Single Port: each function generator has a common read and write port - Dual Port: both function generators are configured together as a single 16x1 dual-port RAM with one write port and two read ports. Simultaneous read and write operations to the same or different addresses are supported. RAM configuration options are selected by placing the appropriate library symbol. ## **Choosing a RAM Configuration Mode** The appropriate choice of RAM mode for a given design should be based on timing and resource requirements, desired functionality, and the simplicity of the design process. Recommended usage is shown in Table 4. The difference between level-sensitive, edge-triggered, and dual-port RAM is only in the write operation. Read operation and timing is identical for all modes of operation. **Table 4: RAM Mode Selection** | | Level-Sens itive | Edge-Trigg<br>ered | Dual-Port<br>Edge-Trigg<br>ered | |----------------------------|------------------|--------------------|---------------------------------| | Use for New Designs? | No | Yes | Yes | | Size (16x1,<br>Registered) | 1/2 CLB | 1/2 CLB | 1 CLB | | Simultaneous<br>Read/Write | No | No | Yes | | Relative<br>Performance | Х | 2X | 2X (4X<br>effective) | #### **RAM Inputs and Outputs** The F1-F4 and G1-G4 inputs to the function generators act as address lines, selecting a particular memory cell in each look-up table. The functionality of the CLB control signals changes when the function generators are configured as RAM. The DIN/H2, H1, and SR/H0 lines become the two data inputs (D0, D1) and the Write Enable (WE) input for the 16x2 memory. When the 32x1 configuration is selected, D1 acts as the fifth address bit and D0 is the data input. The contents of the memory cell(s) being addressed are available at the F' and G' function-generator outputs. They can exit the CLB through its X and Y outputs, or can be captured in the CLB flip-flop(s). Configuring the CLB function generators as Read/Write memory does not affect the functionality of the other por- Figure 4: 16x2 (or 16x1) Edge-Triggered Single-Port RAM Figure 5: 32x1 Edge-Triggered Single-Port RAM (F and G addresses are identical) 6-14 May 14, 1999 (Version 1.6) #### **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 27: Detail of Programmable Interconnect Associated with XC4000 Series CLB 6-30 May 14, 1999 (Version 1.6) Figure 33: Detail of Programmable Interconnect Associated with XC4000 Series IOB (Left Edge) # Product Obsolete or Under Obsolescence XC4000E and XC4000X Series Field Programmable Gate Arrays IOB inputs and outputs interface with the octal lines via the single-length interconnect lines. Single-length lines are also used for communication between the octals and double-length lines, quads, and longlines within the CLB array. Segmentation into buffered octals was found to be optimal for distributing signals over long distances around the device. #### **Global Nets and Buffers** Both the XC4000E and the XC4000X have dedicated global networks. These networks are designed to distribute clocks and other high fanout control signals throughout the devices with minimal skew. The global buffers are described in detail in the following sections. The text descriptions and diagrams are summarized in Table 15. The table shows which CLB and IOB clock pins can be sourced by which global buffers. In both XC4000E and XC4000X devices, placement of a library symbol called BUFG results in the software choosing the appropriate clock buffer, based on the timing requirements of the design. The detailed information in these sections is included only for reference. #### Global Nets and Buffers (XC4000E only) Four vertical longlines in each CLB column are driven exclusively by special global buffers. These longlines are in addition to the vertical longlines used for standard interconnect. The four global lines can be driven by either of two types of global buffers. The clock pins of every CLB and IOB can also be sourced from local interconnect. Two different types of clock buffers are available in the XC4000E: - Primary Global Buffers (BUFGP) - Secondary Global Buffers (BUFGS) Four Primary Global buffers offer the shortest delay and negligible skew. Four Secondary Global buffers have slightly longer delay and slightly more skew due to potentially heavier loading, but offer greater flexibility when used to drive non-clock CLB inputs. The Primary Global buffers must be driven by the semi-dedicated pads. The Secondary Global buffers can be sourced by either semi-dedicated pads or internal nets. Each CLB column has four dedicated vertical Global lines. Each of these lines can be accessed by one particular Primary Global buffer, or by any of the Secondary Global buffers, as shown in Figure 34. Each corner of the device has one Primary buffer and one Secondary buffer. IOBs along the left and right edges have four vertical global longlines. Top and bottom IOBs can be clocked from the global lines in the adjacent CLB column. A global buffer should be specified for all timing-sensitive global signal distribution. To use a global buffer, place a BUFGP (primary buffer), BUFGS (secondary buffer), or BUFG (either primary or secondary buffer) element in a schematic or in HDL code. If desired, attach a LOC attribute or property to direct placement to the designated location. For example, attach a LOC=L attribute or property to a BUFGS symbol to direct that a buffer be placed in one of the two Secondary Global buffers on the left edge of the device, or a LOC=BL to indicate the Secondary Global buffer on the bottom edge of the device, on the left. **Table 15: Clock Pin Access** | | XC4 | 000E | | XC4000X | | | | | | |----------------------------------------------------------------|-------|-------|--------|----------------|----------------|-------------------|--|--|--| | | BUFGP | BUFGS | BUFGLS | L & R<br>BUFGE | T & B<br>BUFGE | Inter-<br>connect | | | | | All CLBs in Quadrant | √ | √ | V | V | V | V | | | | | All CLBs in Device | V | √ | V | | | V | | | | | IOBs on Adjacent Vertical<br>Half Edge | √ | V | 1 | V | √ | V | | | | | IOBs on Adjacent Vertical<br>Full Edge | V | V | V | V | | V | | | | | IOBs on Adjacent Horizontal<br>Half Edge (Direct) | | | | V | | V | | | | | IOBs on Adjacent Horizontal<br>Half Edge (through CLB globals) | V | V | V | V | V | V | | | | | IOBs on Adjacent Horizontal<br>Full Edge (through CLB globals) | V | V | V | | | V | | | | L = Left, R = Right, T = Top, B = Bottom Figure 36: Any BUFGLS (GCK1 - GCK8) Can Drive Any or All Clock Inputs on the Device ## **Global Early Buffers** Each corner of the XC4000X device has two Global Early buffers. The primary purpose of the Global Early buffers is to provide an earlier clock access than the potentially heavily-loaded Global Low-Skew buffers. A clock source applied to both buffers will result in the Global Early clock edge occurring several nanoseconds earlier than the Global Low-Skew buffer clock edge, due to the lighter loading. Global Early buffers also facilitate the fast capture of device inputs, using the Fast Capture latches described in "IOB Input Signals" on page 20. For Fast Capture, take a single clock signal, and route it through both a Global Early buffer and a Global Low-Skew buffer. (The two buffers share an input pad.) Use the Global Early buffer to clock the Fast Capture latch, and the Global Low-Skew buffer to clock the normal input flip-flop or latch, as shown in Figure 17 on page 23. The Global Early buffers can also be used to provide a fast Clock-to-Out on device output pins. However, an early clock in the output flip-flop IOB must be taken into consideration when calculating the internal clock speed for the design. The Global Early buffers at the left and right edges of the chip have slightly different capabilities than the ones at the top and bottom. Refer to Figure 37, Figure 38, and Figure 35 on page 36 while reading the following explanation. Each Global Early buffer can access the eight vertical Global lines for all CLBs in the quadrant. Therefore, only one-fourth of the CLB clock pins can be accessed. This restriction is in large part responsible for the faster speed of the buffers, relative to the Global Low-Skew buffers. Figure 37: Left and Right BUFGEs Can Drive Any or All Clock Inputs in Same Quadrant or Edge (GCK1 is shown. GCK2, GCK5 and GCK6 are similar.) The left-side Global Early buffers can each drive two of the four vertical lines accessing the IOBs on the entire left edge of the device. The right-side Global Early buffers can each drive two of the eight vertical lines accessing the IOBs on the entire right edge of the device. (See Figure 37.) Each left and right Global Early buffer can also drive half of the IOBs along either the top or bottom edge of the device, using a dedicated line that can only be accessed through the Global Early buffers. The top and bottom Global Early buffers can drive half of the IOBs along either the left or right edge of the device, as shown in Figure 38. They can only access the top and bottom IOBs via the CLB global lines. Figure 38: Top and Bottom BUFGEs Can Drive Any or All Clock Inputs in Same Quadrant (GCK8 is shown. GCK3, GCK4 and GCK7 are similar.) 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 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 # Product Obsolete or Under Obsolescence XC4000E and XC4000X Series Field Programmable Gate Arrays #### Start-up from a User Clock (STARTUP.CLK) When, instead of CCLK, a user-supplied start-up clock is selected, Q1 is used to bridge the unknown phase relationship between CCLK and the user clock. This arbitration causes an unavoidable one-cycle uncertainty in the timing of the rest of the start-up sequence. ## DONE Goes High to Signal End of Configuration XC4000 Series devices read the expected length count from the bitstream and store it in an internal register. The length count varies according to the number of devices and the composition of the daisy chain. Each device also counts the number of CCLKs during configuration. Two conditions have to be met in order for the DONE pin to go high: - the chip's internal memory must be full, and - the configuration length count must be met, exactly. This is important because the counter that determines when the length count is met begins with the very first CCLK, not the first one after the preamble. Therefore, if a stray bit is inserted before the preamble, or the data source is not ready at the time of the first CCLK, the internal counter that holds the number of CCLKs will be one ahead of the actual number of data bits read. At the end of configuration, the configuration memory will be full, but the number of bits in the internal counter will not match the expected length count. As a consequence, a Master mode device will continue to send out CCLKs until the internal counter turns over to zero, and then reaches the correct length count a second time. This will take several seconds [2<sup>24</sup> \* CCLK period] — which is sometimes interpreted as the device not configuring at all. If it is not possible to have the data ready at the time of the first CCLK, the problem can be avoided by increasing the number in the length count by the appropriate value. The *XACT User Guide* includes detailed information about manually altering the length count. Note that DONE is an open-drain output and does not go High unless an internal pull-up is activated or an external pull-up is attached. The internal pull-up is activated as the default by the bitstream generation software. ### Release of User I/O After DONE Goes High By default, the user I/O are released one CCLK cycle after the DONE pin goes High. If CCLK is not clocked after DONE goes High, the outputs remain in their initial state — 3-stated, with a 50 k $\Omega$ - 100 k $\Omega$ pull-up. The delay from DONE High to active user I/O is controlled by an option to the bitstream generation software. ## Release of Global Set/Reset After DONE Goes High By default, Global Set/Reset (GSR) is released two CCLK cycles after the DONE pin goes High. If CCLK is not clocked twice after DONE goes High, all flip-flops are held in their initial set or reset state. The delay from DONE High to GSR inactive is controlled by an option to the bitstream generation software. ### Configuration Complete After DONE Goes High Three full CCLK cycles are required after the DONE pin goes High, as shown in Figure 47 on page 53. If CCLK is not clocked three times after DONE goes High, readback cannot be initiated and most boundary scan instructions cannot be used. # **Configuration Through the Boundary Scan Pins** XC4000 Series devices can be configured through the boundary scan pins. The basic procedure is as follows: - Power up the FPGA with INIT held Low (or drive the PROGRAM pin Low for more than 300 ns followed by a High while holding INIT Low). Holding INIT Low allows enough time to issue the CONFIG command to the FPGA. The pin can be used as I/O after configuration if a resistor is used to hold INIT Low. - Issue the CONFIG command to the TMS input - Wait for INIT to go High - Sequence the boundary scan Test Access Port to the SHIFT-DR state - Toggle TCK to clock data into TDI pin. The user must account for all TCK clock cycles after INIT goes High, as all of these cycles affect the Length Count compare. For more detailed information, refer to the Xilinx application note XAPP017, "Boundary Scan in XC4000 Devices." This application note also applies to XC4000E and XC4000X devices. Figure 49: Readback Schematic Example ## **Readback Options** Readback options are: Read Capture, Read Abort, and Clock Select. They are set with the bitstream generation software. ### Read Capture When the Read Capture option is selected, the readback data stream includes sampled values of CLB and IOB signals. The rising edge of RDBK.TRIG latches the inverted values of the four CLB outputs, the IOB output flip-flops and the input signals I1 and I2. Note that while the bits describing configuration (interconnect, function generators, and RAM content) are *not* inverted, the CLB and IOB output signals *are* inverted. When the Read Capture option is not selected, the values of the capture bits reflect the configuration data originally written to those memory locations. If the RAM capability of the CLBs is used, RAM data are available in readback, since they directly overwrite the F and G function-table configuration of the CLB. RDBK.TRIG is located in the lower-left corner of the device, as shown in Figure 50. #### Read Abort When the Read Abort option is selected, a High-to-Low transition on RDBK.TRIG terminates the readback operation and prepares the logic to accept another trigger. After an aborted readback, additional clocks (up to one readback clock per configuration frame) may be required to re-initialize the control logic. The status of readback is indicated by the output control net RDBK.RIP. RDBK.RIP is High whenever a readback is in progress. #### Clock Select CCLK is the default clock. However, the user can insert another clock on RDBK.CLK. Readback control and data are clocked on rising edges of RDBK.CLK. If readback must be inhibited for security reasons, the readback control nets are simply not connected. RDBK.CLK is located in the lower right chip corner, as shown in Figure 50. Figure 50: READBACK Symbol in Graphical Editor ## Violating the Maximum High and Low Time Specification for the Readback Clock The readback clock has a maximum High and Low time specification. In some cases, this specification cannot be met. For example, if a processor is controlling readback, an interrupt may force it to stop in the middle of a readback. This necessitates stopping the clock, and thus violating the specification. The specification is mandatory only on clocking data at the end of a frame prior to the next start bit. The transfer mechanism will load the data to a shift register during the last six clock cycles of the frame, prior to the start bit of the following frame. This loading process is dynamic, and is the source of the maximum High and Low time requirements. Therefore, the specification only applies to the six clock cycles prior to and including any start bit, including the clocks before the first start bit in the readback data stream. At other times, the frame data is already in the register and the register is not dynamic. Thus, it can be shifted out just like a regular shift register. The user must precisely calculate the location of the readback data relative to the frame. The system must keep track of the position within a data frame, and disable interrupts before frame boundaries. Frame lengths and data formats are listed in Table 19, Table 20 and Table 21. #### Readback with the XChecker Cable The XChecker Universal Download/Readback Cable and Logic Probe uses the readback feature for bitstream verification. It can also display selected internal signals on the PC or workstation screen, functioning as a low-cost in-circuit emulator. **Table 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 | | | 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 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 ## 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 ## **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 | | PINS | 84 | 100 | 100 | 144 | 144 | 160 | 160 | 176 | 176 | 208 | 208 | 240 | 240 | 256 | 299 | 304 | 352 | 411 | 432 | 475 | 559 | 560 | |-------------|------------|----------------|----------------|----------------|----------------|--------------------|-------------------|----------------|----------------|--------------------|-------------------|----------------|-------------------|----------------|---------------|---------------|-------------------|---------------|---------------|---------------|---------------|---------------|---------------| | | | | | | | | | | | | | | | | | | | | | | | | | | Т | YPE | 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 | | CC | ODE | 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 | СІ | СІ | СІ | CI | | | СІ | | | | СІ | | | | | | | | | | | | | XC4005XL | -2 | CI | С | CI | CI | | | CI | | | | CI | | | | | | | | | | | | | | -1<br>-09C | C I | CI | C I | C I | | | C I | | | | C I | | | | | | | | | | | | | | -3 | CI | CI | | CI | | | CI | СІ | | | CI | | | СІ | | | | | | | | | | XC4010XL | -2 | СІ | СІ | | СІ | | | СІ | CI | | | СІ | | | CI | | | | | | | | | | AC40 IUAL | -1 | СІ | СІ | | СІ | | | СІ | СІ | | | СІ | | | CI | | | | | | | | | | | -09C | С | С | | С | | | С | С | | | С | | | С | | | | | | | | | | | -3<br>-2 | | | | | CI | | CI | | CI | | CI<br>CI | | CI | CI | | | | | | | | | | XC4013XL | -1 | | | | | CI | | CI | | CI | | CI | | CI | CI | | | | | | | | | | AC4013AL | -09C | | | | | C | | C | | C | | C | | C | C | | | | | | | | | | | -08C | | | | | С | | С | | С | | С | | С | С | | | | | | | | | | | -3 | | | | | СІ | | CI | | CI | | СІ | | CI | СІ | | | | | | | | | | XC4020XL | -2 | | | | | СІ | | СІ | | СІ | | СІ | | СІ | СІ | | | | | | | | | | AC4020AL | -1 | | | | | СІ | | СІ | | СI | | СІ | | 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 | | | | | | | | -3 | | | | | | CI | | | | CI | | CI | | | | CI | CI | СІ | CI | | | | | | -2 | | | | | | СІ | | | | СІ | | С | | | | CI | CI | CI | СІ | | | | | XC4036XL | -1 | | | | | | СІ | | | | СІ | | СІ | | | | СІ | СІ | СІ | СІ | | | | | | -09C | | | | | | O | | | | С | | С | | | | С | С | С | С | | | | | | -08C | | | | | | С | | | | С | | С | | | | С | С | С | С | | | | | | -3 | | | | | | CI | | | | CI | | CI | | | | CI | CI | CI | CI | | | | | XC4044XL | -2<br>-1 | | | | | | CI | | | | CI | | CI | | | | CI | CI | CI | CI | | | | | - | -09C | | | | | | С | | | | С | | С | | | | С | C | С | С | | | | | | -3 | | | | | | | | | | | | CI | | | | CI | <u> </u> | CI | CI | | | СІ | | VC4050VI | -2 | | | | | | | | | | | | CI | | | | CI | | CI | CI | | | CI | | XC4052XL | -1 | | | | | | | | | | | | СІ | | | | СІ | | СІ | СІ | | | СІ | | | -09C | | | | | | | | | | | | С | | | | С | | С | С | | | С | | | -3 | | | | | | | | | | | | CI | | | | CI | | | CI | CI | | CI | | | -2 | | | | | | | | | | | | CI | | | | CI | | | CI | CI | | CI | | | -1<br>-09C | | | | | | | | | | | | C1 | | | | CI | | | C I | C I | | CI<br>C | | | -09C | | | | | | | | | | | | С | | - | | С | | | С | С | | С | | | -3 | | | | | | | | | | | | | | | | | | | CI | | CI | CI | | \\ <b>0</b> | -2 | | | | | | | | | | | | | | | | | | | CI | | CI | CI | | XC4085XL | -1 | | | | | | | | | | | | | | | | | | | CI | | CI | CI | | | -09C | | | | | | | | | | | | | | | | | | | С | | С | С | | 1/29/99 | 550 | | | | | | | | | | | | | | | | | | | J | | | | 1/29/99 $C = Commercial \ T_J = 0^{\circ} \ to \ +85^{\circ}C$ I= Industrial $T_J = -40^{\circ}C$ to $+100^{\circ}C$ ## XC4000 Series Electrical Characteristics and Device-Specific Pinout Table For the latest Electrical Characteristics and package/pinout information for each XC4000 Family, see the Xilinx web site at <a href="http://www.xilinx.com/xlnx/xweb/xil\_publications\_index.jsp">http://www.xilinx.com/xlnx/xweb/xil\_publications\_index.jsp</a> ## **Ordering Information** X9020 ## **Revision Control** | Version | Description | |---------------|---------------------------------------------------------------------------------------------------------| | 3/30/98 (1.5) | Updated XC4000XL timing and added XC4002XL | | 1/29/99 (1.5) | Updated pin diagrams | | 5/14/99 (1.6) | Replaced Electrical Specification and pinout pages for E, EX, and XL families with separate updates and | | | added URL link for electrical specifications/pinouts for Web users |