Welcome to **E-XFL.COM** ## Understanding <u>Embedded - FPGAs (Field Programmable Gate Array)</u> Embedded - FPGAs, or Field Programmable Gate Arrays, are advanced integrated circuits that offer unparalleled flexibility and performance for digital systems. Unlike traditional fixed-function logic devices, FPGAs can be programmed and reprogrammed to execute a wide array of logical operations, enabling customized functionality tailored to specific applications. This reprogrammability allows developers to iterate designs quickly and implement complex functions without the need for custom hardware. #### **Applications of Embedded - FPGAs** The versatility of Embedded - FPGAs makes them indispensable in numerous fields. In telecommunications. | Details | | |--------------------------------|--------------------------------------------------------------| | Product Status | Obsolete | | Number of LABs/CLBs | 1936 | | Number of Logic Elements/Cells | 4598 | | Total RAM Bits | 61952 | | Number of I/O | 256 | | Number of Gates | 52000 | | Voltage - Supply | 3V ~ 3.6V | | Mounting Type | Surface Mount | | Operating Temperature | 0°C ~ 85°C (TJ) | | Package / Case | 304-BFQFP Exposed Pad | | Supplier Device Package | 304-PQFP (40x40) | | Purchase URL | https://www.e-xfl.com/product-detail/xilinx/xc4052xl-1hq304c | Email: info@E-XFL.COM Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong # 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 | <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- 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) | #### **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 15: Simplified Block Diagram of XC4000E IOB Figure 16: Simplified Block Diagram of XC4000X IOB (shaded areas indicate differences from XC4000E) Figure 22: 3-State Buffers Implement a Multiplexer ## Wide Edge Decoders Dedicated decoder circuitry boosts the performance of wide decoding functions. When the address or data field is wider than the function generator inputs, FPGAs need multi-level decoding and are thus slower than PALs. XC4000 Series CLBs have nine inputs. Any decoder of up to nine inputs is, therefore, compact and fast. However, there is also a need for much wider decoders, especially for address decoding in large microprocessor systems. An XC4000 Series FPGA has four programmable decoders located on each edge of the device. The inputs to each decoder are any of the IOB I1 signals on that edge plus one local interconnect per CLB row or column. Each row or column of CLBs provides up to three variables or their compliments., as shown in Figure 23. Each decoder generates a High output (resistor pull-up) when the AND condition of the selected inputs, or their complements, is true. This is analogous to a product term in typical PAL devices. Each of these wired-AND gates is capable of accepting up to 42 inputs on the XC4005E and 72 on the XC4013E. There are up to 96 inputs for each decoder on the XC4028X and 132 on the XC4052X. The decoders may also be split in two when a larger number of narrower decoders are required, for a maximum of 32 decoders per device. The decoder outputs can drive CLB inputs, so they can be combined with other logic to form a PAL-like AND/OR structure. The decoder outputs can also be routed directly to the chip outputs. For fastest speed, the output should be on the same chip edge as the decoder. Very large PALs can be emulated by ORing the decoder outputs in a CLB. This decoding feature covers what has long been considered a weakness of older FPGAs. Users often resorted to external PALs for simple but fast decoding functions. Now, the dedicated decoders in the XC4000 Series device can implement these functions fast and efficiently. To use the wide edge decoders, place one or more of the WAND library symbols (WAND1, WAND4, WAND8, WAND16). Attach a DECODE attribute or property to each WAND symbol. Tie the outputs together and attach a PUL- LUP symbol. Location attributes or properties such as L (left edge) or TR (right half of top edge) should also be used to ensure the correct placement of the decoder inputs. Figure 23: XC4000 Series Edge Decoding Example Figure 24: XC4000 Series Oscillator Symbol #### **On-Chip Oscillator** XC4000 Series devices include an internal oscillator. This oscillator is used to clock the power-on time-out, for configuration memory clearing, and as the source of CCLK in Master configuration modes. The oscillator runs at a nominal 8 MHz frequency that varies with process, Vcc, and temperature. The output frequency falls between 4 and 10 MHz. 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 **Table 16: Pin Descriptions (Continued)** | | I/O | I/O | | |----------------------------------------|-----------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Pin Name | During Config. | After Config. | Pin Description | | 1 III Name | coming. | Coming. | These four inputs are used in Asynchronous Peripheral mode. The chip is selected | | CSO, CS1,<br>WS, RS | ı | I/O | when $\overline{\text{CS0}}$ is Low and CS1 is High. While the chip is selected, a Low on Write Strobe $(\overline{\text{WS}})$ loads the data present on the D0 - D7 inputs into the internal data buffer. A Low on Read Strobe $(\overline{\text{RS}})$ changes D7 into a status output — High if Ready, Low if Busy — and drives D0 - D6 High. In Express mode, CS1 is used as a serial-enable signal for daisy-chaining. $\overline{\text{WS}}$ and $\overline{\text{RS}}$ should be mutually exclusive, but if both are Low simultaneously, the Write Strobe overrides. After configuration, these are user-programmable I/O pins. | | A0 - A17 | 0 | I/O | During Master Parallel configuration, these 18 output pins address the configuration EPROM. After configuration, they are user-programmable I/O pins. | | A18 - A21<br>(XC4003XL to<br>XC4085XL) | 0 | I/O | During Master Parallel configuration with an XC4000X master, these 4 output pins add 4 more bits to address the configuration EPROM. After configuration, they are user-programmable I/O pins. (See Master Parallel Configuration section for additional details.) | | D0 - D7 | I | I/O | During Master Parallel and Peripheral configuration, these eight input pins receive configuration data. After configuration, they are user-programmable I/O pins. | | DIN | I | I/O | During Slave Serial or Master Serial configuration, DIN is the serial configuration data input receiving data on the rising edge of CCLK. During Parallel configuration, DIN is the D0 input. After configuration, DIN is a user-programmable I/O pin. | | DOUT | 0 | I/O | During configuration in any mode but Express mode, DOUT is the serial configuration data output that can drive the DIN of daisy-chained slave FPGAs. DOUT data changes on the falling edge of CCLK, one-and-a-half CCLK periods after it was received at the DIN input. In Express modefor XC4000E and XC4000X only, DOUT is the status output that can drive the CS1 of daisy-chained FPGAs, to enable and disable downstream devices. After configuration, DOUT is a user-programmable I/O pin. | | Unrestricted U | ser-Prog | rammabl | e I/O Pins | | I/O | Weak<br>Pull-up | I/O | These pins can be configured to be input and/or output after configuration is completed. Before configuration is completed, these pins have an internal high-value pull-up resistor (25 k $\Omega$ - 100 k $\Omega$ ) that defines the logic level as High. | ## **Boundary Scan** The 'bed of nails' has been the traditional method of testing electronic assemblies. This approach has become less appropriate, due to closer pin spacing and more sophisticated assembly methods like surface-mount technology and multi-layer boards. The IEEE Boundary Scan Standard 1149.1 was developed to facilitate board-level testing of electronic assemblies. Design and test engineers can imbed a standard test logic structure in their device to achieve high fault coverage for I/O and internal logic. This structure is easily implemented with a four-pin interface on any boundary scan-compatible IC. IEEE 1149.1-compatible devices may be serial daisy-chained together, connected in parallel, or a combination of the two. The XC4000 Series implements IEEE 1149.1-compatible BYPASS, PRELOAD/SAMPLE and EXTEST boundary scan instructions. When the boundary scan configuration option is selected, three normal user I/O pins become dedicated inputs for these functions. Another user output pin becomes the dedicated boundary scan output. The details of how to enable this circuitry are covered later in this section. By exercising these input signals, the user can serially load commands and data into these devices to control the driving of their outputs and to examine their inputs. This method is an improvement over bed-of-nails testing. It avoids the need to over-drive device outputs, and it reduces the user interface to four pins. An optional fifth pin, a reset for the control logic, is described in the standard but is not implemented in Xilinx devices. The dedicated on-chip logic implementing the IEEE 1149.1 functions includes a 16-state machine, an instruction register and a number of data registers. The functional details can be found in the IEEE 1149.1 specification and are also discussed in the Xilinx application note XAPP 017: "Boundary Scan in XC4000 Devices." Figure 40 on page 43 shows a simplified block diagram of the XC4000E Input/Output Block with boundary scan implemented. XC4000X boundary scan logic is identical. 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. ## **Configuration Modes** XC4000E devices have six configuration modes. XC4000X devices have the same six modes, plus an additional configuration mode. These modes are selected by a 3-bit input code applied to the M2, M1, and M0 inputs. There are three self-loading Master modes, two Peripheral modes, and a Serial Slave mode, which is used primarily for daisy-chained devices. The coding for mode selection is shown in Table 18. **Table 18: Configuration Modes** | Mode | M2 | M1 | MO | CCLK | Data | |---------------|----|----|----|--------|------------| | Master Serial | 0 | 0 | 0 | output | Bit-Serial | | Slave Serial | 1 | 1 | 1 | input | Bit-Serial | | Master | 1 | 0 | 0 | output | Byte-Wide, | | Parallel Up | | | | | increment | | | | | | | from 00000 | | Master | 1 | 1 | 0 | output | Byte-Wide, | | Parallel Down | | | | | decrement | | | | | | | from 3FFFF | | Peripheral | 0 | 1 | 1 | input | Byte-Wide | | Synchronous* | | | | | | | Peripheral | 1 | 0 | 1 | output | Byte-Wide | | Asynchronous | | | | | | | Reserved | 0 | 1 | 0 | _ | _ | | Reserved | 0 | 0 | 1 | _ | _ | <sup>\*</sup> Can be considered byte-wide Slave Parallel A detailed description of each configuration mode, with timing information, is included later in this data sheet. During configuration, some of the I/O pins are used temporarily for the configuration process. All pins used during configuration are shown in Table 22 on page 58. #### Master Modes The three Master modes use an internal oscillator to generate a Configuration Clock (CCLK) for driving potential slave devices. They also generate address and timing for external PROM(s) containing the configuration data. Master Parallel (Up or Down) modes generate the CCLK signal and PROM addresses and receive byte parallel data. The data is internally serialized into the FPGA data-frame format. The up and down selection generates starting addresses at either zero or 3FFFF (3FFFFF when 22 address lines are used), for compatibility with different microprocessor addressing conventions. The Master Serial mode generates CCLK and receives the configuration data in serial form from a Xilinx serial-configuration PROM. CCLK speed is selectable as either 1 MHz (default) or 8 MHz. Configuration always starts at the default slow frequency, then can switch to the higher frequency during the first frame. Frequency tolerance is -50% to +25%. #### Additional Address lines in XC4000 devices The XC4000X devices have additional address lines (A18-A21) allowing the additional address space required to daisy-chain several large devices. The extra address lines are programmable in XC4000EX devices. By default these address lines are not activated. In the default mode, the devices are compatible with existing XC4000 and XC4000E products. If desired, the extra address lines can be used by specifying the address lines option in bitgen as 22 (bitgen -g AddressLines:22). The lines (A18-A21) are driven when a master device detects, via the bitstream, that it should be using all 22 address lines. Because these pins will initially be pulled high by internal pull-ups, designers using Master Parallel Up mode should use external pull down resistors on pins A18-A21. If Master Parallel Down mode is used external resistors are not necessary. All 22 address lines are always active in Master Parallel modes with XC4000XL devices. The additional address lines behave identically to the lower order address lines. If the Address Lines option in bitgen is set to 18, it will be ignored by the XC4000XL device. The additional address lines (A18-A21) are not available in the PC84 package. ## Peripheral Modes The two Peripheral modes accept byte-wide data from a bus. A RDY/BUSY status is available as a handshake signal. In Asynchronous Peripheral mode, the internal oscillator generates a CCLK burst signal that serializes the byte-wide data. CCLK can also drive slave devices. In the synchronous mode, an externally supplied clock input to CCLK serializes the data. ### Slave Serial Mode In Slave Serial mode, the FPGA receives serial configuration data on the rising edge of CCLK and, after loading its configuration, passes additional data out, resynchronized on the next falling edge of CCLK. Multiple slave devices with identical configurations can be wired with parallel DIN inputs. In this way, multiple devices can be configured simultaneously. #### **Serial Daisy Chain** Multiple devices with different configurations can be connected together in a "daisy chain," and a single combined bitstream used to configure the chain of slave devices. To configure a daisy chain of devices, wire the CCLK pins of all devices in parallel, as shown in Figure 51 on page 60. Connect the DOUT of each device to the DIN of the next. The lead or master FPGA and following slaves each passes resynchronized configuration data coming from a single source. The header data, including the length count, used), and if RAM is present, the RAM content must be unchanged. Statistically, one error out of 2048 might go undetected. ## **Configuration Sequence** There are four major steps in the XC4000 Series power-up configuration sequence. - Configuration Memory Clear - Initialization - Configuration - Start-Up The full process is illustrated in Figure 46. ## Configuration Memory Clear When power is first applied or is reapplied to an FPGA, an internal circuit forces initialization of the configuration logic. When Vcc reaches an operational level, and the circuit passes the write and read test of a sample pair of configuration bits, a time delay is started. This time delay is nominally 16 ms, and up to 10% longer in the low-voltage devices. The delay is four times as long when in Master Modes (M0 Low), to allow ample time for all slaves to reach a stable Vcc. When all $\overline{\text{INIT}}$ pins are tied together, as recommended, the longest delay takes precedence. Therefore, devices with different time delays can easily be mixed and matched in a daisy chain. This delay is applied only on power-up. It is not applied when re-configuring an FPGA by pulsing the $\overline{\text{PROGRAM}}$ pin Figure 45: Circuit for Generating CRC-16 Figure 46: Power-up Configuration Sequence ## Product Obsolete or Under Obsolescence XC4000E and XC4000X Series Field Programmable Gate Arrays Low. During this time delay, or as long as the PROGRAM input is asserted, the configuration logic is held in a Configuration Memory Clear state. The configuration-memory frames are consecutively initialized, using the internal oscillator. At the end of each complete pass through the frame addressing, the power-on time-out delay circuitry and the level of the PROGRAM pin are tested. If neither is asserted, the logic initiates one additional clearing of the configuration frames and then tests the NIT input. #### Initialization During initialization and configuration, user pins HDC, $\overline{\text{LDC}}$ , $\overline{\text{INIT}}$ and DONE provide status outputs for the system interface. The outputs $\overline{\text{LDC}}$ , $\overline{\text{INIT}}$ and DONE are held Low and HDC is held High starting at the initial application of power. The open drain $\overline{INIT}$ pin is released after the final initialization pass through the frame addresses. There is a deliberate delay of 50 to 250 $\mu s$ (up to 10% longer for low-voltage devices) before a Master-mode device recognizes an inactive $\overline{INIT}$ . Two internal clocks after the $\overline{INIT}$ pin is recognized as High, the FPGA samples the three mode lines to determine the configuration mode. The appropriate interface lines become active and the configuration preamble and data can be loaded.Configuration The 0010 preamble code indicates that the following 24 bits represent the length count. The length count is the total number of configuration clocks needed to load the complete configuration data. (Four additional configuration clocks are required to complete the configuration process, as discussed below.) After the preamble and the length count have been passed through to all devices in the daisy chain, DOUT is held High to prevent frame start bits from reaching any daisy-chained devices. A specific configuration bit, early in the first frame of a master device, controls the configuration-clock rate and can increase it by a factor of eight. Therefore, if a fast configuration clock is selected by the bitstream, the slower clock rate is used until this configuration bit is detected. Each frame has a start field followed by the frame-configuration data bits and a frame error field. If a frame data error is detected, the FPGA halts loading, and signals the error by pulling the open-drain $\overline{\text{INIT}}$ pin Low. After all configuration frames have been loaded into an FPGA, DOUT again follows the input data so that the remaining data is passed on to the next device. ## **Delaying Configuration After Power-Up** There are two methods of delaying configuration after power-up: put a logic Low on the PROGRAM input, or pull the bidirectional INIT pin Low, using an open-collector (open-drain) driver. (See Figure 46 on page 50.) A Low on the PROGRAM input is the more radical approach, and is recommended when the power-supply rise time is excessive or poorly defined. As long as \$\overline{PRO}\$ GRAM is Low, the FPGA keeps clearing its configuration memory. When \$\overline{PROGRAM}\$ goes High, the configuration memory is cleared one more time, followed by the beginning of configuration, provided the \$\overline{INIT}\$ input is not externally held Low. Note that a Low on the \$\overline{PROGRAM}\$ input automatically forces a Low on the \$\overline{INIT}\$ output. The XC4000 Series \$\overline{PROGRAM}\$ pin has a permanent weak pull-up. Using an open-collector or open-drain driver to hold $\overline{INIT}$ Low before the beginning of configuration causes the FPGA to wait after completing the configuration memory clear operation. When $\overline{INIT}$ is no longer held Low externally, the device determines its configuration mode by capturing its mode pins, and is ready to start the configuration process. A master device waits up to an additional 250 $\mu s$ to make sure that any slaves in the optional daisy chain have seen that $\overline{INIT}$ is High. #### Start-Up Start-up is the transition from the configuration process to the intended user operation. This transition involves a change from one clock source to another, and a change from interfacing parallel or serial configuration data where most outputs are 3-stated, to normal operation with I/O pins active in the user-system. Start-up must make sure that the user-logic 'wakes up' gracefully, that the outputs become active without causing contention with the configuration signals, and that the internal flip-flops are released from the global Reset or Set at the right time. Figure 47 describes start-up timing for the three Xilinx families in detail. The configuration modes can use any of the four timing sequences. To access the internal start-up signals, place the STARTUP library symbol. #### **Start-up Timing** Different FPGA families have different start-up sequences. The XC2000 family goes through a fixed sequence. DONE goes High and the internal global Reset is de-activated one CCLK period after the I/O become active. The XC3000A family offers some flexibility. DONE can be programmed to go High one CCLK period before or after the I/O become active. Independent of DONE, the internal global Reset is de-activated one CCLK period before or after the I/O become active. The XC4000 Series offers additional flexibility. The three events — DONE going High, the internal Set/Reset being de-activated, and the user I/O going active — can all occur in any arbitrary sequence. Each of them can occur one CCLK period before or after, or simultaneous with, any of the others. This relative timing is selected by means of software options in the bitstream generation software. Figure 47: Start-up Timing ## 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 | 5 | Symbol | Min | Max | Units | |-----------|------------------------------------------------|---|-------------------|-----|-----|-------| | rdbk.TRIG | rdbk.TRIG setup to initiate and abort Readback | 1 | T <sub>RTRC</sub> | 200 | - | ns | | | rdbk.TRIG hold to initiate and abort Readback | 2 | T <sub>RCRT</sub> | 50 | - | ns | | rdclk.1 | rdbk.DATA delay | 7 | T <sub>RCRD</sub> | - | 250 | ns | | | rdbk.RIP delay | 6 | T <sub>RCRR</sub> | - | 250 | ns | | | High time | 5 | T <sub>RCH</sub> | 250 | 500 | ns | | | Low time | 4 | T <sub>RCL</sub> | 250 | 500 | ns | Note 1: Timing parameters apply to all speed grades. Note 2: If rdbk.TRIG is High prior to Finished, Finished will trigger the first Readback. **Table 22: Pin Functions During Configuration** | SLAVE<br>SERIAL<br><1:1:1> | MASTER<br>SERIAL<br><0:0:0> | SYNCH.<br>PERIPHERAL<br><0:1:1> | ASYNCH. PERIPHERAL <1:0:1> | MASTER<br>PARALLEL DOWN<br><1:1:0> | MASTER<br>PARALLEL UP<br><1:0:0> | USER<br>OPERATION | |----------------------------|-----------------------------|---------------------------------|----------------------------|------------------------------------|----------------------------------|-------------------| | M2(HIGH) (I) | M2(LOW) (I) | M2(LOW) (I) | M2(HIGH) (I) | M2(HIGH) (I) | M2(HIGH) (I) | (I) | | M1(HIGH) (I) | M1(LOW) (I) | M1(HIGH) (I) | M1(LOW) (I) | M1(HIGH) (I) | M1(LOW) (I) | (O) | | M0(HIGH) (I) | M0(LOW) (I) | M0(HIGH) (I) | M0(HIGH) (I) | M0(LOW) (I) | M0(LOW) (I) | (I) | | HDC (HIGH) | HDC (HIGH) | HDC (HIGH) | HDC (HIGH) | HDC (HIGH) | HDC (HIGH) | I/O | | LDC (LOW) | LDC (LOW) | LDC (LOW) | LDC (LOW) | LDC (LOW) | LDC (LOW) | I/O | | ĪNIT | ĪNIT | ĪNIT | ĪNIT | ĪNIT | ĪNIT | I/O | | DONE | PROGRAM (I) | PROGRAM (I) | PROGRAM (I) | PROGRAM (I) | PROGRAM (I) | PROGRAM (I) | PROGRAM | | CCLK (I) | CCLK (O) | CCLK (I) | CCLK (O) | CCLK (O) | CCLK (O) | CCLK (I) | | | | RDY/BUSY (O) | RDY/BUSY (O) | RCLK (O) | RCLK (O) | I/O | | | | | RS (I) | | | I/O | | | | | CSO (I) | | | I/O | | | | DATA 7 (I) | DATA 7 (I) | DATA 7 (I) | DATA 7 (I) | I/O | | | | DATA 6 (I) | DATA 6 (I) | DATA 6 (I) | DATA 6 (I) | I/O | | | | DATA 5 (I) | DATA 5 (I) | DATA 5 (I) | DATA 5 (I) | I/O | | | | DATA 4 (I) | DATA 4 (I) | DATA 4 (I) | DATA 4 (I) | I/O | | | | DATA 3 (I) | DATA 3 (I) | DATA 3 (I) | DATA 3 (I) | I/O | | | | DATA 2 (I) | DATA 2 (I) | DATA 2 (I) | DATA 2 (I) | I/O | | | | DATA 1 (I) | DATA 1 (I) | DATA 1 (I) | DATA 1 (I) | I/O | | DIN (I) | DIN (I) | DATA 0 (I) | DATA 0 (I) | DATA 0 (I) | DATA 0 (I) | I/O | | DOUT | DOUT | DOUT | DOUT | DOUT | DOUT | SGCK4-GCK6-I/O | | TDI | TDI | TDI | TDI | TDI | TDI | TDI-I/O | | TCK | TCK | TCK | TCK | TCK | TCK | TCK-I/O | | TMS | TMS | TMS | TMS | TMS | TMS | TMS-I/O | | TDO | TDO | TDO | TDO | TDO | TDO | TDO-(O) | | | | | WS (I) | A0 | A0 | I/O | | | | | | A1 | A1 | PGCK4-GCK7-I/O | | | | | CS1 | A2 | A2 | I/O | | | | | | A3 | A3 | I/O | | | | | | A4 | A4 | I/O | | | | | | A5 | A5 | I/O | | | | | | A6 | A6 | I/O | | | | | | A7 | A7 | I/O | | | | | | A8 | A8 | I/O | | | | | | A9 | A9 | I/O | | | | | | A10 | A10 | I/O | | | | | | A11 | A11 | I/O | | | | | | A12 | A12 | I/O | | | | | | A13 | A13 | I/O | | | | | | A14 | A14 | I/O | | | | | | A15 | A15 | SGCK1-GCK8-I/O | | | | | | A16 | A16 | PGCK1-GCK1-I/O | | | | | | A17 | A17 | I/O | | | | | | A18* | A18* | I/O | | | | | | A19* | A19* | I/O | | | | | | A20* | A20* | I/O | | | | | | A21* | A21* | I/O | | | | | | | | ALL OTHERS | | | Description | | Symbol | Min | Max | Units | |------|------------------------|---|------------------|-----|-----|-------| | | Delay to Address valid | 1 | T <sub>RAC</sub> | 0 | 200 | ns | | RCLK | Data setup time | 2 | T <sub>DRC</sub> | 60 | | ns | | | Data hold time | 3 | T <sub>RCD</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. The first Data byte is loaded and CCLK starts at the end of the first RCLK active cycle (rising edge). This timing diagram shows that the EPROM requirements are extremely relaxed. EPROM access time can be longer than 500 ns. EPROM data output has no hold-time requirements. Figure 55: Master Parallel Mode Programming Switching Characteristics | | Description | Symbol | Min | Max | Units | |------|------------------------|------------------|-----|-----|-------| | | INIT (High) setup time | T <sub>IC</sub> | 5 | | μs | | | D0 - D7 setup time | T <sub>DC</sub> | 60 | | ns | | CCLK | D0 - D7 hold time | T <sub>CD</sub> | 0 | | ns | | CCLK | CCLK High time | T <sub>CCH</sub> | 50 | | ns | | | CCLK Low time | T <sub>CCL</sub> | 60 | | ns | | | CCLK Frequency | F <sub>CC</sub> | | 8 | MHz | Notes: 1. Peripheral Synchronous mode can be considered Slave Parallel mode. An external CCLK provides timing, clocking in the **first** data byte on the **second** rising edge of CCLK after INIT goes High. Subsequent data bytes are clocked in on every eighth consecutive rising edge of CCLK. - 2. The RDY/BUSY line goes High for one CCLK period after data has been clocked in, although synchronous operation does not require such a response. - 3. The pin name RDY/BUSY is a misnomer. In Synchronous Peripheral mode this is really an ACKNOWLEDGE signal. - 4. Note that data starts to shift out serially on the DOUT pin 0.5 CCLK periods after it was loaded in parallel. Therefore, additional CCLK pulses are clearly required after the last byte has been loaded. Figure 57: Synchronous Peripheral Mode Programming Switching Characteristics ## **Asynchronous Peripheral Mode** #### Write to FPGA Asynchronous Peripheral mode uses the trailing edge of the logic AND condition of $\overline{WS}$ and $\overline{CS0}$ being Low and $\overline{RS}$ and CS1 being High to accept byte-wide data from a microprocessor bus. In the lead FPGA, this data is loaded into a double-buffered UART-like parallel-to-serial converter and is serially shifted into the internal logic. The lead FPGA presents the preamble data (and all data that overflows the lead device) on its DOUT pin. The RDY/BUSY output from the lead FPGA acts as a handshake signal to the microprocessor. RDY/BUSY goes Low when a byte has been received, and goes High again when the byte-wide input buffer has transferred its information into the shift register, and the buffer is ready to receive new data. A new write may be started immediately, as soon as the RDY/BUSY output has gone Low, acknowledging receipt of the previous data. Write may not be terminated until RDY/BUSY is High again for one CCLK period. Note that RDY/BUSY is pulled High with a high-impedance pull-up prior to INIT going High. The length of the $\overline{\text{BUSY}}$ signal depends on the activity in the UART. If the shift register was empty when the new byte was received, the $\overline{\text{BUSY}}$ signal lasts for only two CCLK periods. If the shift register was still full when the new byte was received, the $\overline{\text{BUSY}}$ signal can be as long as nine CCLK periods. Note that after the last byte has been entered, only seven of its bits are shifted out. CCLK remains High with DOUT equal to bit 6 (the next-to-last bit) of the last byte entered. The READY/BUSY handshake can be ignored if the delay from any one Write to the end of the next Write is guaranteed to be longer than 10 CCLK periods. #### Status Read The logic AND condition of the $\overline{CSO}$ , CS1and $\overline{RS}$ inputs puts the device status on the Data bus. - D7 High indicates Ready - D7 Low indicates Busy - D0 through D6 go unconditionally High It is mandatory that the whole start-up sequence be started and completed by one byte-wide input. Otherwise, the pins used as Write Strobe or Chip Enable might become active outputs and interfere with the final byte transfer. If this transfer does not occur, the start-up sequence is not completed all the way to the finish (point F in Figure 47 on page 53). In this case, at worst, the internal reset is not released. At best, Readback and Boundary Scan are inhibited. The length-count value, as generated by the XACT*step* software, ensures that these problems never occur. Although RDY/ $\overline{\text{BUSY}}$ is brought out as a separate signal, microprocessors can more easily read this information on one of the data lines. For this purpose, D7 represents the RDY/ $\overline{\text{BUSY}}$ status when $\overline{\text{RS}}$ is Low, $\overline{\text{WS}}$ is High, and the two chip select lines are both active. Asynchronous Peripheral mode is selected by a <101> on the mode pins (M2, M1, M0). Figure 58: Asynchronous Peripheral Mode Circuit Diagram | | Description | , | Symbol | Min | Max | Units | | | |---------|--------------------------------------------------|---|-------------------|-----|-----|-----------------|--|--| | \\/#ito | Effective Write time (CSO, WS=Low; RS, CS1=High) | 1 | T <sub>CA</sub> | 100 | | ns | | | | Write | DIN setup time | 2 | T <sub>DC</sub> | 60 | | ns | | | | | DIN hold time | 3 | T <sub>CD</sub> | 0 | | ns | | | | RDY | RDY/BUSY delay after end of Write or Read | 4 | T <sub>WTRB</sub> | | 60 | ns | | | | | RDY/BUSY active after beginning of Read | 7 | | | 60 | ns | | | | | RDY/BUSY Low output (Note 4) | 6 | T <sub>BUSY</sub> | 2 | 9 | CCLK<br>periods | | | - Notes: 1. Configuration must be delayed until the NIT pins of all daisy-chained FPGAs are High. - 2. The time from the end of WS to CCLK cycle for the new byte of data depends on the completion of previous byte processing and the phase of the internal timing generator for CCLK. - 3. CCLK and DOUT timing is tested in slave mode. - 4. T<sub>RUSY</sub> indicates that the double-buffered parallel-to-serial converter is not yet ready to receive new data. The shortest T<sub>BUSY</sub> occurs when a byte is loaded into an empty parallel-to-serial converter. The longest T<sub>BUSY</sub> occurs when a new word is loaded into the input register before the second-level buffer has started shifting out data This timing diagram shows very relaxed requirements. Data need not be held beyond the rising edge of WS. RDY/BUSY will go active within 60 ns after the end of WS. A new write may be asserted immediately after RDY/BUSY goes Low, but write may not be terminated until RDY/BUSY has been High for one CCLK period. Figure 59: Asynchronous Peripheral Mode Programming Switching Characteristics ## **Product Availability** Table 24, Table 25, and Table 26 show the planned packages and speed grades for XC4000-Series devices. Call your local sales office for the latest availability information, or see the Xilinx website at http://www.xilinx.com for the latest revision of the specifications. Table 24: Component Availability Chart for XC4000XL FPGAs | | NS | 84 | 100 | 100 | 144 | 144 | 160 | 160 | 176 | 176 | 208 | 208 | 240 | 240 | 256 | 299 | 304 | 352 | 411 | 432 | 475 | 559 | 560 | |--------------|--------------|----------------|----------------|----------------|----------------|--------------------|-------------------|----------------|----------------|--------------------|-------------------|----------------|-------------------|----------------|---------------|---------------|-------------------|---------------|---------------|---------------|---------------|---------------|---------------| | | | | | | | | | | | | | | | | | | | | | | | | | | TYPE<br>CODE | | Plast.<br>PLCC | Plast.<br>PQFP | Plast.<br>VQFP | Plast.<br>TQFP | High-Perf.<br>TQFP | High-Perf.<br>QFP | Plast.<br>PQFP | Plast.<br>TQFP | High-Perf.<br>TQFP | High-Perf.<br>QFP | Plast.<br>PQFP | High-Perf.<br>QFP | Plast.<br>PQFP | Plast.<br>BGA | Ceram.<br>PGA | High-Perf.<br>QFP | Plast.<br>BGA | Ceram.<br>PGA | Plast.<br>BGA | Ceram.<br>PGA | Ceram.<br>PGA | Plast.<br>BGA | | | | PC84 | PQ100 | VQ100 | TQ144 | HT144 | HQ160 | PQ160 | TQ176 | HT176 | HQ208 | PQ208 | HQ240 | PQ240 | BG256 | PG299 | HQ304 | BG352 | PG411 | BG432 | PG475 | PG559 | BG560 | | | -3 | СІ | СІ | СІ | | | | | | | | | | | | | | | | | | | | | XC4002XL | -2 | СІ | СІ | СІ | | | | | | | | | | | | | | | | | | | | | XO4002XL | -1 | СІ | СІ | СІ | | | | | | | | | | | | | | | | | | | | | - | -09C | С | С | С | | | | | | | | | | | | | | | | | | | | | | -3 | СІ | СІ | СІ | СІ | | | СІ | | | | СІ | | | | | | | | | | | | | XC4005XL - | -2 | CI | С | CI | CI | | | CI | | | | CI | | | | | | | | | | | | | <u> </u> | -1<br>-09C | C I | C I | C I | C I | | | C I | | | | C I | | | | | | | | | | | | | | -3 | CI | CI | | CI | | | CI | СІ | | | CI | | | СІ | | | | | | | | | | XC4010XL | -2 | СІ | СІ | | СІ | | | СІ | СІ | | | СІ | | | СІ | | | | | | | | | | | -1 | СІ | СІ | | СІ | | | СІ | СІ | | | СІ | | | СІ | | | | | | | | | | - | -09C | С | С | | С | | | С | С | | | С | | | С | | | | | | | | | | _ | -3<br>-2 | | | | | CI | | CI | | CI | | CI<br>CI | | CI | CI | | | | | | | | | | XC4013XL | - <u>-</u> 2 | | | | | CI | | CI | | CI | | CI | | CI | CI | | | | | | | | | | | -09C | | | | | C | | C | | C | | C | | C | C | | | | | | | | | | | -08C | | | | | С | | С | | С | | С | | С | С | | | | | | | | | | | -3 | | | | | СІ | | CI | | CI | | СІ | | CI | СІ | | | | | | | | | | XC4020XL | -2 | | | | | СІ | | СІ | | СІ | | СІ | | СІ | СІ | | | | | | | | | | AC4020AL | -1 | | | | | СІ | | СІ | | СІ | | СІ | | CI | СІ | | | | | | | | | | - | -09C | | | | | С | | С | | С | | С | | С | С | | | | | | | | | | | -3 | | | | | | CI | | | | CI | | CI | | CI | CI | CI | CI | | | | | | | XC4028XL - | -2<br>-1 | | | | | | CI | | | | CI | | CI | | CI | CI | CI | CI | | | | | | | _ | -09C | | | | | | C | | | | C | | С | | С | C | C | C | | | | | | | | -3 | | | | | | CI | | | | CI | | CI | | | | CI | CI | СІ | СІ | | | | | | -2 | | | | | | CI | | | | CI | | С | | | | CI | CI | CI | CI | | | | | XC4036XL | -1 | | | | | | СІ | | | | СІ | | СІ | | | | СІ | СІ | СІ | СІ | | | | | - | -09C | | | | | | O | | | | С | | С | | | | С | С | С | С | | | | | - | -08C | | | | | | С | | | | С | | С | | | | С | С | С | С | | | | | | -3 | -1 | | | | | CI | | | | CI | | CI | | | | CI | CI | CI | CI | | | | | XC4044XL | -2<br>-1 | | | | | | CI | | | | CI | | CI | | | | CI | CI | CI | CI | | | | | l - | -09C | | | | | | С | | | | С | | С | | | | С | С | С | С | | | | | | -3 | | | | | | | | | | | | CI | | | | CI | <u> </u> | CI | CI | | | СІ | | VC4050VI | -2 | | | | | | | | | | | | СІ | | | | СІ | | СІ | СІ | | | СІ | | XC4052XL | -1 | | | | | | | | | | | | СІ | | | | CI | | СI | СІ | | | СІ | | - | -09C | | | | | | | | | | | | С | | | | С | | С | С | | | С | | | -3 | | | | | | | | | | | | CI | | | | CI | | | CI | CI | | CI | | VC4000VI | -2 | | | | | | | | | | | | CI | | | | CI | | | CI | CI | | CI | | //O 1002//L | -1<br>-09C | | | | | | | | | | | | C1 | | | | CI | | | C I | C I | | C | | | -08C | | | | | | | | | | | | С | | | | С | | | С | С | | С | | | -3 | | | | | | | | | | | | Ť | | | | ۲ | | | CI | بّ | CI | CI | | V04005\(\(\) | -2 | | | | | | | | | | | | | | | | | | | CI | | CI | CI | | XC4085XL | -1 | | | | | | | | | | | | | | | | | | | СІ | | СІ | СІ | | | -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$ ## 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 | | | | | |