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 | 1296 | | Number of Logic Elements/Cells | 3078 | | Total RAM Bits | 41472 | | Number of I/O | 193 | | Number of Gates | 36000 | | Voltage - Supply | 3V ~ 3.6V | | Mounting Type | Surface Mount | | Operating Temperature | -40°C ~ 100°C (TJ) | | Package / Case | 240-BFQFP Exposed Pad | | Supplier Device Package | 240-PQFP (32x32) | | Purchase URL | https://www.e-xfl.com/product-detail/xilinx/xc4036xl-2hq240i | Email: info@E-XFL.COM Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong # **Detailed Functional Description** XC4000 Series devices achieve high speed through advanced semiconductor technology and improved architecture. The XC4000E and XC4000X support system clock rates of up to 80 MHz and internal performance in excess of 150 MHz. Compared to older Xilinx FPGA families, XC4000 Series devices are more powerful. They offer on-chip edge-triggered and dual-port RAM, clock enables on I/O flip-flops, and wide-input decoders. They are more versatile in many applications, especially those involving RAM. Design cycles are faster due to a combination of increased routing resources and more sophisticated software. # **Basic Building Blocks** Xilinx user-programmable gate arrays include two major configurable elements: configurable logic blocks (CLBs) and input/output blocks (IOBs). - CLBs provide the functional elements for constructing the user's logic. - IOBs provide the interface between the package pins and internal signal lines. Three other types of circuits are also available: - 3-State buffers (TBUFs) driving horizontal longlines are associated with each CLB. - Wide edge decoders are available around the periphery of each device. - An on-chip oscillator is provided. Programmable interconnect resources provide routing paths to connect the inputs and outputs of these configurable elements to the appropriate networks. The functionality of each circuit block is customized during configuration by programming internal static memory cells. The values stored in these memory cells determine the logic functions and interconnections implemented in the FPGA. Each of these available circuits is described in this section. # **Configurable Logic Blocks (CLBs)** Configurable Logic Blocks implement most of the logic in an FPGA. The principal CLB elements are shown in Figure 1. Two 4-input function generators (F and G) offer unrestricted versatility. Most combinatorial logic functions need four or fewer inputs. However, a third function generator (H) is provided. The H function generator has three inputs. Either zero, one, or two of these inputs can be the outputs of F and G; the other input(s) are from outside the CLB. The CLB can, therefore, implement certain functions of up to nine variables, like parity check or expandable-identity comparison of two sets of four inputs. Each CLB contains two storage elements that can be used to store the function generator outputs. However, the storage elements and function generators can also be used independently. These storage elements can be configured as flip-flops in both XC4000E and XC4000X devices; in the XC4000X they can optionally be configured as latches. DIN can be used as a direct input to either of the two storage elements. H1 can drive the other through the H function generator. Function generator outputs can also drive two outputs independent of the storage element outputs. This versatility increases logic capacity and simplifies routing. Thirteen CLB inputs and four CLB outputs provide access to the function generators and storage elements. These inputs and outputs connect to the programmable interconnect resources outside the block. #### **Function Generators** Four independent inputs are provided to each of two function generators (F1 - F4 and G1 - G4). These function generators, with outputs labeled F' and G', are each capable of implementing any arbitrarily defined Boolean function of four inputs. The function generators are implemented as memory look-up tables. The propagation delay is therefore independent of the function implemented. A third function generator, labeled H', can implement any Boolean function of its three inputs. Two of these inputs can optionally be the F' and G' functional generator outputs. Alternatively, one or both of these inputs can come from outside the CLB (H2, H0). The third input must come from outside the block (H1). Signals from the function generators can exit the CLB on two outputs. F' or H' can be connected to the X output. G' or H' can be connected to the Y output. A CLB can be used to implement any of the following functions: - any function of up to four variables, plus any second function of up to four unrelated variables, plus any third function of up to three unrelated variables<sup>1</sup> - any single function of five variables - any function of four variables together with some functions of six variables - · some functions of up to nine variables. Implementing wide functions in a single block reduces both the number of blocks required and the delay in the signal path, achieving both increased capacity and speed. The versatility of the CLB function generators significantly improves system speed. In addition, the design-software tools can deal with each function generator independently. This flexibility improves cell usage. <sup>1.</sup> When three separate functions are generated, one of the function outputs must be captured in a flip-flop internal to the CLB. Only two unregistered function generator outputs are available from the CLB. tions of the CLB, with the exception of the redefinition of the control signals. In 16x2 and 16x1 modes, the H' function generator can be used to implement Boolean functions of F', G', and D1, and the D flip-flops can latch the F', G', H', or D0 signals. #### Single-Port Edge-Triggered Mode Edge-triggered (synchronous) RAM simplifies timing requirements. XC4000 Series edge-triggered RAM timing operates like writing to a data register. Data and address are presented. The register is enabled for writing by a logic High on the write enable input, WE. Then a rising or falling clock edge loads the data into the register, as shown in Figure 3. Figure 3: Edge-Triggered RAM Write Timing Complex timing relationships between address, data, and write enable signals are not required, and the external write enable pulse becomes a simple clock enable. The active edge of WCLK latches the address, input data, and WE sig- nals. An internal write pulse is generated that performs the write. See Figure 4 and Figure 5 for block diagrams of a CLB configured as 16x2 and 32x1 edge-triggered, single-port RAM. The relationships between CLB pins and RAM inputs and outputs for single-port, edge-triggered mode are shown in Table 5. The Write Clock input (WCLK) can be configured as active on either the rising edge (default) or the falling edge. It uses the same CLB pin (K) used to clock the CLB flip-flops, but it can be independently inverted. Consequently, the RAM output can optionally be registered within the same CLB either by the same clock edge as the RAM, or by the opposite edge of this clock. The sense of WCLK applies to both function generators in the CLB when both are configured as RAM. The WE pin is active-High and is not invertible within the CLB. **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. Table 5: Single-Port Edge-Triggered RAM Signals | RAM Signal | CLB Pin | Function | |------------|------------------|-----------------| | D | D0 or D1 (16x2, | Data In | | | 16x1), D0 (32x1) | | | A[3:0] | F1-F4 or G1-G4 | Address | | A[4] | D1 (32x1) | Address | | WE | WE | Write Enable | | WCLK | K | Clock | | SPO | F' or G' | Single Port Out | | (Data Out) | | (Data Out) | 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 14: Detail of XC4000E Dedicated Carry Logic # Input/Output Blocks (IOBs) User-configurable input/output blocks (IOBs) provide the interface between external package pins and the internal logic. Each IOB controls one package pin and can be configured for input, output, or bidirectional signals. Figure 15 shows a simplified block diagram of the XC4000E IOB. A more complete diagram which includes the boundary scan logic of the XC4000E IOB can be found in Figure 40 on page 43, in the "Boundary Scan" section. The XC4000X IOB contains some special features not included in the XC4000E IOB. These features are highlighted in a simplified block diagram found in Figure 16, and discussed throughout this section. When XC4000X special features are discussed, they are clearly identified in the text. Any feature not so identified is present in both XC4000E and XC4000X devices. #### IOB Input Signals Two paths, labeled I1 and I2 in Figure 15 and Figure 16, bring input signals into the array. Inputs also connect to an input register that can be programmed as either an edge-triggered flip-flop or a level-sensitive latch. The choice is made by placing the appropriate library symbol. For example, IFD is the basic input flip-flop (rising edge triggered), and ILD is the basic input latch (transparent-High). Variations with inverted clocks are available, and some combinations of latches and flip-flops can be implemented in a single IOB, as described in the *XACT Libraries Guide*. The XC4000E inputs can be globally configured for either TTL (1.2V) or 5.0 volt CMOS thresholds, using an option in the bitstream generation software. There is a slight input hysteresis of about 300mV. The XC4000E output levels are also configurable; the two global adjustments of input threshold and output level are independent. Inputs on the XC4000XL are TTL compatible and 3.3V CMOS compatible. Outputs on the XC4000XL are pulled to the 3.3V positive supply. The inputs of XC4000 Series 5-Volt devices can be driven by the outputs of any 3.3-Volt device, if the 5-Volt inputs are in TTL mode. Supported sources for XC4000 Series device inputs are shown in Table 8. Table 8: Supported Sources for XC4000 Series Device Inputs | | | 0E/EX<br>Inputs | XC4000XL<br>Series Inputs | |-------------------------------------------------------------------------|-------------|-----------------|---------------------------| | Source | 5 V,<br>TTL | 5 V,<br>CMOS | 3.3 V<br>CMOS | | Any device, Vcc = 3.3 V,<br>CMOS outputs | V | Unreli | √ | | XC4000 Series, Vcc = 5 V, TTL outputs | V | -able<br>Data | √ | | Any device, $Vcc = 5 \text{ V}$ , TTL outputs $(Voh \le 3.7 \text{ V})$ | √ | Data | √ | | Any device, Vcc = 5 V,<br>CMOS outputs | V | √ | √ | #### XC4000XL 5-Volt Tolerant I/Os The I/Os on the XC4000XL are fully 5-volt tolerant even though the $V_{\rm CC}$ is 3.3 volts. This allows 5 V signals to directly connect to the XC4000XL inputs without damage, as shown in Table 8. In addition, the 3.3 volt $V_{\rm CC}$ can be applied before or after 5 volt signals are applied to the I/Os. This makes the XC4000XL immune to power supply sequencing problems. #### **Registered Inputs** The I1 and I2 signals that exit the block can each carry either the direct or registered input signal. The input and output storage elements in each IOB have a common clock enable input, which, through configuration, can be activated individually for the input or output flip-flop, or both. This clock enable operates exactly like the EC pin on the XC4000 Series CLB. It cannot be inverted within the IOB. The storage element behavior is shown in Table 9. Table 9: Input Register Functionality (active rising edge is shown) | Mode | Clock | Clock<br>Enable | D | Q | |-----------------|-------|-----------------|---|----| | Power-Up or GSR | X | Х | Х | SR | | Flip-Flop | | 1* | D | D | | | 0 | Х | Х | Q | | Latch | 1 | 1* | Х | Q | | | 0 | 1* | D | D | | Both | Χ | 0 | Х | Q | Legend: X Don't care Rising edge SR Set or Reset value. Reset is default. 0\* Input is Low or unconnected (default value) 1\* Input is High or unconnected (default value) #### **Optional Delay Guarantees Zero Hold Time** The data input to the register can optionally be delayed by several nanoseconds. With the delay enabled, the setup time of the input flip-flop is increased so that normal clock routing does not result in a positive hold-time requirement. A positive hold time requirement can lead to unreliable, temperature- or processing-dependent operation. The input flip-flop setup time is defined between the data measured at the device I/O pin and the clock input at the IOB (not at the clock pin). Any routing delay from the device clock pin to the clock input of the IOB must, therefore, be subtracted from this setup time to arrive at the real setup time requirement relative to the device pins. A short specified setup time might, therefore, result in a negative setup time at the device pins, i.e., a positive hold-time requirement. When a delay is inserted on the data line, more clock delay can be tolerated without causing a positive hold-time requirement. Sufficient delay eliminates the possibility of a data hold-time requirement at the external pin. The maximum delay is therefore inserted as the default. The XC4000E IOB has a one-tap delay element: either the delay is inserted (default), or it is not. The delay guarantees a zero hold time with respect to clocks routed through any of the XC4000E global clock buffers. (See "Global Nets and Buffers (XC4000E only)" on page 35 for a description of the global clock buffers in the XC4000E.) For a shorter input register setup time, with non-zero hold, attach a NODELAY attribute or property to the flip-flop. The XC4000X IOB has a two-tap delay element, with choices of a full delay, a partial delay, or no delay. The attributes or properties used to select the desired delay are shown in Table 10. The choices are no added attribute, MEDDELAY, and NODELAY. The default setting, with no added attribute, ensures no hold time with respect to any of the XC4000X clock buffers, including the Global Low-Skew buffers. MEDDELAY ensures no hold time with respect to the Global Early buffers. Inputs with NODELAY may have a positive hold time with respect to all clock buffers. For a description of each of these buffers, see "Global Nets and Buffers (XC4000X only)" on page 37. Table 10: XC4000X IOB Input Delay Element | Value | When to Use | |------------------|----------------------------------------| | full delay | Zero Hold with respect to Global | | (default, no | Low-Skew Buffer, Global Early Buffer | | attribute added) | | | MEDDELAY | Zero Hold with respect to Global Early | | | Buffer | | NODELAY | Short Setup, positive Hold time | #### Additional Input Latch for Fast Capture (XC4000X only) The XC4000X IOB has an additional optional latch on the input. This latch, as shown in Figure 16, is clocked by the output clock — the clock used for the output flip-flop — rather than the input clock. Therefore, two different clocks can be used to clock the two input storage elements. This additional latch allows the very fast capture of input data, which is then synchronized to the internal clock by the IOB flip-flop or latch. To use this Fast Capture technique, drive the output clock pin (the Fast Capture latching signal) from the output of one of the Global Early buffers supplied in the XC4000X. The second storage element should be clocked by a Global Low-Skew buffer, to synchronize the incoming data to the internal logic. (See Figure 17.) These special buffers are described in "Global Nets and Buffers (XC4000X only)" on page 37. The Fast Capture latch (FCL) is designed primarily for use with a Global Early buffer. For Fast Capture, a single clock signal is routed through both a Global Early buffer and a Global Low-Skew buffer. (The two buffers share an input pad.) The Fast Capture latch is clocked by the Global Early buffer, and the standard IOB flip-flop or latch is clocked by the Global Low-Skew buffer. This mode is the safest way to use the Fast Capture latch, because the clock buffers on both storage elements are driven by the same pad. There is no external skew between clock pads to create potential problems. To place the Fast Capture latch in a design, use one of the special library symbols, ILFFX or ILFLX. ILFFX is a transparent-Low Fast Capture latch followed by an active-High input flip-flop. ILFLX is a transparent-Low Fast Capture latch followed by a transparent-High input latch. Any of the clock inputs can be inverted before driving the library element, and the inverter is absorbed into the IOB. If a single BUFG output is used to drive both clock inputs, the software automatically runs the clock through both a Global Low-Skew buffer and a Global Early buffer, and clocks the Fast Capture latch appropriately. Figure 16 on page 21 also shows a two-tap delay on the input. By default, if the Fast Capture latch is used, the Xilinx software assumes a Global Early buffer is driving the clock, and selects MEDDELAY to ensure a zero hold time. Select Figure 17: Examples Using XC4000X FCL the desired delay based on the discussion in the previous subsection. #### IOB Output Signals Output signals can be optionally inverted within the IOB, and can pass directly to the pad or be stored in an edge-triggered flip-flop. The functionality of this flip-flop is shown in Table 11. An active-High 3-state signal can be used to place the output buffer in a high-impedance state, implementing 3-state outputs or bidirectional I/O. Under configuration control, the output (OUT) and output 3-state (T) signals can be inverted. The polarity of these signals is independently configured for each IOB. The 4-mA maximum output current specification of many FPGAs often forces the user to add external buffers, which are especially cumbersome on bidirectional I/O lines. The XC4000E and XC4000EX/XL devices solve many of these problems by providing a guaranteed output sink current of 12 mA. Two adjacent outputs can be interconnected externally to sink up to 24 mA. The XC4000E and XC4000EX/XL FPGAs can thus directly drive buses on a printed circuit board. By default, the output pull-up structure is configured as a TTL-like totem-pole. The High driver is an n-channel pull-up transistor, pulling to a voltage one transistor threshold below Vcc. Alternatively, the outputs can be globally configured as CMOS drivers, with p-channel pull-up transistors pulling to Vcc. This option, applied using the bitstream generation software, applies to all outputs on the device. It is not individually programmable. In the XC4000XL, all outputs are pulled to the positive supply rail. Table 11: Output Flip-Flop Functionality (active rising edge is shown) | Mode | Clock | Clock<br>Enable | Т | D | Q | |-----------------|-------|-----------------|----|---|----| | Power-Up or GSR | Х | Х | 0* | Х | SR | | | Х | 0 | 0* | Х | Q | | Flip-Flop | /_ | 1* | 0* | D | D | | | Х | Х | 1 | Х | Z | | | 0 | Х | 0* | Х | Q | Legend: X Don't care Rising edge SR Set or Reset value. Reset is default. 0\* Input is Low or unconnected (default value) 1\* Input is High or unconnected (default value) 7 3-state # Product Obsolete or Under Obsolescence XC4000E and XC4000X Series Field Programmable Gate Arrays or clear on reset and after configuration. Other than the global GSR net, no user-controlled set/reset signal is available to the I/O flip-flops. The choice of set or clear applies to both the initial state of the flip-flop and the response to the Global Set/Reset pulse. See "Global Set/Reset" on page 11 for a description of how to use GSR. #### **JTAG Support** Embedded logic attached to the IOBs contains test structures compatible with IEEE Standard 1149.1 for boundary scan testing, permitting easy chip and board-level testing. More information is provided in "Boundary Scan" on page 42. #### **Three-State Buffers** A pair of 3-state buffers is associated with each CLB in the array. (See Figure 27 on page 30.) These 3-state buffers can be used to drive signals onto the nearest horizontal longlines above and below the CLB. They can therefore be used to implement multiplexed or bidirectional buses on the horizontal longlines, saving logic resources. Programmable pull-up resistors attached to these longlines help to implement a wide wired-AND function. The buffer enable is an active-High 3-state (i.e. an active-Low enable), as shown in Table 13. Another 3-state buffer with similar access is located near each I/O block along the right and left edges of the array. (See Figure 33 on page 34.) The horizontal longlines driven by the 3-state buffers have a weak keeper at each end. This circuit prevents undefined floating levels. However, it is overridden by any driver, even a pull-up resistor. Special longlines running along the perimeter of the array can be used to wire-AND signals coming from nearby IOBs or from internal longlines. These longlines form the wide edge decoders discussed in "Wide Edge Decoders" on page 27. ### Three-State Buffer Modes The 3-state buffers can be configured in three modes: - · Standard 3-state buffer - Wired-AND with input on the I pin - Wired OR-AND #### **Standard 3-State Buffer** All three pins are used. Place the library element BUFT. Connect the input to the I pin and the output to the O pin. The T pin is an active-High 3-state (i.e. an active-Low enable). Tie the T pin to Ground to implement a standard buffer. #### Wired-AND with Input on the I Pin The buffer can be used as a Wired-AND. Use the WAND1 library symbol, which is essentially an open-drain buffer. WAND4, WAND8, and WAND16 are also available. See the *XACT Libraries Guide* for further information. The T pin is internally tied to the I pin. Connect the input to the I pin and the output to the O pin. Connect the outputs of all the WAND1s together and attach a PULLUP symbol. #### Wired OR-AND The buffer can be configured as a Wired OR-AND. A High level on either input turns off the output. Use the WOR2AND library symbol, which is essentially an open-drain 2-input OR gate. The two input pins are functionally equivalent. Attach the two inputs to the I0 and I1 pins and tie the output to the O pin. Tie the outputs of all the WOR2ANDs together and attach a PULLUP symbol. ## Three-State Buffer Examples Figure 21 shows how to use the 3-state buffers to implement a wired-AND function. When all the buffer inputs are High, the pull-up resistor(s) provide the High output. Figure 22 shows how to use the 3-state buffers to implement a multiplexer. The selection is accomplished by the buffer 3-state signal. Pay particular attention to the polarity of the T pin when using these buffers in a design. Active-High 3-state (T) is identical to an active-Low output enable, as shown in Table 13. **Table 13: Three-State Buffer Functionality** | IN | Т | OUT | |----|---|-----| | X | 1 | Z | | IN | 0 | IN | Figure 21: Open-Drain Buffers Implement a Wired-AND Function Figure 27: Detail of Programmable Interconnect Associated with XC4000 Series CLB 6-30 May 14, 1999 (Version 1.6) 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) # Product Obsolete or Under Obsolescence XC4000E and XC4000X Series Field Programmable Gate Arrays IOB inputs and outputs interface with the octal lines via the single-length interconnect lines. Single-length lines are also used for communication between the octals and double-length lines, quads, and longlines within the CLB array. Segmentation into buffered octals was found to be optimal for distributing signals over long distances around the device. #### **Global Nets and Buffers** Both the XC4000E and the XC4000X have dedicated global networks. These networks are designed to distribute clocks and other high fanout control signals throughout the devices with minimal skew. The global buffers are described in detail in the following sections. The text descriptions and diagrams are summarized in Table 15. The table shows which CLB and IOB clock pins can be sourced by which global buffers. In both XC4000E and XC4000X devices, placement of a library symbol called BUFG results in the software choosing the appropriate clock buffer, based on the timing requirements of the design. The detailed information in these sections is included only for reference. #### Global Nets and Buffers (XC4000E only) Four vertical longlines in each CLB column are driven exclusively by special global buffers. These longlines are in addition to the vertical longlines used for standard interconnect. The four global lines can be driven by either of two types of global buffers. The clock pins of every CLB and IOB can also be sourced from local interconnect. Two different types of clock buffers are available in the XC4000E: - Primary Global Buffers (BUFGP) - Secondary Global Buffers (BUFGS) Four Primary Global buffers offer the shortest delay and negligible skew. Four Secondary Global buffers have slightly longer delay and slightly more skew due to potentially heavier loading, but offer greater flexibility when used to drive non-clock CLB inputs. The Primary Global buffers must be driven by the semi-dedicated pads. The Secondary Global buffers can be sourced by either semi-dedicated pads or internal nets. Each CLB column has four dedicated vertical Global lines. Each of these lines can be accessed by one particular Primary Global buffer, or by any of the Secondary Global buffers, as shown in Figure 34. Each corner of the device has one Primary buffer and one Secondary buffer. IOBs along the left and right edges have four vertical global longlines. Top and bottom IOBs can be clocked from the global lines in the adjacent CLB column. A global buffer should be specified for all timing-sensitive global signal distribution. To use a global buffer, place a BUFGP (primary buffer), BUFGS (secondary buffer), or BUFG (either primary or secondary buffer) element in a schematic or in HDL code. If desired, attach a LOC attribute or property to direct placement to the designated location. For example, attach a LOC=L attribute or property to a BUFGS symbol to direct that a buffer be placed in one of the two Secondary Global buffers on the left edge of the device, or a LOC=BL to indicate the Secondary Global buffer on the bottom edge of the device, on the left. Table 15: Clock Pin Access | | XC4 | XC4000E XC4000X | | | Local | | |----------------------------------------------------------------|-------|-----------------|--------|----------------|----------------|-------------------| | | BUFGP | BUFGS | BUFGLS | L & R<br>BUFGE | T & B<br>BUFGE | Inter-<br>connect | | All CLBs in Quadrant | √ | √ | V | V | V | V | | All CLBs in Device | V | √ | V | | | V | | IOBs on Adjacent Vertical<br>Half Edge | √ | V | V | V | √ | V | | IOBs on Adjacent Vertical<br>Full Edge | V | V | V | <b>V</b> | | V | | IOBs on Adjacent Horizontal<br>Half Edge (Direct) | | | | <b>V</b> | | V | | IOBs on Adjacent Horizontal<br>Half Edge (through CLB globals) | V | V | V | 1 | V | V | | IOBs on Adjacent Horizontal<br>Full Edge (through CLB globals) | V | V | V | | | V | L = Left, R = Right, T = Top, B = Bottom # **Table 16: Pin Descriptions (Continued)** | | I/O<br>During | I/O<br>After | | |------------------------------------------------------------|-----------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Pin Name | Config. | Config. | Pin Description | | TDI, TCK,<br>TMS | I | I/O<br>or I<br>(JTAG) | If boundary scan is used, these pins are Test Data In, Test Clock, and Test Mode Select inputs respectively. They come directly from the pads, bypassing the IOBs. These pins can also be used as inputs to the CLB logic after configuration is completed. If the BSCAN symbol is not placed in the design, all boundary scan functions are inhibited once configuration is completed, and these pins become user-programmable I/O. The pins can be used automatically or user-constrained. To use them, use "LOC=" or place the library components TDI, TCK, and TMS instead of the usual pad symbols. Input or output buffers must still be used. | | HDC | 0 | I/O | High During Configuration (HDC) is driven High until the I/O go active. It is available as a control output indicating that configuration is not yet completed. After configuration, HDC is a user-programmable I/O pin. | | LDC | 0 | I/O | Low During Configuration (LDC) is driven Low until the I/O go active. It is available as a control output indicating that configuration is not yet completed. After configuration, LDC is a user-programmable I/O pin. | | ĪNĪT | I/O | I/O | Before and during configuration, $\overline{\text{INIT}}$ is a bidirectional signal. A 1 k $\Omega$ - 10 k $\Omega$ external pull-up resistor is recommended. As an active-Low open-drain output, $\overline{\text{INIT}}$ is held Low during the power stabilization and internal clearing of the configuration memory. As an active-Low input, it can be used to hold the FPGA in the internal WAIT state before the start of configuration. Master mode devices stay in a WAIT state an additional 30 to 300 $\mu$ s after $\overline{\text{INIT}}$ has gone High. During configuration, a Low on this output indicates that a configuration data error has occurred. After the I/O go active, $\overline{\text{INIT}}$ is a user-programmable I/O pin. | | PGCK1 -<br>PGCK4<br>(XC4000E<br>only) | Weak<br>Pull-up | I or I/O | Four Primary Global inputs each drive a dedicated internal global net with short delay and minimal skew. If not used to drive a global buffer, any of these pins is a user-programmable I/O. The PGCK1-PGCK4 pins drive the four Primary Global Buffers. Any input pad symbol connected directly to the input of a BUFGP symbol is automatically placed on one of these pins. | | SGCK1 -<br>SGCK4<br>(XC4000E<br>only) | Weak<br>Pull-up | I or I/O | Four Secondary Global inputs each drive a dedicated internal global net with short delay and minimal skew. These internal global nets can also be driven from internal logic. If not used to drive a global net, any of these pins is a user-programmable I/O pin. The SGCK1-SGCK4 pins provide the shortest path to the four Secondary Global Buffers. Any input pad symbol connected directly to the input of a BUFGS symbol is automatically placed on one of these pins. | | GCK1 -<br>GCK8<br>(XC4000X<br>only) | Weak<br>Pull-up | I or I/O | Eight inputs can each drive a Global Low-Skew buffer. In addition, each can drive a Global Early buffer. Each pair of global buffers can also be driven from internal logic, but must share an input signal. If not used to drive a global buffer, any of these pins is a user-programmable I/O. Any input pad symbol connected directly to the input of a BUFGLS or BUFGE symbol is automatically placed on one of these pins. | | FCLK1 -<br>FCLK4<br>(XC4000XLA<br>and<br>XC4000XV<br>only) | Weak<br>Pull-up | I or I/O | Four inputs can each drive a Fast Clock (FCLK) buffer which can deliver a clock signal to any IOB clock input in the octant of the die served by the Fast Clock buffer. Two Fast Clock buffers serve the two IOB octants on the left side of the die and the other two Fast Clock buffers serve the two IOB octants on the right side of the die. On each side of the die, one Fast Clock buffer serves the upper octant and the other serves the lower octant. If not used to drive a Fast Clock buffer, any of these pins is a user-programmable I/O. | Figure 41: XC4000 Series Boundary Scan Logic #### **Instruction Set** The XC4000 Series boundary scan instruction set also includes instructions to configure the device and read back the configuration data. The instruction set is coded as shown in Table 17. ## **Bit Sequence** The bit sequence within each IOB is: In, Out, 3-State. The input-only M0 and M2 mode pins contribute only the In bit to the boundary scan I/O data register, while the output-only M1 pin contributes all three bits. The first two bits in the I/O data register are TDO.T and TDO.O, which can be used for the capture of internal signals. The final bit is BSCANT.UPD, which can be used to drive an internal net. These locations are primarily used by Xilinx for internal testing. From a cavity-up view of the chip (as shown in XDE or Epic), starting in the upper right chip corner, the boundary scan data-register bits are ordered as shown in Figure 42. The device-specific pinout tables for the XC4000 Series include the boundary scan locations for each IOB pin. BSDL (Boundary Scan Description Language) files for XC4000 Series devices are available on the Xilinx FTP site. # **Including Boundary Scan in a Schematic** If boundary scan is only to be used during configuration, no special schematic elements need be included in the schematic or HDL code. In this case, the special boundary scan pins TDI, TMS, TCK and TDO can be used for user functions after configuration. To indicate that boundary scan remain enabled after configuration, place the BSCAN library symbol and connect the TDI, TMS, TCK and TDO pad symbols to the appropriate pins, as shown in Figure 43. Even if the boundary scan symbol is used in a schematic, the input pins TMS, TCK, and TDI can still be used as inputs to be routed to internal logic. Care must be taken not to force the chip into an undesired boundary scan state by inadvertently applying boundary scan input patterns to these pins. The simplest way to prevent this is to keep TMS High, and then apply whatever signal is desired to TDI and TCK. # 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. Figure 48: Start-up Logic ## Readback The user can read back the content of configuration memory and the level of certain internal nodes without interfering with the normal operation of the device. Readback not only reports the downloaded configuration bits, but can also include the present state of the device, represented by the content of all flip-flops and latches in CLBs and IOBs, as well as the content of function generators used as RAMs. Note that in XC4000 Series devices, configuration data is *not* inverted with respect to configuration as it is in XC2000 and XC3000 families. XC4000 Series Readback does not use any dedicated pins, but uses four internal nets (RDBK.TRIG, RDBK.DATA, RDBK.RIP and RDBK.CLK) that can be routed to any IOB. To access the internal Readback signals, place the READ- BACK library symbol and attach the appropriate pad symbols, as shown in Figure 49. After Readback has been initiated by a High level on RDBK.TRIG after configuration, the RDBK.RIP (Read In Progress) output goes High on the next rising edge of RDBK.CLK. Subsequent rising edges of this clock shift out Readback data on the RDBK.DATA net. Readback data does not include the preamble, but starts with five dummy bits (all High) followed by the Start bit (Low) of the first frame. The first two data bits of the first frame are always High. Each frame ends with four error check bits. They are read back as High. The last seven bits of the last frame are also read back as High. An additional Start bit (Low) and an 11-bit Cyclic Redundancy Check (CRC) signature follow, before RDBK.RIP returns Low. # 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 | | 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. #### 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. # **Configuration Timing** The seven configuration modes are discussed in detail in this section. Timing specifications are included. #### Slave Serial Mode In Slave Serial mode, an external signal drives the CCLK input of the FPGA. The serial configuration bitstream must be available at the DIN input of the lead FPGA a short setup time before each 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 delay of 0.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. Figure 51 shows a full master/slave system. An XC4000 Series device in Slave Serial mode should be connected as shown in the third device from the left. Slave Serial mode is selected by a <111> on the mode pins (M2, M1, M0). Slave Serial is the default mode if the mode pins are left unconnected, as they have weak pull-up resistors during configuration. Figure 51: Master/Slave Serial Mode Circuit Diagram | | Description | | Symbol | Min | Max | Units | |------|-------------|---|------------------|-----|-----|-------| | | DIN setup | 1 | T <sub>DCC</sub> | 20 | | ns | | | DIN hold | 2 | T <sub>CCD</sub> | 0 | | ns | | CCLK | DIN to DOUT | 3 | T <sub>CCO</sub> | | 30 | ns | | CCLK | High time | 4 | T <sub>CCH</sub> | 45 | | ns | | | Low time | 5 | T <sub>CCL</sub> | 45 | | ns | | | Frequency | | F <sub>CC</sub> | | 10 | MHz | Note: Configuration must be delayed until the INIT pins of all daisy-chained FPGAs are High. Figure 52: Slave Serial Mode Programming Switching Characteristics ## **Asynchronous Peripheral Mode** #### Write to FPGA Asynchronous Peripheral mode uses the trailing edge of the logic AND condition of $\overline{WS}$ and $\overline{CS0}$ being Low and $\overline{RS}$ and CS1 being High to accept byte-wide data from a microprocessor bus. In the lead FPGA, this data is loaded into a double-buffered UART-like parallel-to-serial converter and is serially shifted into the internal logic. The lead FPGA presents the preamble data (and all data that overflows the lead device) on its DOUT pin. The RDY/BUSY output from the lead FPGA acts as a handshake signal to the microprocessor. RDY/BUSY goes Low when a byte has been received, and goes High again when the byte-wide input buffer has transferred its information into the shift register, and the buffer is ready to receive new data. A new write may be started immediately, as soon as the RDY/BUSY output has gone Low, acknowledging receipt of the previous data. Write may not be terminated until RDY/BUSY is High again for one CCLK period. Note that RDY/BUSY is pulled High with a high-impedance pull-up prior to INIT going High. The length of the $\overline{\text{BUSY}}$ signal depends on the activity in the UART. If the shift register was empty when the new byte was received, the $\overline{\text{BUSY}}$ signal lasts for only two CCLK periods. If the shift register was still full when the new byte was received, the $\overline{\text{BUSY}}$ signal can be as long as nine CCLK periods. Note that after the last byte has been entered, only seven of its bits are shifted out. CCLK remains High with DOUT equal to bit 6 (the next-to-last bit) of the last byte entered. The READY/BUSY handshake can be ignored if the delay from any one Write to the end of the next Write is guaranteed to be longer than 10 CCLK periods. #### Status Read The logic AND condition of the $\overline{CSO}$ , CS1and $\overline{RS}$ inputs puts the device status on the Data bus. - D7 High indicates Ready - D7 Low indicates Busy - D0 through D6 go unconditionally High It is mandatory that the whole start-up sequence be started and completed by one byte-wide input. Otherwise, the pins used as Write Strobe or Chip Enable might become active outputs and interfere with the final byte transfer. If this transfer does not occur, the start-up sequence is not completed all the way to the finish (point F in Figure 47 on page 53). In this case, at worst, the internal reset is not released. At best, Readback and Boundary Scan are inhibited. The length-count value, as generated by the XACT*step* software, ensures that these problems never occur. Although RDY/ $\overline{\text{BUSY}}$ is brought out as a separate signal, microprocessors can more easily read this information on one of the data lines. For this purpose, D7 represents the RDY/ $\overline{\text{BUSY}}$ status when $\overline{\text{RS}}$ is Low, $\overline{\text{WS}}$ is High, and the two chip select lines are both active. Asynchronous Peripheral mode is selected by a <101> on the mode pins (M2, M1, M0). Figure 58: Asynchronous Peripheral Mode Circuit Diagram # **Configuration Switching Characteristics** # Master Modes (XC4000E/EX) | Description | | Symbol | Min | Max | Units | | | |----------------------------|-----------|-------------------|-----|--------|------------|--|--| | | M0 = High | T <sub>POR</sub> | 10 | 40 | ms | | | | Power-On Reset | M0 = Low | T <sub>POR</sub> | 40 | 130 | ms | | | | Program Latency | • | T <sub>Pl</sub> | 30 | 200 | μs per | | | | | | | | | CLB column | | | | CCLK (output) Delay | | T <sub>ICCK</sub> | 40 | 250 | μs | | | | CCLK (output) Period, slow | | T <sub>CCLK</sub> | 640 | 2000 | ns | | | | CCLK (output) Period, fast | | T <sub>CCLK</sub> | 80 | 80 250 | | | | # Master Modes (XC4000XL) | Description | | Symbol | Min | Max | Units | | | |----------------------------|-----------|-------------------|------------------------|--------|------------|--|--| | | M0 = High | T <sub>POR</sub> | T <sub>POR</sub> 10 40 | | | | | | Power-On Reset | M0 = Low | T <sub>POR</sub> | 40 | 130 ms | | | | | Program Latency | | T <sub>Pl</sub> | 30 | 200 | μs per | | | | | | | | | CLB column | | | | CCLK (output) Delay | | T <sub>ICCK</sub> | 40 | 250 | μs | | | | CCLK (output) Period, slow | | T <sub>CCLK</sub> | 540 | 1600 | ns | | | | CCLK (output) Period, fast | | T <sub>CCLK</sub> | 67 | 200 | ns | | | # Slave and Peripheral Modes (All) | Description | Symbol | Min | Max | Units | |--------------------------------|-------------------|-----|-----|----------------------| | Power-On Reset | T <sub>POR</sub> | 10 | 33 | ms | | Program Latency | T <sub>Pl</sub> | 30 | 200 | μs per<br>CLB column | | CCLK (input) Delay (required) | T <sub>ICCK</sub> | 4 | | μs | | CCLK (input) Period (required) | T <sub>CCLK</sub> | 100 | | ns | # **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 | | Plas | | Plas<br>VQF | Plas<br>TQF | High-P<br>TQF | High-P<br>QFF | | | High-P<br>TQF | High-P<br>QFF | Plas<br>PQF | 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 | ı | | | | COD | DE | PC84 | PQ100 | VQ100 | TQ144 | HT144 | HQ160 | PQ160 | TQ176 | HT176 | HQ208 | PQ208 | HQ240 | PQ240 | BG256 | PG299 | HQ304 | BG352 | PG411 | BG432 | PG475 | PG559 | BG560 | | | -3 | СІ | СІ | СІ | | | | | | | | | | | | | | | | | | | | | XC4002XI | -2 | СІ | СІ | СІ | | | | | | | | | | | | | | | | | | | | | XO4002XL | -1 | СІ | СІ | СІ | | | | | | | | | | | | | | | | | | | | | - | | С | С | С | | | | | | | | | | | | | | | | | | | | | | | СІ | СІ | СІ | СІ | | | СІ | | | | СІ | | | | | | | | | | | | | XC4005XL - | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | | | | | | | | | | | | | | | | | | | | | | | | | | -3 | CI | CI | | CI | | | CI | СІ | | | CI | | | СІ | | | | | | | | | | XC4002XL | -2 | СІ | СІ | | СІ | | | СІ | СІ | | | СІ | | | СІ | | | | | | | | | | | -1 | СІ | СІ | | СІ | | | СІ | СІ | | | СІ | | | СІ | | | | | | | C C C C C C C C C C C C C C C C C C C | | | - | | С | С | | С | | | | С | | | | | | | | | | | | | | | | _ | | | | | | | | | | | | | | | | | | | | | | | | | XC4013XI | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | XC4020XL | | | | | | | | | | | | | | | | | | | | | | | | | | -3 | | | | | | | | | | | | | | | | | | | | | | | | VC4020VI | -2 | | | | | СІ | | СІ | | СІ | | СІ | | СІ | СІ | | | | | | | | | | AC4020AL | -1 | | | | | СІ | | СІ | | СІ | | СІ | | CI | СІ | | | | | | | | | | - | -09C | | | | | С | | С | | С | | С | | С | | | | | | | | | | | | | | | | | | | | | | | | | | | | _ | | | | | | | | XC4028XL - | | | | | | | | | | | | | | | | | | | | | | | | | _ | | | | | | | | | | | | | | | | | _ | | | | | | | | | | | | | | | | | | | | | | | | | | | CI | CI | | | | | | -2 | | | | | | CI | | | | CI | | С | | | | CI | CI | CI | CI | | | | | XC4036XL | -1 | | | | | | СІ | | | | СІ | | СІ | | | | СІ | СІ | СІ | СІ | | | | | - | -09C | | | | | | O | | | | С | | С | | | | С | С | С | С | | | | | - | -08C | | | | | | С | | | | С | | С | | | | С | С | С | С | | PG259 Ceram. | | | XC4002XL | CI | | | | CI | CI | CI | CI | | | | | | | | | | | | | | | | | XC4044XL | | | | | | | | | | | | | | | | | | | | | | | | | l - | | | C1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | | | | | СІ | | VC4050VI | -2 | | | | | | | | | | | | СІ | | | | СІ | | СІ | | | | СІ | | | | | | | | | | | | | | | CI | | | | CI | | CI | СІ | | | СІ | | - | | | | | | | | | | | | | | | | | | | С | | | | | | | | | | | | | | | | | | | | | | | | | | | | | CI | | VC4000VI | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | C | | | | C | | | C | _ | | | | | | | | | | | | | | | | | С | | | | С | | | С | | | | | | | | | | | | | | | | | | Ť | | | | ۲ | | | CI | بّ | CI | | | V04005\(\(\) | | | | | | | | | | | | | | | | | | | | CI | | | CI | | XC4085XL | | | | | | | | | | | | | | | | | | | | СІ | | | СІ | | 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$