Welcome to **E-XFL.COM** ## Understanding <u>Embedded - FPGAs (Field Programmable Gate Array)</u> Embedded - FPGAs, or Field Programmable Gate Arrays, are advanced integrated circuits that offer unparalleled flexibility and performance for digital systems. Unlike traditional fixed-function logic devices, FPGAs can be programmed and reprogrammed to execute a wide array of logical operations, enabling customized functionality tailored to specific applications. This reprogrammability allows developers to iterate designs quickly and implement complex functions without the need for custom hardware. ## **Applications of Embedded - FPGAs** The versatility of Embedded - FPGAs makes them indispensable in numerous fields. In telecommunications. | Details | | |--------------------------------|--------------------------------------------------------------| | Product Status | Obsolete | | Number of LABs/CLBs | 576 | | Number of Logic Elements/Cells | 1368 | | Total RAM Bits | 18432 | | Number of I/O | 77 | | Number of Gates | 30000 | | Voltage - Supply | 3V ~ 3.6V | | Mounting Type | Surface Mount | | Operating Temperature | 0°C ~ 85°C (TJ) | | Package / Case | 100-TQFP | | Supplier Device Package | 100-VQFP (14x14) | | Purchase URL | https://www.e-xfl.com/product-detail/xilinx/xcs30xl-4vqg100c | Email: info@E-XFL.COM Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong Spartan and Spartan-XL devices provide system clock rates exceeding 80 MHz and internal performance in excess of 150 MHz. In addition to the conventional benefit of high volume programmable logic solutions, Spartan series FPGAs also offer on-chip edge-triggered single-port and dual-port RAM, clock enables on all flip-flops, fast carry logic, and many other features. The Spartan/XL families leverage the highly successful XC4000 architecture with many of that family's features and benefits. Technology advancements have been derived from the XC4000XLA process developments. ## **Logic Functional Description** The Spartan series uses a standard FPGA structure as shown in Figure 1, page 2. The FPGA consists of an array of configurable logic blocks (CLBs) placed in a matrix of routing channels. The input and output of signals is achieved through a set of input/output blocks (IOBs) forming a ring around the CLBs and routing channels. - CLBs provide the functional elements for implementing the user's logic. - IOBs provide the interface between the package pins and internal signal lines. - Routing channels provide paths to interconnect the inputs and outputs of the CLBs and IOBs. 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. ## **Configurable Logic Blocks (CLBs)** The CLBs are used to implement most of the logic in an FPGA. The principal CLB elements are shown in the simplified block diagram in Figure 2. There are three look-up tables (LUT) which are used as logic function generators, two flip-flops and two groups of signal steering multiplexers. There are also some more advanced features provided by the CLB which will be covered in the **Advanced Features Description**, page 13. #### **Function Generators** Two 16 x 1 memory look-up tables (F-LUT and G-LUT) are used to implement 4-input function generators, each offering unrestricted logic implementation of any Boolean function of up to four independent input signals (F1 to F4 or G1 to G4). Using memory look-up tables the propagation delay is independent of the function implemented. A third 3-input function generator (H-LUT) can implement any Boolean function of its three inputs. Two of these inputs are controlled by programmable multiplexers (see box "A" of Figure 2). These inputs can come from the F-LUT or G-LUT outputs or from CLB inputs. The third input always comes from a CLB input. The CLB can, therefore, implement certain functions of up to nine inputs, like parity checking. The three LUTs in the CLB can also be combined to do any arbitrarily defined Boolean function of five inputs. Slave Serial is the default mode if the Mode pins are left unconnected, as they have weak pull-up resistors during configuration. 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 25. 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, is passed through and is captured by each FPGA when it recognizes the 0010 preamble. Following the length-count data, each FPGA outputs a High on DOUT until it has received its required number of data frames. After an FPGA has received its configuration data, it passes on any additional frame start bits and configuration data on DOUT. When the total number of configuration clocks applied after memory initialization equals the value of the 24-bit length count, the FPGAs begin the start-up sequence and become operational together. FPGA I/O are normally released two CCLK cycles after the last configuration bit is received. The daisy-chained bitstream is not simply a concatenation of the individual bitstreams. The PROM File Formatter must be used to combine the bitstreams for a daisy-chained configuration. Note: Figure 25: Master/Slave Serial Mode Circuit Diagram DS060\_25\_061301 to the DONE pin. User I/Os for each device become active after the DONE pin for that device goes High. (The exact timing is determined by development system options.) Since the DONE pin is open-drain and does not drive a High value, tying the DONE pins of all devices together prevents all devices in the chain from going High until the last device in the chain has completed its configuration cycle. If the DONE pin of a device is left unconnected, the device becomes active as soon as that device has been configured. Only devices supporting Express mode can be used to form an Express mode daisy chain. Figure 27: Express Mode Circuit Diagram ---- Table 16: Spartan/XL Data Stream Formats | Data Type | Serial Modes<br>(D0) | Express Mode<br>(D0-D7)<br>(Spartan-XL only) | |--------------------------------|------------------------|----------------------------------------------| | Fill Byte | 11111111b | FFFFh | | Preamble Code | 0010b | 11110010b | | Length Count | COUNT[23:0] | COUNT[23:0] <sup>(1)</sup> | | Fill Bits | 1111b | - | | Field Check<br>Code | - | 11010010b | | Start Field | 0b | 11111110b <sup>(2)</sup> | | Data Frame | DATA[n-1:0] | DATA[n-1:0] | | CRC or Constant<br>Field Check | xxxx (CRC)<br>or 0110b | 11010010b | | Extend Write<br>Cycle | - | FFD2FFFFFh | | Postamble | 01111111b | - | | Start-Up Bytes <sup>(3)</sup> | FFh | FFFFFFFFFF | #### Legend: | Unshaded | Once per bitstream | |----------|---------------------| | Light | Once per data frame | | Dark | Once per device | #### Notes: - 1. Not used by configuration logic. - 2. 111111111b for XCS40XL only. - 3. Development system may add more start-up bytes. A selection of CRC or non-CRC error checking is allowed by the bitstream generation software. The Spartan-XL family Express mode only supports non-CRC error checking. The non-CRC error checking tests for a designated end-of-frame field for each frame. For CRC error checking, the software calculates a running CRC and inserts a unique four-bit partial check at the end of each frame. The 11-bit CRC check of the last frame of an FPGA includes the last seven data bits. Detection of an error results in the suspension of data loading before DONE goes High, and the pulling down of the $\overline{\text{INIT}}$ pin. In Master serial mode, CCLK continues to operate externally. The user must detect $\overline{\text{INIT}}$ and initialize a new configuration by pulsing the $\overline{\text{PROGRAM}}$ pin Low or cycling $V_{CC}$ . # Cyclic Redundancy Check (CRC) for Configuration and Readback The Cyclic Redundancy Check is a method of error detection in data transmission applications. Generally, the transmitting system performs a calculation on the serial bitstream. The result of this calculation is tagged onto the data stream as additional check bits. The receiving system performs an identical calculation on the bitstream and compares the result with the received checksum. Each data frame of the configuration bitstream has four error bits at the end, as shown in Table 16. If a frame data error is detected during the loading of the FPGA, the configuration process with a potentially corrupted bitstream is terminated. The FPGA pulls the INIT pin Low and goes into a Wait state. 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 the state of the Mode pins, and is ready to start the configuration process. A master device waits up to an additional 300 $\mu s$ to make sure that any slaves in the optional daisy chain have seen that $\overline{INIT}$ is High. For more details on Configuration, refer to the Xilinx Application Note "FPGA Configuration Guidelines" (XAPP090). #### 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 Set/Reset (GSR) at the right time. #### **Start-Up Initiation** Two conditions have to be met in order for the start-up sequence to begin: - The chip's internal memory must be full, and - The configuration length count must be met, exactly. In all configuration modes except Express mode, Spartan/XL devices read the expected length count from the bitstream and store it in an internal register. The length count varies according to the number of devices and the composition of the daisy chain. Each device also counts the number of CCLKs during configuration. In Express mode, there is no length count. The start-up sequence for each device begins when the device has received its quota of configuration data. Wiring the DONE pins of several devices together delays start-up of all devices until all are fully configured. #### **Start-Up Events** The device can be programmed to control three start-up events. - The release of the open-drain DONE output - The termination of the Global Three-State and the change of configuration-related pins to the user function, activating all IOBs. - The termination of the Global Set/Reset initialization of all CLB and IOB storage elements. Figure 31 describes start-up timing in detail. The three events — DONE going High, the internal GSR being de-activated, and the user I/O going active — can all occur in any arbitrary sequence. This relative timing is selected by options in the bitstream generation software. Heavy lines in Figure 31 show the default timing. The thin lines indicate all other possible timing options. The start-up logic must be clocked until the "F" (Finished) state is reached. The default option, and the most practical one, is for DONE to go High first, disconnecting the configuration data source and avoiding any contention when the I/Os become active one clock later. GSR is then released another clock period later to make sure that user operation starts from stable internal conditions. This is the most common sequence, shown with heavy lines in Figure 31, but the designer can modify it to meet particular requirements. #### Start-Up Clock Normally, the start-up sequence is controlled by the internal device oscillator (CCLK), which is asynchronous to the system clock. As a configuration option, they can be triggered by an on-chip user net called UCLK. This user net can be accessed by placing the STARTUP library symbol, and the start-up modes are known as UCLK\_NOSYNC or UCLK\_SYNC. This allows the device to wake up in synchronism with the user system. #### **DONE Pin** Note that DONE is an open-drain output and does not go High unless an internal pull-up is activated or an external pull-up is attached. The internal pull-up is activated as the default by the bitstream generation software. The DONE pin can also be wire-ANDed with DONE pins of other FPGAs or with other external signals, and can then be used as input to the start-up control logic. This is called "Start-up Timing Synchronous to Done In" and is selected by either CCLK\_SYNC or UCLK\_SYNC. When DONE is not used as an input, the operation is called "Start-up Timing Not Synchronous to DONE In," and is selected by either CCLK\_NOSYNC or UCLK\_NOSYNC. Express mode configuration always uses either CCLK\_SYNC or UCLK\_SYNC timing, while the other configuration modes can use any of the four timing sequences. When the UCLK\_SYNC option is enabled, the user can externally hold the open-drain DONE output Low, and thus stall all further progress in the start-up sequence until DONE is released and has gone High. This option can be used to force synchronization of several FPGAs to a common user clock, or to guarantee that all devices are successfully configured before any I/Os go active. #### 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. Although readback can be performed while the device is operating, for best results and to freeze a known capture state, it is recommended that the clock inputs be stopped until readback is complete. Readback of Spartan-XL family Express mode bitstreams results in data that does not resemble the original bitstream, because the bitstream format differs from other modes. Spartan/XL FPGA 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, instantiate the READBACK library symbol and attach the appropriate pad symbols, as shown in Figure 32. After Readback has been initiated by a Low-to-High transition on RDBK.TRIG, 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. #### Readback Options Readback options are: Readback Capture, Readback Abort, and Clock Select. They are set with the bitstream generation software. ## **Readback Capture** When the Readback Capture option is selected, the data stream includes sampled values of CLB and IOB signals. The rising edge of RDBK.TRIG latches the inverted values of the four CLB outputs, the IOB output flip-flops and the input signals I1 and I2. Note that while the bits describing configuration (interconnect, function generators, and RAM content) are *not* inverted, the CLB and IOB output signals *are* inverted. RDBK.TRIG is located in the lower-left corner of the device. When the Readback Capture option is not selected, the values of the capture bits reflect the configuration data originally written to those memory locations. If the RAM capability of the CLBs is used, RAM data are available in Readback, since they directly overwrite the F and G function-table configuration of the CLB. Figure 32: Readback Example ## **Spartan Family Detailed Specifications** #### **Definition of Terms** In the following tables, some specifications may be designated as Advance or Preliminary. These terms are defined as follows: **Advance:** Initial estimates based on simulation and/or extrapolation from other speed grades, devices, or families. Values are subject to change. Use as estimates, not for production. Preliminary: Based on preliminary characterization. Further changes are not expected. Unmarked: Specifications not identified as either Advance or Preliminary are to be considered Final. Notwithstanding the definition of the above terms, all specifications are subject to change without notice. Except for pin-to-pin input and output parameters, the AC parameter delay specifications included in this document are derived from measuring internal test patterns. All specifications are representative of worst-case supply voltage and junction temperature conditions. The parameters included are common to popular designs and typical applications. ## Spartan Family Absolute Maximum Ratings(1) | Symbol | Description | Value | Units | | |------------------|----------------------------------------------------|------------------------------|-------------|----| | V <sub>CC</sub> | Supply voltage relative to GND | -0.5 to +7.0 | V | | | V <sub>IN</sub> | Input voltage relative to GND <sup>(2,3)</sup> | -0.5 to V <sub>CC</sub> +0.5 | V | | | V <sub>TS</sub> | Voltage applied to 3-state output <sup>(2,3)</sup> | -0.5 to V <sub>CC</sub> +0.5 | V | | | T <sub>STG</sub> | Storage temperature (ambient) | | -65 to +150 | °C | | T <sub>J</sub> | Junction temperature | Plastic packages | +125 | °C | #### Notes: - Stresses beyond those listed under Absolute Maximum Ratings may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those listed under Operating Conditions is not implied. Exposure to Absolute Maximum Ratings conditions for extended periods of time may affect device reliability. - 2. Maximum DC overshoot (above V<sub>CC</sub>) or undershoot (below GND) must be limited to either 0.5V or 10 mA, whichever is easier to achieve. - 3. Maximum AC (during transitions) conditions are as follows; the device pins may undershoot to -2.0V or overshoot to +7.0V, provided this overshoot or undershoot lasts no more than 11 ns with a forcing current no greater than 100 mA. - 4. For soldering guidelines, see the Package Information on the Xilinx website. ## **Spartan Family Recommended Operating Conditions** | Symbol | Description | | Min | Max | Units | |-----------------|---------------------------------------------------------------------------------------------|-------------|------|----------|----------| | V <sub>CC</sub> | Supply voltage relative to GND, T <sub>J</sub> = 0°C to +85°C | Commercial | 4.75 | 5.25 | V | | | Supply voltage relative to GND, $T_J = -40^{\circ}\text{C}$ to $+100^{\circ}\text{C}^{(1)}$ | Industrial | 4.5 | 5.5 | V | | V <sub>IH</sub> | High-level input voltage <sup>(2)</sup> | TTL inputs | 2.0 | $V_{CC}$ | V | | | | CMOS inputs | 70% | 100% | $V_{CC}$ | | V <sub>IL</sub> | Low-level input voltage <sup>(2)</sup> | TTL inputs | 0 | 8.0 | V | | | | CMOS inputs | 0 | 20% | $V_{CC}$ | | T <sub>IN</sub> | Input signal transition time | 1 | - | 250 | ns | #### Notes: - At junction temperatures above those listed as Recommended Operating Conditions, all delay parameters increase by 0.35% per °C. - 2. Input and output measurement thresholds are: 1.5V for TTL and 2.5V for CMOS. ## **Spartan Family CLB Switching Characteristic Guidelines** All devices are 100% functionally tested. Internal timing parameters are derived from measuring internal test patterns. Listed below are representative values. For more specific, more precise, and worst-case guaranteed data, use the values reported by the static timing analyzer (TRCE in the Xilinx Development System) and back-annotated to the simulation netlist. All timing parameters assume worst-case operating conditions (supply voltage and junction temperature). Values apply to all Spartan devices and expressed in nanoseconds unless otherwise noted. | | | Speed Grade | | | | | |--------------------|------------------------------------------------------------------|-------------|---------------------------|---------------|---------|-------| | | Decesiation - | - | 4 | -3 | | 1 | | Symbol | Description | Min | Max | Min | Max | Units | | Clocks | | | | | | | | T <sub>CH</sub> | Clock High time | 3.0 | - | 4.0 | - | ns | | $T_{CL}$ | Clock Low time | 3.0 | - | 4.0 | - | ns | | Combina | torial Delays | | 1 | 1 | 1 | 1 | | T <sub>ILO</sub> | F/G inputs to X/Y outputs | - | 1.2 | - | 1.6 | ns | | T <sub>IHO</sub> | F/G inputs via H to X/Y outputs | - | 2.0 | - | 2.7 | ns | | T <sub>HH1O</sub> | C inputs via H1 via H to X/Y outputs | - | 1.7 | - | 2.2 | ns | | CLB Fast | Carry Logic | | 1 | | 1 | | | T <sub>OPCY</sub> | Operand inputs (F1, F2, G1, G4) to C <sub>OUT</sub> | - | 1.7 | - | 2.1 | ns | | T <sub>ASCY</sub> | Add/Subtract input (F3) to C <sub>OUT</sub> | - | 2.8 | - | 3.7 | ns | | T <sub>INCY</sub> | Initialization inputs (F1, F3) to C <sub>OUT</sub> | - | 1.2 | - | 1.4 | ns | | T <sub>SUM</sub> | C <sub>IN</sub> through function generators to X/Y outputs | - | 2.0 | - | 2.6 | ns | | T <sub>BYP</sub> | C <sub>IN</sub> to C <sub>OUT</sub> , bypass function generators | - | 0.5 | - | 0.6 | ns | | Sequentia | al Delays | | | | | | | T <sub>CKO</sub> | Clock K to Flip-Flop outputs Q | - | 2.1 | - | 2.8 | ns | | Setup Tin | ne before Clock K | | | | | | | T <sub>ICK</sub> | F/G inputs | 1.8 | - | 2.4 | - | ns | | T <sub>IHCK</sub> | F/G inputs via H | 2.9 | - | 3.9 | - | ns | | T <sub>HH1CK</sub> | C inputs via H1 through H | 2.3 | - | 3.3 | - | ns | | T <sub>DICK</sub> | C inputs via DIN | 1.3 | - | 2.0 | - | ns | | T <sub>ECCK</sub> | C inputs via EC | 2.0 | - | 2.6 | - | ns | | T <sub>RCK</sub> | C inputs via S/R, going Low (inactive) | 2.5 | - | 4.0 | - | ns | | Hold Time | e after Clock K | | 1 | | 1 | | | | All Hold times, all devices | 0.0 | - | 0.0 | - | ns | | Set/Reset | Direct | | | | | | | T <sub>RPW</sub> | Width (High) | 3.0 | - | 4.0 | - | ns | | T <sub>RIO</sub> | Delay from C inputs via S/R, going High to Q | - | 3.0 | - | 4.0 | ns | | Global Se | et/Reset | | | | | | | $T_{MRW}$ | Minimum GSR pulse width | 11.5 | - | 13.5 | - | ns | | $T_{MRQ}$ | Delay from GSR input to any Q | See pa | ge 50 for T <sub>RI</sub> | RI values per | device. | | | F <sub>TOG</sub> | Toggle Frequency (MHz) (for export control purposes) | - | 166 | - | 125 | MHz | ## Spartan Family CLB RAM Synchronous (Edge-Triggered) Write Operation Guidelines All devices are 100% functionally tested. Internal timing parameters are derived from measuring internal test patterns. Listed below are representative values. For more specific, more precise, and worst-case guaranteed data, use the values reported by the static timing analyzer (TRCE in the Xilinx Development System) and back-annotated to the simulation netlist. All timing parameters assume worst-case operating conditions (supply voltage and junction temperature). Values apply to all Spartan devices and are expressed in nanoseconds unless otherwise noted. | | | - | Speed Grade | | | | | |-------------------|-------------------------------------------|---------------------|-------------|-----|------|-----|-------| | | | | -4 | | -3 | | | | Symbol | Single Port RAM | Size <sup>(1)</sup> | Min | Max | Min | Max | Units | | Write Ope | eration | | | | | | | | T <sub>WCS</sub> | Address write cycle time (clock K period) | 16x2 | 8.0 | - | 11.6 | - | ns | | T <sub>WCTS</sub> | | 32x1 | 8.0 | - | 11.6 | - | ns | | $T_{WPS}$ | Clock K pulse width (active edge) | 16x2 | 4.0 | - | 5.8 | - | ns | | $T_{WPTS}$ | | 32x1 | 4.0 | - | 5.8 | - | ns | | T <sub>ASS</sub> | Address setup time before clock K | 16x2 | 1.5 | - | 2.0 | - | ns | | T <sub>ASTS</sub> | | 32x1 | 1.5 | - | 2.0 | - | ns | | T <sub>AHS</sub> | Address hold time after clock K | 16x2 | 0.0 | - | 0.0 | - | ns | | T <sub>AHTS</sub> | | 32x1 | 0.0 | - | 0.0 | - | ns | | T <sub>DSS</sub> | DIN setup time before clock K | 16x2 | 1.5 | - | 2.7 | - | ns | | T <sub>DSTS</sub> | | 32x1 | 1.5 | - | 1.7 | - | ns | | T <sub>DHS</sub> | DIN hold time after clock K | 16x2 | 0.0 | - | 0.0 | - | ns | | T <sub>DHTS</sub> | | 32x1 | 0.0 | - | 0.0 | - | ns | | T <sub>WSS</sub> | WE setup time before clock K | 16x2 | 1.5 | - | 1.6 | - | ns | | T <sub>WSTS</sub> | | 32x1 | 1.5 | - | 1.6 | - | ns | | T <sub>WHS</sub> | WE hold time after clock K | 16x2 | 0.0 | - | 0.0 | - | ns | | T <sub>WHTS</sub> | | 32x1 | 0.0 | - | 0.0 | - | ns | | T <sub>WOS</sub> | Data valid after clock K | 16x2 | - | 6.5 | - | 7.9 | ns | | T <sub>WOTS</sub> | | 32x1 | - | 7.0 | - | 9.3 | ns | | Read Ope | ration | | | i. | | | 1 | | T <sub>RC</sub> | Address read cycle time | 16x2 | 2.6 | - | 2.6 | - | ns | | T <sub>RCT</sub> | | 32x1 | 3.8 | - | 3.8 | - | ns | | T <sub>ILO</sub> | Data valid after address change (no Write | 16x2 | - | 1.2 | - | 1.6 | ns | | T <sub>IHO</sub> | Enable) | 32x1 | - | 2.0 | - | 2.7 | ns | | T <sub>ICK</sub> | Address setup time before clock K | 16x2 | 1.8 | - | 2.4 | - | ns | | T <sub>IHCK</sub> | | 32x1 | 2.9 | - | 3.9 | - | ns | #### Notes: <sup>1.</sup> Timing for 16 x 1 RAM option is identical to 16 x 2 RAM timing. # Spartan Family CLB RAM Synchronous (Edge-Triggered) Write Operation Guidelines (continued) All devices are 100% functionally tested. Internal timing parameters are derived from measuring internal test patterns. Listed below are representative values. For more specific, more precise, and worst-case guaranteed data, use the values reported by the static timing analyzer (TRCE in the Xilinx Development System) and back-annotated to the simulation netlist. All timing parameters assume worst-case operating conditions (supply voltage and junction temperature). Values apply to all Spartan devices and are expressed in nanoseconds unless otherwise noted. ## **Dual-Port RAM Synchronous (Edge-Triggered) Write Operation Characteristics** | | | | -4 | | -3 | | | |-------------------|-------------------------------------------|---------------------|-----|-----|------|-----|-------| | Symbol | Dual Port RAM | Size <sup>(1)</sup> | Min | Max | Min | Max | Units | | Write Operation | | | | | | | | | T <sub>WCDS</sub> | Address write cycle time (clock K period) | 16x1 | 8.0 | - | 11.6 | - | ns | | T <sub>WPDS</sub> | Clock K pulse width (active edge) | 16x1 | 4.0 | - | 5.8 | - | ns | | T <sub>ASDS</sub> | Address setup time before clock K | 16x1 | 1.5 | - | 2.1 | - | ns | | T <sub>AHDS</sub> | Address hold time after clock K | 16x1 | 0 | - | 0 | - | ns | | T <sub>DSDS</sub> | DIN setup time before clock K | 16x1 | 1.5 | - | 1.6 | - | ns | | T <sub>DHDS</sub> | DIN hold time after clock K | 16x1 | 0 | - | 0 | - | ns | | T <sub>WSDS</sub> | WE setup time before clock K | 16x1 | 1.5 | - | 1.6 | - | ns | | T <sub>WHDS</sub> | WE hold time after clock K | 16x1 | 0 | - | 0 | - | ns | | T <sub>WODS</sub> | Data valid after clock K | 16x1 | - | 6.5 | - | 7.0 | ns | #### Notes: ## Spartan Family CLB RAM Synchronous (Edge-Triggered) Write Timing <sup>1.</sup> Read Operation timing for 16 x 1 dual-port RAM option is identical to 16 x 2 single-port RAM timing ## **Spartan Family Pin-to-Pin Input Parameter Guidelines** All devices are 100% functionally tested. Pin-to-pin timing parameters are derived from measuring external and internal test patterns and are guaranteed over worst-case oper- ating conditions (supply voltage and junction temperature). Listed below are representative values for typical pin locations and normal clock loading. ## Spartan Family Primary and Secondary Setup and Hold | | | | Speed | l Grade | | |-------------------------------------|-----------------------------------------|-------|-----------|-----------|-------| | | | | -4 | -3 | | | Symbol | <b>Description</b> Device | | Min | Min | Units | | Input Setup/H | old Times Using Primary Clock and IFF | | | | | | T <sub>PSUF</sub> /T <sub>PHF</sub> | No Delay | XCS05 | 1.2 / 1.7 | 1.8 / 2.5 | ns | | | | XCS10 | 1.0 / 2.3 | 1.5 / 3.4 | ns | | | | XCS20 | 0.8 / 2.7 | 1.2 / 4.0 | ns | | | | XCS30 | 0.6 / 3.0 | 0.9 / 4.5 | ns | | | | XCS40 | 0.4 / 3.5 | 0.6 / 5.2 | ns | | T <sub>PSU</sub> /T <sub>PH</sub> | With Delay | XCS05 | 4.3 / 0.0 | 6.0 / 0.0 | ns | | | | XCS10 | 4.3 / 0.0 | 6.0 / 0.0 | ns | | | | XCS20 | 4.3 / 0.0 | 6.0 / 0.0 | ns | | | | XCS30 | 4.3 / 0.0 | 6.0 / 0.0 | ns | | | | XCS40 | 5.3 / 0.0 | 6.8 / 0.0 | ns | | Input Setup/H | old Times Using Secondary Clock and IFF | | | | | | $T_{SSUF}/T_{SHF}$ | No Delay | XCS05 | 0.9 / 2.2 | 1.5 / 3.0 | ns | | | | XCS10 | 0.7 / 2.8 | 1.2 / 3.9 | ns | | | | XCS20 | 0.5 / 3.2 | 0.9 / 4.5 | ns | | | | XCS30 | 0.3 / 3.5 | 0.6 / 5.0 | ns | | | | XCS40 | 0.1 / 4.0 | 0.3 / 5.7 | ns | | T <sub>SSU</sub> /T <sub>SH</sub> | With Delay | XCS05 | 4.0 / 0.0 | 5.7 / 0.0 | ns | | | | XCS10 | 4.0 / 0.0 | 5.7 / 0.0 | ns | | | | XCS20 | 4.0 / 0.5 | 5.7 / 0.5 | ns | | | | XCS30 | 4.0 / 0.5 | 5.7 / 0.5 | ns | | | | XCS40 | 5.0 / 0.0 | 6.5 / 0.0 | ns | #### Notes: Setup time is measured with the fastest route and the lightest load. Hold time is measured using the furthest distance and a reference load of one clock pin per IOB/CLB. <sup>2.</sup> IFF = Input Flip-flop or Latch ## Spartan-XL Family Global Buffer Switching Characteristic Guidelines All devices are 100% functionally tested. Internal timing parameters are derived from measuring internal test patterns. Listed below are representative values where one global clock input drives one vertical clock line in each accessible column, and where all accessible IOB and CLB flip-flops are clocked by the global clock net. When fewer vertical clock lines are connected, the clock distribution is faster; when multiple clock lines per column are driven from the same global clock, the delay is longer. For more specific, more precise, and worst-case guaranteed data, reflecting the actual routing structure, use the values provided by the static timing analyzer (TRCE in the Xilinx Development System) and back-annotated to the simulation netlist. These path delays, provided as a guideline, have been extracted from the static timing analyzer report. All timing parameters assume worst-case operating conditions (supply voltage and junction temperature). | | | | Speed Grade | | | |------------------|-----------------------------------------|---------|-------------|-----|-------| | | | | -5 | -4 | | | Symbol | Description | Device | Max | Max | Units | | T <sub>GLS</sub> | From pad through buffer, to any clock K | XCS05XL | 1.4 | 1.5 | ns | | | | XCS10XL | 1.7 | 1.8 | ns | | | | XCS20XL | 2.0 | 2.1 | ns | | | | XCS30XL | 2.3 | 2.5 | ns | | | | XCS40XL | 2.6 | 2.8 | ns | ## **Pin Descriptions** There are three types of pins in the Spartan/XL devices: - · Permanently dedicated pins - User I/O pins that can have special functions - Unrestricted user-programmable I/O pins. Before and during configuration, all outputs not used for the configuration process are 3-stated with the I/O pull-up resistor network activated. After configuration, if an IOB is unused it is configured as an input with the I/O pull-up resistor network remaining activated. Any user I/O can be configured to drive the Global Set/Reset net GSR or the global three-state net GTS. See **Global Signals: GSR and GTS**, page 20 for more information. Device pins for Spartan/XL devices are described in Table 18. Some Spartan-XL devices are available in Pb-free package options. The Pb-free package options have the same pinouts as the standard package options. Table 18: Pin Descriptions | Pin Name | I/O<br>During<br>Config. | I/O After<br>Config. | Pin Description | |------------------------|--------------------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Permanently D | Dedicated P | ins | | | V <sub>CC</sub> | Х | Х | Eight or more (depending on package) connections to the nominal +5V supply voltage (+3.3V for Spartan-XL devices). All must be connected, and each must be decoupled with a 0.01 –0.1 $\mu$ F capacitor to Ground. | | GND | Х | Х | Eight or more (depending on package type) connections to Ground. All must be connected. | | CCLK | I or O | I | During configuration, Configuration Clock (CCLK) is an output in Master mode and is an input in Slave mode. After configuration, CCLK has a weak pull-up resistor and can be selected as the Readback Clock. There is no CCLK High or Low time restriction on Spartan/XL devices, except during Readback. See Violating the Maximum High and Low Time Specification for the Readback Clock, page 39 for an explanation of this exception. | | DONE | I/O | 0 | DONE is a bidirectional signal with an optional internal pull-up resistor. As an open-drain output, it indicates the completion of the configuration process. As an input, a Low level on DONE can be configured to delay the global logic initialization and the enabling of outputs. | | | | | The optional pull-up resistor is selected as an option in the program that creates the configuration bitstream. The resistor is included by default. | | PROGRAM | I | I | PROGRAM is an active Low input that forces the FPGA to clear its configuration memory. It is used to initiate a configuration cycle. When PROGRAM goes High, the FPGA finishes the current clear cycle and executes another complete clear cycle, before it goes into a WAIT state and releases INIT. | | | | | The PROGRAM pin has a permanent weak pull-up, so it need not be externally pulled up to VCC. | | MODE<br>(Spartan) | I | X | The Mode input(s) are sampled after INIT goes High to determine the configuration mode to be used. | | M0, M1<br>(Spartan-XL) | | | During configuration, these pins have a weak pull-up resistor. For the most popular configuration mode, Slave Serial, the mode pins can be left unconnected. For Master Serial mode, connect the Mode/M0 pin directly to system ground. | ## XCS05 and XCS05XL Device Pinouts | XCS05/XL | | | Bndry | |-----------------------------------------------------------|---------------------|-------|--------------------| | Pad Name | PC84 <sup>(4)</sup> | VQ100 | Scan | | I/O | P70 | P71 | 238 <sup>(3)</sup> | | I/O (D0 <sup>(2)</sup> , DIN) | P71 | P72 | 241 <sup>(3)</sup> | | I/O, SGCK4 <sup>(1)</sup> , GCK6 <sup>(2)</sup><br>(DOUT) | P72 | P73 | 244 <sup>(3)</sup> | | CCLK | P73 | P74 | - | | VCC | P74 | P75 | - | | O, TDO | P75 | P76 | 0 | | GND | P76 | P77 | - | | I/O | P77 | P78 | 2 | | I/O, PGCK4 <sup>(1)</sup> , GCK7 <sup>(2)</sup> | P78 | P79 | 5 | | I/O (CS1 <sup>(2)</sup> ) | P79 | P80 | 8 | | I/O | P80 | P81 | 11 | | I/O | P81 | P82 | 14 | | I/O | P82 | P83 | 17 | | I/O | - | P84 | 20 | | I/O | - | P85 | 23 | | I/O | P83 | P86 | 26 | | I/O | P84 | P87 | 29 | | GND | P1 | P88 | - | #### Notes: - 1. 5V Spartan family only - 2. 3V Spartan-XL family only - 3. The "PWRDWN" on the XCS05XL is not part of the Boundary Scan chain. For the XCS05XL, subtract 1 from all Boundary Scan numbers from GCK3 on (127 and higher). - 4. PC84 package discontinued by PDN2004-01 ## **XCS10 and XCS10XL Device Pinouts** | XCS10/XL<br>Pad Name | PC84 <sup>(4)</sup> | VQ100 | CS144 <sup>(2,4)</sup> | TQ144 | Bndry<br>Scan | |----------------------|---------------------|-------|------------------------|-------|---------------| | VCC | P2 | P89 | D7 | P128 | - | | I/O | P3 | P90 | A6 | P129 | 44 | | I/O | P4 | P91 | В6 | P130 | 47 | | I/O | - | P92 | C6 | P131 | 50 | | I/O | - | P93 | D6 | P132 | 53 | | I/O | P5 | P94 | A5 | P133 | 56 | | I/O | P6 | P95 | B5 | P134 | 59 | | I/O | - | - | C5 | P135 | 62 | | I/O | - | - | D5 | P136 | 65 | | GND | - | - | A4 | P137 | - | | I/O | P7 | P96 | B4 | P138 | 68 | | I/O | P8 | P97 | C4 | P139 | 71 | | I/O | - | - | A3 | P140 | 74 | | I/O | - | - | В3 | P141 | 77 | | I/O | P9 | P98 | C3 | P142 | 80 | ## **XCS10 and XCS10XL Device Pinouts** | ACSTU AND ACSTUAL Device Pinouis | | | | | | | | |----------------------------------|---------------------|-------|------------------------|-------|---------------|--|--| | XCS10/XL<br>Pad Name | PC84 <sup>(4)</sup> | VQ100 | CS144 <sup>(2,4)</sup> | TQ144 | Bndry<br>Scan | | | | I/O, | P10 | P99 | A2 | P143 | 83 | | | | SGCK1 <sup>(1)</sup> | | | | | | | | | GCK8 <sup>(2)</sup> | | | | | | | | | VCC | P11 | P100 | B2 | P144 | - | | | | GND | P12 | P1 | A1 | P1 | - | | | | I/O, | P13 | P2 | B1 | P2 | 86 | | | | PGCK1 <sup>(1)</sup> | | | | | | | | | GCK1 <sup>(2)</sup> | | | | | | | | | I/O | P14 | P3 | C2 | P3 | 89 | | | | I/O | - | - | C1 | P4 | 92 | | | | I/O | - | - | D4 | P5 | 95 | | | | I/O, TDI | P15 | P4 | D3 | P6 | 98 | | | | I/O, TCK | P16 | P5 | D2 | P7 | 101 | | | | GND | - | - | D1 | P8 | ı | | | | I/O | - | _ | E4 | P9 | 104 | | | | I/O | - | - | E3 | P10 | 107 | | | | I/O, TMS | P17 | P6 | E2 | P11 | 110 | | | | I/O | P18 | P7 | E1 | P12 | 113 | | | | I/O | - | - | F4 | P13 | 116 | | | | I/O | - | P8 | F3 | P14 | 119 | | | | I/O | P19 | P9 | F2 | P15 | 122 | | | | I/O | P20 | P10 | F1 | P16 | 125 | | | | GND | P21 | P11 | G2 | P17 | - | | | | VCC | P22 | P12 | G1 | P18 | - | | | | I/O | P23 | P13 | G3 | P19 | 128 | | | | I/O | P24 | P14 | G4 | P20 | 131 | | | | I/O | - | P15 | H1 | P21 | 134 | | | | I/O | - | - | H2 | P22 | 137 | | | | I/O | P25 | P16 | H3 | P23 | 140 | | | | I/O | P26 | P17 | H4 | P24 | 143 | | | | I/O | - | - | J1 | P25 | 146 | | | | I/O | - | - | J2 | P26 | 149 | | | | GND | - | - | J3 | P27 | - | | | | I/O | P27 | P18 | J4 | P28 | 152 | | | | I/O | - | P19 | K1 | P29 | 155 | | | | I/O | _ | - | K2 | P30 | 158 | | | | I/O | _ | _ | K3 | P31 | 161 | | | | I/O | P28 | P20 | L1 | P32 | 164 | | | | I/O, | P29 | P21 | L2 | P33 | 167 | | | | SGCK2 <sup>(1)</sup> | 1 23 | 1 - 1 | L | . 00 | 107 | | | | GCK2 <sup>(2)</sup> | | | | | | | | | Not | P30 | P22 | L3 | P34 | 170 | | | | Connect- | | | | | | | | | ed <sup>(1)</sup> | | | | | | | | | M1 <sup>(2)</sup> | | | | | | | | | GND | P31 | P23 | M1 | P35 | - | | | | $MODE^{(1)}$ , | P32 | P24 | M2 | P36 | 173 | | | | M0 <sup>(2)</sup> | | | | | | | | ## **XCS10 and XCS10XL Device Pinouts** | XCS10/XL<br>Pad Name | PC84 <sup>(4)</sup> | VQ100 | CS144 <sup>(2,4)</sup> | TQ144 | Bndry<br>Scan | |----------------------|---------------------|-------|------------------------|-------|---------------| | I/O | P80 | P81 | A10 | P116 | 17 | | GND | - | - | C9 | P118 | - | | I/O | - | - | B9 | P119 | 20 | | I/O | - | - | A9 | P120 | 23 | | I/O | P81 | P82 | D8 | P121 | 26 | | I/O | P82 | P83 | C8 | P122 | 29 | | I/O | - | P84 | B8 | P123 | 32 | | I/O | - | P85 | A8 | P124 | 35 | | I/O | P83 | P86 | B7 | P125 | 38 | | I/O | P84 | P87 | A7 | P126 | 41 | | GND | P1 | P88 | C7 | P127 | - | #### Notes: - 1. 5V Spartan family only - 2. 3V Spartan-XL family only - 3. The "PWRDWN" on the XCS10XL is not part of the Boundary Scan chain. For the XCS10XL, subtract 1 from all Boundary Scan numbers from GCK3 on (175 and higher). - 4. PC84 and CS144 packages discontinued by PDN2004-01 ## Additional XCS10/XL Package Pins | TQ144 | | | | | | | | | |--------|--------------------|--|--|--|--|--|--|--| | | Not Connected Pins | | | | | | | | | P117 | P117 | | | | | | | | | 5/5/97 | 5/5/97 | | | | | | | | | CS144 | | | | | | | | | |---------|--------------------|--|--|--|--|--|--|--| | | Not Connected Pins | | | | | | | | | D9 | D9 | | | | | | | | | 4/28/99 | 4/28/99 | | | | | | | | ## XCS20 and XCS20XL Device Pinouts | XCS20/XL | | | | | Bndry | |--------------------|-------|------------------------|-------|-------|-------| | Pad Name | VQ100 | CS144 <sup>(2,4)</sup> | TQ144 | PQ208 | Scan | | VCC | P89 | D7 | P128 | P183 | - | | I/O | P90 | A6 | P129 | P184 | 62 | | I/O | P91 | B6 | P130 | P185 | 65 | | I/O | P92 | C6 | P131 | P186 | 68 | | I/O | P93 | D6 | P132 | P187 | 71 | | I/O | - | - | - | P188 | 74 | | I/O | - | - | - | P189 | 77 | | I/O | P94 | A5 | P133 | P190 | 80 | | I/O | P95 | B5 | P134 | P191 | 83 | | VCC <sup>(2)</sup> | - | - | - | P192 | - | | I/O | - | C5 | P135 | P193 | 86 | | I/O | - | D5 | P136 | P194 | 89 | | GND | - | A4 | P137 | P195 | - | | I/O | - | - | - | P196 | 92 | | I/O | - | - | - | P197 | 95 | | I/O | - | - | - | P198 | 98 | | I/O | - | - | - | P199 | 101 | | I/O | P96 | B4 | P138 | P200 | 104 | | I/O | P97 | C4 | P139 | P201 | 107 | | I/O | - | А3 | P140 | P204 | 110 | | I/O | - | B3 | P141 | P205 | 113 | | I/O | P98 | C3 | P142 | P206 | 116 | ## **XCS20 and XCS20XL Device Pinouts** | XCS20/XL | V0400 | CS144 <sup>(2,4)</sup> | TO444 | DOGGG | Bndry | |-------------------------------------------------------|-------|------------------------|-------|-------|-------| | Pad Name | VQ100 | | TQ144 | PQ208 | Scan | | I/O,<br>SGCK1 <sup>(1)</sup> ,<br>GCK8 <sup>(2)</sup> | P99 | A2 | P143 | P207 | 119 | | VCC | P100 | B2 | P144 | P208 | - | | GND | P1 | A1 | P1 | P1 | - | | I/O,<br>PGCK1 <sup>(1)</sup> ,<br>GCK1 <sup>(2)</sup> | P2 | B1 | P2 | P2 | 122 | | I/O | P3 | C2 | P3 | P3 | 125 | | I/O | - | C1 | P4 | P4 | 128 | | I/O | - | D4 | P5 | P5 | 131 | | I/O, TDI | P4 | D3 | P6 | P6 | 134 | | I/O, TCK | P5 | D2 | P7 | P7 | 137 | | I/O | - | - | - | P8 | 140 | | I/O | - | - | - | P9 | 143 | | I/O | - | - | - | P10 | 146 | | I/O | - | - | - | P11 | 149 | | GND | - | D1 | P8 | P13 | - | | I/O | - | E4 | P9 | P14 | 152 | | I/O | - | E3 | P10 | P15 | 155 | | I/O, TMS | P6 | E2 | P11 | P16 | 158 | | I/O | P7 | E1 | P12 | P17 | 161 | | VCC <sup>(2)</sup> | - | - | - | P18 | - | | I/O | - | - | - | P19 | 164 | | I/O | - | - | - | P20 | 167 | ## Additional XCS20/XL Package Pins | | PQ208 | | | | | | | | |----------------------------------------------------------|----------------------------------------------------------------------|------|---------------------|---------------------|------|--|--|--| | | Not Connected Pins | | | | | | | | | P12 | P12 P18 <sup>(1)</sup> P33 <sup>(1)</sup> P39 P65 P71 <sup>(1)</sup> | | | | | | | | | P86 <sup>(1)</sup> | P92 | P111 | P121 <sup>(1)</sup> | P140 <sup>(1)</sup> | P144 | | | | | P165 P173 <sup>(1)</sup> P192 <sup>(1)</sup> P202 P203 - | | | | | | | | | | 9/16/98 | | | | | | | | | #### Notes: - 1. 5V Spartan family only - 2. 3V Spartan-XL family only - The "PWRDWN" on the XCS20XL is not part of the Boundary Scan chain. For the XCS20XL, subtract 1 from all Boundary Scan numbers from GCK3 on (247 and higher). - 4. CS144 package discontinued by PDN2004-01 ## XCS30 and XCS30XL Device Pinouts | XCS30/XL<br>Pad Name | VQ100 <sup>(5)</sup> | TQ144 | PQ208 | PQ240 | BG256 <sup>(5)</sup> | CS280 <sup>(2,5)</sup> | Bndry<br>Scan | |-------------------------------------------------|----------------------|-------|-------|-------|----------------------|------------------------|---------------| | VCC | P89 | P128 | P183 | P212 | VCC <sup>(4)</sup> | C10 | - | | I/O | P90 | P129 | P184 | P213 | C10 | D10 | 74 | | I/O | P91 | P130 | P185 | P214 | D10 | E10 | 77 | | I/O | P92 | P131 | P186 | P215 | A9 | A9 | 80 | | I/O | P93 | P132 | P187 | P216 | B9 | В9 | 83 | | I/O | - | - | P188 | P217 | C9 | C9 | 86 | | I/O | - | - | P189 | P218 | D9 | D9 | 89 | | I/O | P94 | P133 | P190 | P220 | A8 | A8 | 92 | | I/O | P95 | P134 | P191 | P221 | B8 | B8 | 95 | | VCC | - | - | P192 | P222 | VCC <sup>(4)</sup> | A7 | - | | I/O | - | - | - | P223 | A6 | B7 | 98 | | I/O | - | - | - | P224 | C7 | C7 | 101 | | I/O | - | P135 | P193 | P225 | B6 | D7 | 104 | | I/O | - | P136 | P194 | P226 | A5 | A6 | 107 | | GND | - | P137 | P195 | P227 | GND <sup>(4)</sup> | GND <sup>(4)</sup> | - | | I/O | - | - | P196 | P228 | C6 | B6 | 110 | | I/O | - | - | P197 | P229 | B5 | C6 | 113 | | I/O | - | - | P198 | P230 | A4 | D6 | 116 | | I/O | - | - | P199 | P231 | C5 | E6 | 119 | | I/O | P96 | P138 | P200 | P232 | B4 | <b>A</b> 5 | 122 | | I/O | P97 | P139 | P201 | P233 | A3 | C5 | 125 | | I/O | - | - | P202 | P234 | D5 | B4 | 128 | | I/O | - | - | P203 | P235 | C4 | C4 | 131 | | I/O | - | P140 | P204 | P236 | В3 | A3 | 134 | | I/O | - | P141 | P205 | P237 | B2 | A2 | 137 | | I/O | P98 | P142 | P206 | P238 | A2 | В3 | 140 | | I/O, SGCK1 <sup>(1)</sup> , GCK8 <sup>(2)</sup> | P99 | P143 | P207 | P239 | СЗ | B2 | 143 | | VCC | P100 | P144 | P208 | P240 | VCC <sup>(4)</sup> | A1 | - | | GND | P1 | P1 | P1 | P1 | GND <sup>(4)</sup> | GND <sup>(4)</sup> | - | | I/O, PGCK1 <sup>(1)</sup> , GCK1 <sup>(2)</sup> | P2 | P2 | P2 | P2 | B1 | C3 | 146 | | I/O | P3 | P3 | P3 | P3 | C2 | C2 | 149 | | I/O | - | P4 | P4 | P4 | D2 | B1 | 152 | ## XCS30 and XCS30XL Device Pinouts (Continued) | XCS30/XL<br>Pad Name | VQ100 <sup>(5)</sup> | TQ144 | PQ208 | PQ240 | BG256 <sup>(5)</sup> | CS280 <sup>(2,5)</sup> | Bndry<br>Scan | |-------------------------------------------------|----------------------|-------|-------|-------|----------------------|------------------------|--------------------| | I/O | - | - | P85 | P97 | U12 | T11 | 382 <sup>(3)</sup> | | I/O | - | - | - | P99 | V13 | U12 | 385 <sup>(3)</sup> | | I/O | - | - | - | P100 | Y14 | T12 | 388 (3) | | VCC | - | - | P86 | P101 | VCC <sup>(4)</sup> | W13 | - | | I/O | P43 | P60 | P87 | P102 | Y15 | V13 | 391 <sup>(3)</sup> | | I/O | P44 | P61 | P88 | P103 | V14 | U13 | 394 <sup>(3)</sup> | | I/O | - | P62 | P89 | P104 | W15 | T13 | 397 <sup>(3)</sup> | | I/O | - | P63 | P90 | P105 | Y16 | W14 | 400 (3) | | GND | - | P64 | P91 | P106 | GND <sup>(4)</sup> | GND <sup>(4)</sup> | - | | I/O | - | - | - | P107 | V15 | V14 | 403 (3) | | I/O | - | - | P92 | P108 | W16 | U14 | 406 <sup>(3)</sup> | | I/O | - | - | P93 | P109 | Y17 | T14 | 409 (3) | | I/O | - | - | P94 | P110 | V16 | R14 | 412 <sup>(3)</sup> | | I/O | - | - | P95 | P111 | W17 | W15 | 415 <sup>(3)</sup> | | I/O | - | - | P96 | P112 | Y18 | U15 | 418 <sup>(3)</sup> | | I/O | P45 | P65 | P97 | P113 | U16 | V16 | 421 <sup>(3)</sup> | | I/O | P46 | P66 | P98 | P114 | V17 | U16 | 424 (3) | | I/O | - | P67 | P99 | P115 | W18 | W17 | 427 (3) | | I/O | - | P68 | P100 | P116 | Y19 | W18 | 430 (3) | | I/O | P47 | P69 | P101 | P117 | V18 | V17 | 433 (3) | | I/O, SGCK3 <sup>(1)</sup> , GCK4 <sup>(2)</sup> | P48 | P70 | P102 | P118 | W19 | V18 | 436 <sup>(3)</sup> | | GND | P49 | P71 | P103 | P119 | GND <sup>(4)</sup> | GND <sup>(4)</sup> | - | | DONE | P50 | P72 | P104 | P120 | Y20 | W19 | - | | VCC | P51 | P73 | P105 | P121 | VCC <sup>(4)</sup> | U17 | - | | PROGRAM | P52 | P74 | P106 | P122 | V19 | U18 | - | | I/O (D7 <sup>(2)</sup> ) | P53 | P75 | P107 | P123 | U19 | V19 | 439 (3) | | I/O, PGCK3 <sup>(1)</sup> , GCK5 <sup>(2)</sup> | P54 | P76 | P108 | P124 | U18 | U19 | 442 (3) | | I/O | - | P77 | P109 | P125 | T17 | T16 | 445 <sup>(3)</sup> | | I/O | - | P78 | P110 | P126 | V20 | T17 | 448 (3) | | I/O | - | - | - | P127 | U20 | T18 | 451 <sup>(3)</sup> | | I/O | - | - | P111 | P128 | T18 | T19 | 454 <sup>(3)</sup> | | I/O (D6 <sup>(2)</sup> ) | P55 | P79 | P112 | P129 | T19 | R16 | 457 <sup>(3)</sup> | | I/O | P56 | P80 | P113 | P130 | T20 | R19 | 460 <sup>(3)</sup> | | I/O | - | - | P114 | P131 | R18 | P15 | 463 <sup>(3)</sup> | | I/O | - | - | P115 | P132 | R19 | P17 | 466 <sup>(3)</sup> | | I/O | - | - | P116 | P133 | R20 | P18 | 469 <sup>(3)</sup> | | I/O | - | - | P117 | P134 | P18 | P16 | 472 <sup>(3)</sup> | | GND | - | P81 | P118 | P135 | GND <sup>(4)</sup> | GND <sup>(4)</sup> | - | | I/O | - | - | - | P136 | P20 | P19 | 475 <sup>(3)</sup> | | I/O | - | - | - | P137 | N18 | N17 | 478 <sup>(3)</sup> | | I/O | - | P82 | P119 | P138 | N19 | N18 | 481 <sup>(3)</sup> | | I/O | - | P83 | P120 | P139 | N20 | N19 | 484 (3) | | VCC | - | - | P121 | P140 | VCC <sup>(4)</sup> | N16 | - | | I/O (D5 <sup>(2)</sup> ) | P57 | P84 | P122 | P141 | M17 | M19 | 487 <sup>(3)</sup> | | I/O | P58 | P85 | P123 | P142 | M18 | M17 | 490 (3) | ## **XCS40 and XCS40XL Device Pinouts** | XC540 and | | | | | | |-----------------------------------------------|-------|-------|--------------------|------------------------|--------------------| | XCS40/XL<br>Pad Name | PQ208 | PQ240 | BG256 | CS280 <sup>(2,5)</sup> | Bndry<br>Scan | | I/O | P90 | P105 | Y16 | W14 | 466 <sup>(3)</sup> | | GND | P91 | P106 | GND <sup>(4)</sup> | GND <sup>(4)</sup> | - | | I/O | - | P107 | V15 | V14 | 469 <sup>(3)</sup> | | I/O | P92 | P108 | W16 | U14 | 472 <sup>(3)</sup> | | I/O | P93 | P109 | Y17 | T14 | 475 <sup>(3)</sup> | | I/O | P94 | P110 | V16 | R14 | 478 <sup>(3)</sup> | | I/O | P95 | P111 | W17 | W15 | 481 <sup>(3)</sup> | | I/O | P96 | P112 | Y18 | U15 | 484 (3) | | I/O | - | - | - | T15 | 487 <sup>(3)</sup> | | I/O | - | - | - | W16 | 490 (3) | | I/O | P97 | P113 | U16 | V16 | 493 (3) | | I/O | P98 | P114 | V17 | U16 | 496 <sup>(3)</sup> | | I/O | P99 | P115 | W18 | W17 | 499 (3) | | I/O | P100 | P116 | Y19 | W18 | 502 <sup>(3)</sup> | | I/O | P101 | P117 | V18 | V17 | 505 <sup>(3)</sup> | | I/O, | P102 | P118 | W19 | V18 | 508 <sup>(3)</sup> | | SGCK3 <sup>(1)</sup> , | | | | | | | GCK4 <sup>(2)</sup> | | | | | | | GND | P103 | P119 | GND <sup>(4)</sup> | GND <sup>(4)</sup> | - | | DONE | P104 | P120 | Y20 | W19 | - | | VCC | P105 | P121 | VCC <sup>(4)</sup> | VCC <sup>(4)</sup> | - | | PROGRAM | P106 | P122 | V19 | U18 | - | | I/O (D7 <sup>(2)</sup> ) | P107 | P123 | U19 | V19 | 511 <sup>(3)</sup> | | I/O, | P108 | P124 | U18 | U19 | 514 <sup>(3)</sup> | | PGCK3 <sup>(1)</sup> ,<br>GCK5 <sup>(2)</sup> | | | | | | | I/O | P109 | P125 | T17 | T16 | 517 <sup>(3)</sup> | | I/O | P110 | P126 | V20 | T17 | 520 <sup>(3)</sup> | | I/O | - | P127 | U20 | T18 | 523 <sup>(3)</sup> | | I/O | P111 | P128 | T18 | T19 | 526 <sup>(3)</sup> | | I/O | _ | - | - | R15 | 529 <sup>(3)</sup> | | I/O | - | - | - | R17 | 523 <sup>(3)</sup> | | I/O (D6 <sup>(2)</sup> ) | P112 | P129 | T19 | R16 | 535 <sup>(3)</sup> | | I/O | P113 | P130 | T20 | R19 | 538 <sup>(3)</sup> | | I/O | P114 | P131 | R18 | P15 | 541 <sup>(3)</sup> | | I/O | P115 | P132 | R19 | P17 | 544 (3) | | I/O | P116 | P133 | R20 | P18 | 547 <sup>(3)</sup> | | I/O | P117 | P134 | P18 | P16 | 550 <sup>(3)</sup> | | GND | P118 | P135 | GND <sup>(4)</sup> | GND <sup>(4)</sup> | - | | I/O | | P136 | P20 | P19 | 553 <sup>(3)</sup> | | I/O | _ | P137 | N18 | N17 | 556 <sup>(3)</sup> | | I/O | P119 | P138 | N19 | N18 | 559 <sup>(3)</sup> | | I/O | P120 | P139 | N20 | N19 | 562 <sup>(3)</sup> | | VCC | P121 | P140 | VCC <sup>(4)</sup> | VCC <sup>(4)</sup> | 502 ( ) | | I/O (D5 <sup>(2)</sup> ) | P122 | P140 | M17 | M19 | 565 <sup>(3)</sup> | | I/O (D3(=/) | P123 | P141 | M18 | M17 | 568 <sup>(3)</sup> | | "0 | 1 123 | 1 142 | IVI I O | IVI I / | JU0 (°) | ## XCS40 and XCS40XL Device Pinouts | XCS40/XL<br>Pad Name | PQ208 | PQ240 | BG256 | CS280 <sup>(2,5)</sup> | Bndry<br>Scan | |-----------------------------------------------------------------|-------|-------|--------------------|------------------------|--------------------| | I/O | - | - | - | M18 | 571 <sup>(3)</sup> | | I/O | - | - | M19 | M16 | 574 <sup>(3)</sup> | | I/O | P124 | P144 | M20 | L19 | 577 <sup>(3)</sup> | | I/O | P125 | P145 | L19 | L18 | 580 <sup>(3)</sup> | | I/O | P126 | P146 | L18 | L17 | 583 <sup>(3)</sup> | | I/O | P127 | P147 | L20 | L16 | 586 <sup>(3)</sup> | | I/O (D4 <sup>(2)</sup> ) | P128 | P148 | K20 | K19 | 589 <sup>(3)</sup> | | I/O | P129 | P149 | K19 | K18 | 592 <sup>(3)</sup> | | VCC | P130 | P150 | VCC <sup>(4)</sup> | VCC <sup>(4)</sup> | - | | GND | P131 | P151 | GND <sup>(4)</sup> | GND <sup>(4)</sup> | - | | I/O (D3 <sup>(2)</sup> ) | P132 | P152 | K18 | K16 | 595 <sup>(3)</sup> | | I/O | P133 | P153 | K17 | K15 | 598 <sup>(3)</sup> | | I/O | P134 | P154 | J20 | J19 | 601 <sup>(3)</sup> | | I/O | P135 | P155 | J19 | J18 | 604 <sup>(3)</sup> | | I/O | P136 | P156 | J18 | J17 | 607 <sup>(3)</sup> | | I/O | P137 | P157 | J17 | J16 | 610 <sup>(3)</sup> | | I/O | - | - | H20 | H19 | 613 <sup>(3)</sup> | | I/O | - | - | - | H18 | 616 <sup>(3)</sup> | | I/O (D2 <sup>(2)</sup> ) | P138 | P159 | H19 | H17 | 619 <sup>(3)</sup> | | I/O | P139 | P160 | H18 | H16 | 622 <sup>(3)</sup> | | VCC | P140 | P161 | VCC <sup>(4)</sup> | VCC <sup>(4)</sup> | - | | I/O | P141 | P162 | G19 | G18 | 625 <sup>(3)</sup> | | I/O | P142 | P163 | F20 | G17 | 628 <sup>(3)</sup> | | I/O | - | P164 | G18 | G16 | 631 <sup>(3)</sup> | | I/O | - | P165 | F19 | F19 | 634 <sup>(3)</sup> | | GND | P143 | P166 | GND <sup>(4)</sup> | GND <sup>(4)</sup> | - | | I/O | - | P167 | F18 | F18 | 637 <sup>(3)</sup> | | I/O | P144 | P168 | E19 | F17 | 640 <sup>(3)</sup> | | I/O | P145 | P169 | D20 | F16 | 643 <sup>(3)</sup> | | I/O | P146 | P170 | E18 | F15 | 646 <sup>(3)</sup> | | I/O | P147 | P171 | D19 | E19 | 649 <sup>(3)</sup> | | I/O | P148 | P172 | C20 | E17 | 652 <sup>(3)</sup> | | I/O (D1 <sup>(2)</sup> ) | P149 | P173 | E17 | E16 | 655 <sup>(3)</sup> | | I/O | P150 | P174 | D18 | D19 | 658 <sup>(3)</sup> | | I/O | - | - | - | D18 | 661 <sup>(3)</sup> | | I/O | - | - | - | D17 | 664 <sup>(3)</sup> | | I/O | P151 | P175 | C19 | C19 | 667 <sup>(3)</sup> | | I/O | P152 | P176 | B20 | B19 | 670 <sup>(3)</sup> | | I/O (D0 <sup>(2)</sup> ,<br>DIN) | P153 | P177 | C18 | C18 | 673 <sup>(3)</sup> | | I/O,<br>SGCK4 <sup>(1)</sup> ,<br>GCK6 <sup>(2)</sup><br>(DOUT) | P154 | P178 | B19 | B18 | 676 <sup>(3)</sup> | | CCLK | P155 | P179 | A20 | A19 | - | | VCC | P156 | P180 | VCC <sup>(4)</sup> | VCC <sup>(4)</sup> | - | ## XCS40 and XCS40XL Device Pinouts | XCS40/XL | | | | 00000(2 F) | Bndry | | |-------------------------------------------------------|-------|-------|--------------------|------------------------|-------|--| | Pad Name | PQ208 | PQ240 | BG256 | CS280 <sup>(2,5)</sup> | Scan | | | O, TDO | P157 | P181 | A19 | B17 | 0 | | | GND | P158 | P182 | GND <sup>(4)</sup> | GND <sup>(4)</sup> | - | | | I/O | P159 | P183 | B18 | A18 | 2 | | | I/O,<br>PGCK4 <sup>(1)</sup> ,<br>GCK7 <sup>(2)</sup> | P160 | P184 | B17 | A17 | 5 | | | I/O | P161 | P185 | C17 | D16 | 8 | | | I/O | P162 | P186 | D16 | C16 | 11 | | | I/O (CS1 <sup>(2)</sup> ) | P163 | P187 | A18 | B16 | 14 | | | I/O | P164 | P188 | A17 | A16 | 17 | | | I/O | - | - | - | E15 | 20 | | | I/O | - | - | - | C15 | 23 | | | I/O | P165 | P189 | C16 | D15 | 26 | | | I/O | - | P190 | B16 | A15 | 29 | | | I/O | P166 | P191 | A16 | E14 | 32 | | | I/O | P167 | P192 | C15 | C14 | 35 | | | I/O | P168 | P193 | B15 | B14 | 38 | | | I/O | P169 | P194 | A15 | D14 | 41 | | | GND | P170 | P196 | GND <sup>(4)</sup> | GND <sup>(4)</sup> | - | | | I/O | P171 | P197 | B14 | A14 | 44 | | | I/O | P172 | P198 | A14 | C13 | 47 | | | I/O | - | P199 | C13 | B13 | 50 | | | I/O | - | P200 | B13 | A13 | 53 | | | VCC | P173 | P201 | VCC <sup>(4)</sup> | VCC <sup>(4)</sup> | - | | | I/O | - | - | A13 | A12 | 56 | | | I/O | - | - | D12 | C12 | 59 | | | I/O | P174 | P202 | C12 | B12 | 62 | | | I/O | P175 | P203 | B12 | D12 | 65 | | | I/O | P176 | P205 | A12 | A11 | 68 | | | I/O | P177 | P206 | B11 | B11 | 71 | | | I/O | P178 | P207 | C11 | C11 | 74 | | | I/O | P179 | P208 | A11 | D11 | 77 | | | I/O | P180 | P209 | A10 | A10 | 80 | | | I/O | P181 | P210 | B10 | B10 | 83 | | | GND | P182 | P211 | GND <sup>(4)</sup> | GND <sup>(4)</sup> | - | | | 2/8/00 | • | • | • | • | | | #### Notes: - 1. 5V Spartan family only - 2. 3V Spartan-XL family only - 3. The "PWRDWN" on the XCS40XL is not part of the Boundary Scan chain. For the XCS40XL, subtract 1 from all Boundary Scan numbers from GCK3 on (343 and higher). - 4. Pads labeled $\mathrm{GND^{(4)}}$ or $\mathrm{V_{CC}^{(4)}}$ are internally bonded to Ground or $\mathrm{V_{CC}}$ planes within the package. - CS280 package discontinued by <u>PDN2004-01</u> ## Additional XCS40/XL Package Pins #### **PQ240** | | GND Pins | | | | | | | | | |------|--------------------|-----|-----|------|------|--|--|--|--| | P22 | P37 | P83 | P98 | P143 | P158 | | | | | | P204 | P219 | - | | | - | | | | | | | Not Connected Pins | | | | | | | | | | P195 | - | - | - | - | - | | | | | 2/12/98 #### **BG256** | VCC Pins | | | | | | | | | |----------|----------|-----|-----|-----|-----|--|--|--| | C14 | D6 | D7 | D11 | D14 | D15 | | | | | E20 | F1 | F4 | F17 | G4 | G17 | | | | | K4 | L17 | P4 | P17 | P19 | R2 | | | | | R4 | R17 | U6 | U7 | U10 | U14 | | | | | U15 | V7 | W20 | - | - | - | | | | | | GND Pins | | | | | | | | | A1 | B7 | D4 | D8 | D13 | D17 | | | | | G20 | H4 | H17 | N3 | N4 | N17 | | | | | U4 | U8 | U13 | U17 | W14 | - | | | | 6/17/97 #### **CS280** | VCC Pins | | | | | | | | | |----------|----------|-----|-----|-----|-----|--|--|--| | A1 | A7 | B5 | B15 | C10 | C17 | | | | | D13 | E3 | E18 | G1 | G19 | K2 | | | | | K17 | M4 | N16 | R3 | R18 | T7 | | | | | U3 | U10 | U17 | V5 | V15 | W13 | | | | | | GND Pins | | | | | | | | | E5 | E7 | E8 | E9 | E11 | E12 | | | | | E13 | G5 | G15 | H5 | H15 | J5 | | | | | J15 | L5 | L15 | M5 | M15 | N5 | | | | | N15 | R7 | R8 | R9 | R11 | R12 | | | | | R13 | - | - | - | - | - | | | | 5/19/99 Table 20: User I/O Chart for Spartan/XL FPGAs | | Max | Package Type | | | | | | | | | |---------|-----|---------------------|----------------------|----------------------|--------------------|--------------------|--------------------|----------------------|----------------------|--| | Device | I/O | PC84 <sup>(1)</sup> | VQ100 <sup>(1)</sup> | CS144 <sup>(1)</sup> | TQ144 | PQ208 | PQ240 | BG256 <sup>(1)</sup> | CS280 <sup>(1)</sup> | | | XCS05 | 80 | 61 <sup>(1)</sup> | 77 | - | - | - | - | - | - | | | XCS10 | 112 | 61 <sup>(1)</sup> | 77 | - | 112 | - | - | - | - | | | XCS20 | 160 | - | 77 | - | 113 | 160 | - | - | - | | | XCS30 | 192 | - | 77 <sup>(1)</sup> | - | 113 | 169 | 192 | 192 <sup>(1)</sup> | - | | | XCS40 | 224 | - | - | - | - | 169 | 192 | 205 | - | | | XCS05XL | 80 | 61 <sup>(1)</sup> | 77 <sup>(2)</sup> | - | - | - | - | - | - | | | XCS10XL | 112 | 61 <sup>(1)</sup> | 77 <sup>(2)</sup> | 112 <sup>(1)</sup> | 112 <sup>(2)</sup> | - | - | - | - | | | XCS20XL | 160 | - | 77 <sup>(2)</sup> | 113 <sup>(1)</sup> | 113 <sup>(2)</sup> | 160 <sup>(2)</sup> | - | - | - | | | XCS30XL | 192 | - | 77 <sup>(2)</sup> | - | 113 <sup>(2)</sup> | 169 <sup>(2)</sup> | 192 <sup>(2)</sup> | 192 <sup>(2)</sup> | 192 <sup>(1)</sup> | | | XCS40XL | 224 | - | - | - | - | 169 <sup>(2)</sup> | 192 <sup>(2)</sup> | 205 <sup>(2)</sup> | 224 <sup>(1)</sup> | | | 6/25/08 | | • | • | | | • | | • | | | #### 0/23/00 #### Notes: - PC84, CS144, and CS280 packages, and VQ100 and BG256 packages for XCS30 only, discontinued by PDN2004-01 - 2. These Spartan-XL devices are available in Pb-free package options. The Pb-free packages insert a "G" in the package code. Contact Xilinx for availability. ## **Ordering Information** BG = Ball Grid Array VQ = Very Thin Quad Flat Pack BGG = Ball Grid Array (Pb-free) VQG = Very Thin Quad Flat Pack (Pb-free) PC = Plastic Lead Chip Carrier TQ = Thin Quad Flat Pack PQ = Plastic Quad Flat Pack TQG = Thin Quad Flat Pack (Pb-free)