# E·XFL



Welcome to E-XFL.COM

#### Understanding <u>Embedded - FPGAs (Field</u> <u>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                 | Active                                                        |
|--------------------------------|---------------------------------------------------------------|
| Number of LABs/CLBs            | 1164                                                          |
| Number of Logic Elements/Cells | 10476                                                         |
| Total RAM Bits                 | 368640                                                        |
| Number of I/O                  | 66                                                            |
| Number of Gates                | 500000                                                        |
| Voltage - Supply               | 1.14V ~ 1.26V                                                 |
| Mounting Type                  | Surface Mount                                                 |
| Operating Temperature          | -40°C ~ 100°C (TJ)                                            |
| Package / Case                 | 100-TQFP                                                      |
| Supplier Device Package        | 100-VQFP (14x14)                                              |
| Purchase URL                   | https://www.e-xfl.com/product-detail/xilinx/xc3s500e-4vqg100i |
|                                |                                                               |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

# Configuration

Spartan-3E FPGAs are programmed by loading configuration data into robust, reprogrammable, static CMOS configuration latches (CCLs) that collectively control all functional elements and routing resources. The FPGA's configuration data is stored externally in a PROM or some other non-volatile medium, either on or off the board. After applying power, the configuration data is written to the FPGA using any of seven different modes:

- Master Serial from a Xilinx Platform Flash PROM
- Serial Peripheral Interface (SPI) from an industry-standard SPI serial Flash
- Byte Peripheral Interface (BPI) Up or Down from an industry-standard x8 or x8/x16 parallel NOR Flash
- Slave Serial, typically downloaded from a processor
- Slave Parallel, typically downloaded from a processor
- Boundary Scan (JTAG), typically downloaded from a processor or system tester.

Furthermore, Spartan-3E FPGAs support MultiBoot configuration, allowing two or more FPGA configuration bitstreams to be stored in a single parallel NOR Flash. The FPGA application controls which configuration to load next and when to load it.

# I/O Capabilities

The Spartan-3E FPGA SelectIO interface supports many popular single-ended and differential standards. Table 2 shows the number of user I/Os as well as the number of differential I/O pairs available for each device/package combination.

Spartan-3E FPGAs support the following single-ended standards:

- 3.3V low-voltage TTL (LVTTL)
- Low-voltage CMOS (LVCMOS) at 3.3V, 2.5V, 1.8V, 1.5V, or 1.2V
- 3V PCI at 33 MHz, and in some devices, <u>66 MHz</u>
- HSTL I and III at 1.8V, commonly used in memory applications
- SSTL I at 1.8V and 2.5V, commonly used for memory applications

Spartan-3E FPGAs support the following differential standards:

- LVDS
- Bus LVDS
- mini-LVDS
- RSDS
- Differential HSTL (1.8V, Types I and III)
- Differential SSTL (2.5V and 1.8V, Type I)
- 2.5V LVPECL inputs

| Package                | VQ1<br>VQG                      | 00<br>100        | CP<br>CPC         | 132<br>3132      | TQ<br>TQC          | 144<br>6144      | PQ:<br>PQC         | 208<br>6208      | FT:<br>FTG         | 256<br>1256      | FG<br>FGC          | 320<br>3320       | FG<br>FGC          | 400<br>6400        | FG4<br>FGG         | 484<br>i484        |
|------------------------|---------------------------------|------------------|-------------------|------------------|--------------------|------------------|--------------------|------------------|--------------------|------------------|--------------------|-------------------|--------------------|--------------------|--------------------|--------------------|
| Footprint<br>Size (mm) | 16 x                            | 16               | 8                 | x 8              | 22 >               | c 22             | 30.5 >             | c 30.5           | 17 :               | k 17             | 19 3               | c 19              | 21 :               | x 21               | 23 >               | x 23               |
| Device                 | User                            | Diff             | User              | Diff             | User               | Diff             | User               | Diff             | User               | Diff             | User               | Diff              | User               | Diff               | User               | Diff               |
| XC3S100E               | <b>66<sup>(2)</sup></b><br>9(7) | <b>30</b><br>(2) | <b>83</b><br>(11) | <b>35</b><br>(2) | <b>108</b><br>(28) | <b>40</b><br>(4) | -                  | -                | -                  | -                | -                  | -                 | -                  | -                  | -                  | -                  |
| XC3S250E               | <b>66</b><br>(7)                | <b>30</b><br>(2) | <b>92</b><br>(7)  | <b>41</b><br>(2) | <b>108</b><br>(28) | <b>40</b><br>(4) | <b>158</b><br>(32) | <b>65</b><br>(5) | <b>172</b><br>(40) | <b>68</b><br>(8) | -                  | -                 | -                  | -                  | -                  | -                  |
| XC3S500E               | <b>66</b> <sup>(3)</sup><br>(7) | <b>30</b><br>(2) | <b>92</b><br>(7)  | <b>41</b><br>(2) | -                  | -                | <b>158</b><br>(32) | <b>65</b><br>(5) | <b>190</b><br>(41) | <b>77</b><br>(8) | <b>232</b><br>(56) | <b>92</b><br>(12) | -                  | -                  | -                  | -                  |
| XC3S1200E              | -                               | -                | -                 | -                | -                  | -                | -                  | -                | <b>190</b><br>(40) | <b>77</b><br>(8) | <b>250</b><br>(56) | <b>99</b><br>(12) | <b>304</b><br>(72) | <b>124</b><br>(20) | -                  | -                  |
| XC3S1600E              | -                               | -                | -                 | -                | -                  | -                | -                  | -                | -                  | -                | <b>250</b><br>(56) | <b>99</b><br>(12) | <b>304</b><br>(72) | <b>124</b><br>(20) | <b>376</b><br>(82) | <b>156</b><br>(21) |

# Table 2: Available User I/Os and Differential (Diff) I/O Pairs

#### Notes:

1. All Spartan-3E devices provided in the same package are pin-compatible as further described in Module 4, Pinout Descriptions.

2. The number shown in **bold** indicates the maximum number of I/O and input-only pins. The number shown in (*italics*) indicates the number of input-only pins.

3. The XC3S500E is available in the VQG100 Pb-free package and not the standard VQ100. The VQG100 and VQ100 pin-outs are identical and general references to the VQ100 will apply to the XC3S500E.

**Xilinx Alerts** 



# Spartan-3 FPGA Family: Functional Description

Create a Xilinx user account and sign up to receive

the associated user guides are updated.

https://secure.xilinx.com/webreg/register.do

Spartan-3E FPGA Starter Kit

various design examples and the user guide.

http://www.xilinx.com/s3estarter

Sign Up for Alerts on Xilinx.com

?group=myprofile&languageID=1

automatic e-mail notification whenever this data sheet or

For specific hardware examples, please see the Spartan-3E

UG230: Spartan-3E FPGA Starter Kit User Guide

FPGA Starter Kit board web page, which has links to

Spartan-3E FPGA Starter Kit Board page

DS312 (4.0) October 29, 2012

## **Product Specification**

# **Design Documentation Available**

The functionality of the Spartan®-3E FPGA family is now described and updated in the following documents. The topics covered in each guide are listed below.

- <u>UG331</u>: Spartan-3 Generation FPGA User Guide
  - Clocking Resources
  - Digital Clock Managers (DCMs)
  - Block RAM
  - Configurable Logic Blocks (CLBs)
    - Distributed RAM
    - SRL16 Shift Registers
    - Carry and Arithmetic Logic
  - I/O Resources
  - Embedded Multiplier Blocks
  - Programmable Interconnect
  - ISE® Design Tools
  - IP Cores
  - Embedded Processing and Control Solutions
  - Pin Types and Package Overview
  - Package Drawings
  - Powering FPGAs
  - Power Management
- UG332: Spartan-3 Generation Configuration User Guide
  - Configuration Overview
    - Configuration Pins and Behavior
    - Bitstream Sizes
  - Detailed Descriptions by Mode
    - Master Serial Mode using Xilinx® Platform Flash PROM
    - Master SPI Mode using Commodity SPI Serial Flash PROM
    - Master BPI Mode using Commodity Parallel NOR Flash PROM
    - Slave Parallel (SelectMAP) using a Processor
    - Slave Serial using a Processor
    - JTAG Mode
  - ISE iMPACT Programming Examples
  - MultiBoot Reconfiguration

© Copyright 2005–2012 Xilinx, Inc. XILINX, the Xilinx logo, Virtex, Spartan, ISE, Artix, Kintex, Zynq, Vivado, and other designated brands included herein are trademarks of Xilinx in the United States and other countries. PCI and PCI-X are trademarks of PCI-SIG and used under license. All other trademarks are the property of their respective owners.

Spartan-3E FPGAs provide additional input flexibility by allowing I/O standards to be mixed in different banks. For a particular V<sub>CCO</sub> voltage, Table 6 and Table 7 list all of the

IOSTANDARDs that can be combined and if the IOSTANDARD is supported as an input only or can be used for both inputs and outputs.

#### Table 6: Single-Ended IOSTANDARD Bank Compatibility

|                            |                  | v <sub>cco</sub> s | upply/Comp       | Input Requirements |                  |                    |                                                    |
|----------------------------|------------------|--------------------|------------------|--------------------|------------------|--------------------|----------------------------------------------------|
| Single-Ended<br>IOSTANDARD | 1.2V             | 1.5V               | 1.8V             | 2.5V               | 3.3V             | V <sub>REF</sub>   | Board<br>Termination<br>Voltage (V <sub>TT</sub> ) |
| LVTTL                      | -                | -                  | -                | -                  | Input/<br>Output | N/R <sup>(1)</sup> | N/R                                                |
| LVCMOS33                   | -                | -                  | -                | -                  | Input/<br>Output | N/R                | N/R                                                |
| LVCMOS25                   | -                | -                  | -                | Input/<br>Output   | Input            | N/R                | N/R                                                |
| LVCMOS18                   | -                | -                  | Input/<br>Output | Input              | Input            | N/R                | N/R                                                |
| LVCMOS15                   | -                | Input/<br>Output   | Input            | Input              | Input            | N/R                | N/R                                                |
| LVCMOS12                   | Input/<br>Output | Input              | Input            | Input              | Input            | N/R                | N/R                                                |
| PCI33_3                    | -                | -                  | -                | -                  | Input/<br>Output | N/R                | N/R                                                |
| PCI66_3                    | -                | -                  | -                | -                  | Input/<br>Output | N/R                | N/R                                                |
| HSTL_I_18                  | -                | -                  | Input/<br>Output | Input              | Input            | 0.9                | 0.9                                                |
| HSTL_III_18                | -                | -                  | Input/<br>Output | Input              | Input            | 1.1                | 1.8                                                |
| SSTL18_I                   | -                | -                  | Input/<br>Output | Input              | Input            | 0.9                | 0.9                                                |
| SSTL2_I                    | -                | -                  | -                | Input/<br>Output   | Input            | 1.25               | 1.25                                               |

#### Notes:

1. N/R - Not required for input operation.

# Configurable Logic Block (CLB) and Slice Resources

For additional information, refer to the "Using Configurable Logic Blocks (CLBs)" chapter in <u>UG331</u>.

# **CLB** Overview

The Configurable Logic Blocks (CLBs) constitute the main logic resource for implementing synchronous as well as combinatorial circuits. Each CLB contains four slices, and each slice contains two Look-Up Tables (LUTs) to implement logic and two dedicated storage elements that can be used as flip-flops or latches. The LUTs can be used as a 16x1 memory (RAM16) or as a 16-bit shift register (SRL16), and additional multiplexers and carry logic simplify wide logic and arithmetic functions. Most general-purpose logic in a design is automatically mapped to the slice resources in the CLBs. Each CLB is identical, and the Spartan-3E family CLB structure is identical to that for the Spartan-3 family.

# **CLB** Array

The CLBs are arranged in a regular array of rows and columns as shown in Figure 14.

Each density varies by the number of rows and columns of CLBs (see Table 9).



Figure 14: CLB Locations

| Device    | CLB<br>Rows | CLB<br>Columns | CLB<br>Total <sup>(1)</sup> | Slices | LUTs /<br>Flip-Flops | Equivalent<br>Logic Cells | RAM16 /<br>SRL16 | Distributed<br>RAM Bits |
|-----------|-------------|----------------|-----------------------------|--------|----------------------|---------------------------|------------------|-------------------------|
| XC3S100E  | 22          | 16             | 240                         | 960    | 1,920                | 2,160                     | 960              | 15,360                  |
| XC3S250E  | 34          | 26             | 612                         | 2,448  | 4,896                | 5,508                     | 2,448            | 39,168                  |
| XC3S500E  | 46          | 34             | 1,164                       | 4,656  | 9,312                | 10,476                    | 4,656            | 74,496                  |
| XC3S1200E | 60          | 46             | 2,168                       | 8,672  | 17,344               | 19,512                    | 8,672            | 138,752                 |
| XC3S1600E | 76          | 58             | 3,688                       | 14,752 | 29,504               | 33,192                    | 14,752           | 236,032                 |

# Table 9: Spartan-3E CLB Resources

#### Notes:

1. The number of CLBs is less than the multiple of the rows and columns because the block RAM/multiplier blocks and the DCMs are embedded in the array (see Figure 1 in Module 1).

# Slices

Each CLB comprises four interconnected slices, as shown in Figure 16. These slices are grouped in pairs. Each pair is organized as a column with an independent carry chain. The left pair supports both logic and memory functions and its slices are called SLICEM. The right pair supports logic only and its slices are called SLICEL. Therefore half the LUTs support both logic and memory (including both RAM16 and SRL16 shift registers) while half support logic only, and the two types alternate throughout the array columns. The SLICEL reduces the size of the CLB and lowers the cost of the device, and can also provide a performance advantage over the SLICEM.



#### Notes:

- 1. Options to invert signal polarity as well as other options that enable lines for various functions are not shown.
- 2. The index i can be 6, 7, or 8, depending on the slice. The upper SLICEL has an F8MUX, and the upper SLICEM has an F7MUX. The lower SLICEL and SLICEM both have an F6MUX.

# Figure 15: Simplified Diagram of the Left-Hand SLICEM

initialized distributed RAM contents are not disturbed during the configuration process.

The distributed RAM is useful for smaller amounts of memory. Larger memory requirements can use the dedicated 18Kbit RAM blocks (see Block RAM).

# **Shift Registers**

For additional information, refer to the "Using Look-Up Tables as Shift Registers (SRL16)" chapter in UG331.

It is possible to program each SLICEM LUT as a 16-bit shift register (see Figure 28). Used in this way, each LUT can delay serial data anywhere from 1 to 16 clock cycles without using any of the dedicated flip-flops. The resulting programmable delays can be used to balance the timing of data pipelines.

The SLICEM LUTs cascade from the G-LUT to the F-LUT through the DIFMUX (see Figure 15). SHIFTIN and SHIFTOUT lines cascade a SLICEM to the SLICEM below to form larger shift registers. The four SLICEM LUTs of a single CLB can be combined to produce delays up to 64 clock cycles. It is also possible to combine shift registers across more than one CLB.



Figure 28: Logic Cell SRL16 Structure

Each shift register provides a shift output MC15 for the last bit in each LUT, in addition to providing addressable access to any bit in the shift register through the normal D output. The address inputs A[3:0] are the same as the distributed RAM address lines, which come from the LUT inputs F[4:1] or G[4:1]. At the end of the shift register, the CLB flip-flop can be used to provide one more shift delay for the addressable bit.

The shift register element is known as the SRL16 (Shift Register LUT 16-bit), with a 'C' added to signify a cascade ability (Q15 output) and 'E' to indicate a Clock Enable. See Figure 29 for an example of the SRLC16E component.



# Figure 29: SRL16 Shift Register Component with Cascade and Clock Enable

The functionality of the shift register is shown in Table 20. The SRL16 shifts on the rising edge of the clock input when the Clock Enable control is High. This shift register cannot be initialized either during configuration or during operation except by shifting data into it. The clock enable and clock inputs are shared between the two LUTs in a SLICEM. The clock enable input is automatically kept active if unused.

|    | Inp        | uts |   | Outputs |       |  |  |
|----|------------|-----|---|---------|-------|--|--|
| Am | CLK        | CE  | D | Q       | Q15   |  |  |
| Am | Х          | 0   | Х | Q[Am]   | Q[15] |  |  |
| Am | $\uparrow$ | 1   | D | Q[Am-1] | Q[15] |  |  |

Notes:

1. m = 0, 1, 2, 3.

| Pin Name | FPGA Direction                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | During Configuration                               | After Configuration                                                                                                                                                    |
|----------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DONE     | Open-drain<br>bidirectional I/O | <b>FPGA Configuration Done</b> . Low during configuration. Goes High when FPGA successfully completes configuration. Requires external $330 \Omega$ pull-up resistor to 2.5V.                                                                                                                                                                                                                                                                                                                                    | Low indicates that the FPGA is not yet configured. | Pulled High via external<br>pull-up. When High,<br>indicates that the FPGA is<br>successfully configured.                                                              |
| PROG_B   | Input                           | <b>Program FPGA</b> . Active Low. When<br>asserted Low for 500 ns or longer,<br>forces the FPGA to restart its<br>configuration process by clearing<br>configuration memory and resetting<br>the DONE and INIT_B pins once<br>PROG_B returns High.<br>Recommend external 4.7 kΩ<br>pull-up resistor to 2.5V. Internal<br>pull-up value may be weaker (see<br>Table 78). If driving externally with a<br>3.3V output, use an open-drain or<br>open-collector driver or use a<br>current limiting series resistor. | Must be High to allow configuration to start.      | Drive PROG_B Low and<br>release to reprogram<br>FPGA. Hold PROG_B to<br>force FPGA I/O pins into<br>Hi-Z, allowing direct<br>programming access to<br>Flash PROM pins. |

#### Table 59: Byte-Wide Peripheral Interface (BPI) Connections (Cont'd)

# **Voltage Compatibility**

V The FPGA's parallel Flash interface signals are within I/O Banks 1 and 2. The majority of parallel Flash PROMs use a single 3.3V supply voltage. Consequently, in most cases, the FPGA's VCCO\_1 and VCCO\_2 supply voltages must also be 3.3V to match the parallel Flash PROM. There are some 1.8V parallel Flash PROMs available and the FPGA interfaces with these devices if the VCCO\_1 and VCCO\_2 supplies are also 1.8V.

# Power-On Precautions if PROM Supply is Last in Sequence

Like SPI Flash PROMs, parallel Flash PROMs typically require some amount of internal initialization time when the supply voltage reaches its minimum value.

The PROM supply voltage also connects to the FPGA's VCCO\_2 supply input. In many systems, the PROM supply feeding the FPGA's VCCO\_2 input is valid before the FPGA's other V<sub>CCINT</sub> and V<sub>CCAUX</sub> supplies, and consequently, there is no issue. However, if the PROM supply is last in the sequence, a potential race occurs between the FPGA and the parallel Flash PROM. See

Power-On Precautions if 3.3V Supply is Last in Sequence for a similar description of the issue for SPI Flash PROMs.

# **Supported Parallel NOR Flash PROM Densities**

Table 60 indicates the smallest usable parallel Flash PROMto program a single Spartan-3E FPGA. Parallel Flashdensity is specified in bits but addressed as bytes. TheFPGA presents up to 24 address lines during configurationbut not all are required for single FPGA applications.Table 60 shows the minimum required number of addresslines between the FPGA and parallel Flash PROM. Theactual number of address line required depends on thedensity of the attached parallel Flash PROM.

A multiple-FPGA daisy-chained application requires a parallel Flash PROM large enough to contain the sum of the FPGA file sizes. An application can also use a larger-density parallel Flash PROM to hold additional data beyond just FPGA configuration data. For example, the parallel Flash PROM can also contain the application code for a MicroBlaze RISC processor core implemented within the Spartan-3E FPGA. After configuration, the MicroBlaze processor can execute directly from external Flash or can copy the code to other, faster system memory before executing the code.

#### Table 60: Number of Bits to Program a Spartan-3E FPGA and Smallest Parallel Flash PROM

| Spartan-3E FPGA | Uncompressed<br>File Sizes (bits) | Smallest Usable<br>Parallel Flash PROM | Minimum Required<br>Address Lines |
|-----------------|-----------------------------------|----------------------------------------|-----------------------------------|
| XC3S100E        | 581,344                           | 1 Mbit                                 | A[16:0]                           |
| XC3S250E        | 1,353,728                         | 2 Mbit                                 | A[17:0]                           |
| XC3S500E        | 2,270,208                         | 4 Mbit                                 | A[18:0]                           |
| XC3S1200E       | 3,841,184                         | 4 Mbit                                 | A[18:0]                           |
| XC3S1600E       | 5,969,696                         | 8 Mbit                                 | A[19:0]                           |

| Pin Name | FPGA Direction                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                    | During Configuration                                                                                      | After Configuration                                                                                    |
|----------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|
| INIT_B   | Open-drain<br>bidirectional I/O | <b>Initialization Indicator</b> . Active Low.<br>Goes Low at the start of<br>configuration during the Initialization<br>memory clearing process. Released<br>at the end of memory clearing, when<br>mode select pins are sampled. In<br>daisy-chain applications, this signal<br>requires an external 4.7 k $\Omega$ pull-up<br>resistor to VCCO_2.                                                                                            | Active during configuration. If<br>CRC error detected during<br>configuration, FPGA drives<br>INIT_B Low. | User I/O. If unused in the<br>application, drive INIT_B<br>High.                                       |
| DONE     | Open-drain<br>bidirectional I/O | <b>FPGA Configuration Done</b> . Low during configuration. Goes High when FPGA successfully completes configuration. Requires external 330 $\Omega$ pull-up resistor to 2.5V.                                                                                                                                                                                                                                                                  | Low indicates that the FPGA is not yet configured.                                                        | Pulled High via external<br>pull-up. When High,<br>indicates that the FPGA<br>successfully configured. |
| PROG_B   | Input                           | <b>Program FPGA</b> . Active Low. When asserted Low for 500 ns or longer, forces the FPGA to restart its configuration process by clearing the DONE and INIT_B pins once PROG_B returns High. Recommend external 4.7 k $\Omega$ pull-up resistor to 2.5V. Internal pull-up value may be weaker (see Table 78). If driving externally with a 3.3V output, use an open-drain or open-collector driver or use a current limiting series resistor. | Must be High to allow<br>configuration to start.                                                          | Drive PROG_B Low and<br>release to reprogram<br>FPGA.                                                  |

### Table 65: Slave Parallel Mode Connections (Cont'd)

# **Voltage Compatibility**

W Most Slave Parallel interface signals are within the FPGA's I/O Bank 2, supplied by the VCCO\_2 supply input. The VCCO\_2 voltage can be 1.8V, 2.5V, or 3.3V to match the requirements of the external host, ideally 2.5V. Using 1.8V or 3.3V requires additional design considerations as the DONE and PROG\_B pins are powered by the FPGA's 2.5V V<sub>CCAUX</sub> supply. See <u>XAPP453</u>: *The 3.3V Configuration of Spartan-3 FPGAs* for additional information.

# **Daisy-Chaining**

If the application requires multiple FPGAs with different configurations, then configure the FPGAs using a daisy chain. Use Slave Parallel mode (M[2:0] = <1:1:0>) for all FPGAs in the daisy-chain. The schematic in Figure 62 is optimized for FPGA downloading and does not support the SelectMAP read interface. The FPGA's RDWR\_B pin must be Low during configuration.

After the lead FPGA is filled with its configuration data, the lead FPGA enables the next FPGA in the daisy-chain by asserting is chip-select output, CSO\_B.

# Maximum Bitstream Size for Daisy-Chains

The maximum bitstream length supported by Spartan-3E FPGAs in serial daisy-chains is 4,294,967,264 bits (4 Gbits), roughly equivalent to a daisy-chain with 720 XC3S1600E FPGAs. This is a limit only for serial daisy-chains where configuration data is passed via the FPGA's DOUT pin. There is no such limit for JTAG chains.

# **Configuration Sequence**

For additional information including I/O behavior before and during configuration, refer to the "Sequence of Events" chapter in <u>UG332</u>.

The Spartan-3E configuration process is three-stage process that begins after the FPGA powers on (a POR event) or after the PROG\_B input is asserted. Power-On Reset (POR) occurs after the  $V_{CCINT}$ ,  $V_{CCAUX}$ , and the  $V_{CCO}$  Bank 2 supplies reach their respective input threshold levels. After either a POR or PROG\_B event, the three-stage configuration process begins.

- 1. The FPGA clears (initializes) the internal configuration memory.
- 2. Configuration data is loaded into the internal memory.
- 3. The user-application is activated by a start-up process.

Figure 66 is a generalized block diagram of the Spartan-3E configuration logic, showing the interaction of different device inputs and Bitstream Generator (BitGen) options. A flow diagram for the configuration sequence of the Serial and Parallel modes appears in Figure 66. Figure 67 shows the Boundary-Scan or JTAG configuration sequence.

# Initialization

Configuration automatically begins after power-on or after asserting the FPGA PROG\_B pin, unless delayed using the FPGA's INIT\_B pin. The FPGA holds the open-drain INIT\_B signal Low while it clears its internal configuration memory. Externally holding the INIT\_B pin Low forces the configuration sequencer to wait until INIT\_B again goes High.

The FPGA signals when the memory-clearing phase is complete by releasing the open-drain INIT\_B pin, allowing the pin to go High via the external pull-up resistor to VCCO\_2.

# Loading Configuration Data

After initialization, configuration data is written to the FPGA's internal memory. The FPGA holds the Global Set/Reset (GSR) signal active throughout configuration, holding all FPGA flip-flops in a reset state. The FPGA signals when the entire configuration process completes by releasing the DONE pin, allowing it to go High. The FPGA configuration sequence can also be initiated by asserting PROG\_B. Once released, the FPGA begins clearing its internal configuration memory, and progresses through the remainder of the configuration process.

# **E** XILINX.



Figure 66: Generalized Spartan-3E FPGA Configuration Logic Block Diagram

# Table 93: Timing for the IOB Three-State Path

|                                    |                                                                                                                                                              |                                                    |        | Speed |      |       |
|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|--------|-------|------|-------|
| Symbol                             | Description                                                                                                                                                  | Conditions                                         | Device | -5    | -4   | Units |
|                                    |                                                                                                                                                              |                                                    |        | Max   | Max  |       |
| Synchronous Ou                     | utput Enable/Disable Times                                                                                                                                   |                                                    |        |       |      |       |
| Т <sub>ЮСКНZ</sub>                 | Time from the active transition at the OTCLK input<br>of the Three-state Flip-Flop (TFF) to when the<br>Output pin enters the high-impedance state           | LVCMOS25, 12 mA<br>output drive, Fast<br>slew rate | All    | 1.49  | 1.71 | ns    |
| T <sub>IOCKON</sub> <sup>(2)</sup> | Time from the active transition at TFF's OTCLK input to when the Output pin drives valid data                                                                |                                                    | All    | 2.70  | 3.10 | ns    |
| Asynchronous C                     | Output Enable/Disable Times                                                                                                                                  |                                                    |        |       |      |       |
| T <sub>GTS</sub>                   | TS Time from asserting the Global Three State (GTS)<br>input on the STARTUP_SPARTAN3E primitive to<br>when the Output pin enters the high-impedance<br>state |                                                    | All    | 8.52  | 9.79 | ns    |
| Set/Reset Times                    |                                                                                                                                                              |                                                    |        |       |      |       |
| T <sub>IOSRHZ</sub>                | Time from asserting TFF's SR input to when the Output pin enters a high-impedance state                                                                      | LVCMOS25, 12 mA output drive, Fast                 | All    | 2.11  | 2.43 | ns    |
| T <sub>IOSRON</sub> <sup>(2)</sup> | Time from asserting TFF's SR input at TFF to when<br>the Output pin drives valid data                                                                        | siew rate                                          | All    | 3.32  | 3.82 | ns    |

#### Notes:

1. The numbers in this table are tested using the methodology presented in Table 95 and are based on the operating conditions set forth in Table 77 and Table 80.

2. This time requires adjustment whenever a signal standard other than LVCMOS25 with 12 mA drive and Fast slew rate is assigned to the data Output. When this is true, *add* the appropriate Output adjustment from Table 94.

3. For minimum delays use the values reported by the Timing Analyzer.

## Table 94: Output Timing Adjustments for IOB

| Convert Ou<br>LVCMOS25 wit<br>Fast Slew Rat | Add<br>Adjus<br>Bel | Units    |       |       |    |
|---------------------------------------------|---------------------|----------|-------|-------|----|
| Signal Standard (IOSTANDARD)                |                     |          | Speed | Grade |    |
|                                             |                     |          | -5    | -4    |    |
| Single-Ended                                | Standards           | <b>;</b> |       |       |    |
| LVTTL                                       | Slow                | 2 mA     | 5.20  | 5.41  | ns |
|                                             |                     | 4 mA     | 2.32  | 2.41  | ns |
|                                             |                     | 6 mA     | 1.83  | 1.90  | ns |
|                                             |                     | 8 mA     | 0.64  | 0.67  | ns |
|                                             |                     | 12 mA    | 0.68  | 0.70  | ns |
|                                             |                     | 16 mA    | 0.41  | 0.43  | ns |
|                                             | Fast                | 2 mA     | 4.80  | 5.00  | ns |
|                                             |                     | 4 mA     | 1.88  | 1.96  | ns |
|                                             |                     | 6 mA     | 1.39  | 1.45  | ns |
|                                             |                     | 8 mA     | 0.32  | 0.34  | ns |
|                                             |                     | 12 mA    | 0.28  | 0.30  | ns |
|                                             |                     | 16 mA    | 0.28  | 0.30  | ns |
| LVCMOS33                                    | Slow                | 2 mA     | 5.08  | 5.29  | ns |
|                                             |                     | 4 mA     | 1.82  | 1.89  | ns |
|                                             |                     | 6 mA     | 1.00  | 1.04  | ns |
|                                             |                     | 8 mA     | 0.66  | 0.69  | ns |
|                                             |                     | 12 mA    | 0.40  | 0.42  | ns |
|                                             |                     | 16 mA    | 0.41  | 0.43  | ns |
|                                             | Fast                | 2 mA     | 4.68  | 4.87  | ns |
|                                             |                     | 4 mA     | 1.46  | 1.52  | ns |
|                                             |                     | 6 mA     | 0.38  | 0.39  | ns |
|                                             |                     | 8 mA     | 0.33  | 0.34  | ns |
|                                             |                     | 12 mA    | 0.28  | 0.30  | ns |
|                                             |                     | 16 mA    | 0.28  | 0.30  | ns |
| LVCMOS25                                    | Slow                | 2 mA     | 4.04  | 4.21  | ns |
|                                             |                     | 4 mA     | 2.17  | 2.26  | ns |
|                                             |                     | 6 mA     | 1.46  | 1.52  | ns |
|                                             |                     | 8 mA     | 1.04  | 1.08  | ns |
|                                             |                     | 12 mA    | 0.65  | 0.68  | ns |
|                                             | Fast                | 2 mA     | 3.53  | 3.67  | ns |
|                                             |                     | 4 mA     | 1.65  | 1.72  | ns |
|                                             |                     | 6 mA     | 0.44  | 0.46  | ns |
|                                             |                     | 8 mA     | 0.20  | 0.21  | ns |
|                                             |                     | 12 mA    | 0     | 0     | ns |

# Table 94: Output Timing Adjustments for IOB (Cont'd)

| Convert Ou<br>LVCMOS25 wit | Add<br>Adjus<br>Bel | the<br>tment<br>low | Units |             |    |
|----------------------------|---------------------|---------------------|-------|-------------|----|
| Signal Standa              | rd (IOSTA           | NDARD)              | Speed | Speed Grade |    |
| •                          | •                   |                     | -5    | -4          |    |
| LVCMOS18                   | Slow                | 2 mA                | 5.03  | 5.24        | ns |
|                            |                     | 4 mA                | 3.08  | 3.21        | ns |
|                            |                     | 6 mA                | 2.39  | 2.49        | ns |
|                            |                     | 8 mA                | 1.83  | 1.90        | ns |
|                            | Fast                | 2 mA                | 3.98  | 4.15        | ns |
|                            |                     | 4 mA                | 2.04  | 2.13        | ns |
|                            |                     | 6 mA                | 1.09  | 1.14        | ns |
|                            |                     | 8 mA                | 0.72  | 0.75        | ns |
| LVCMOS15                   | Slow                | 2 mA                | 4.49  | 4.68        | ns |
|                            |                     | 4 mA                | 3.81  | 3.97        | ns |
|                            |                     | 6 mA                | 2.99  | 3.11        | ns |
|                            | Fast                | 2 mA                | 3.25  | 3.38        | ns |
|                            |                     | 4 mA                | 2.59  | 2.70        | ns |
|                            |                     | 6 mA                | 1.47  | 1.53        | ns |
| LVCMOS12                   | Slow                | 2 mA                | 6.36  | 6.63        | ns |
|                            | Fast                | 2 mA                | 4.26  | 4.44        | ns |
| HSTL_I_18                  |                     |                     | 0.33  | 0.34        | ns |
| HSTL_III_18                |                     |                     | 0.53  | 0.55        | ns |
| PCI33_3                    |                     |                     | 0.44  | 0.46        | ns |
| PCI66_3                    |                     |                     | 0.44  | 0.46        | ns |
| SSTL18_I                   |                     |                     | 0.24  | 0.25        | ns |
| SSTL2_I                    |                     |                     | -0.20 | -0.20       | ns |
| <b>Differential Sta</b>    | ndards              |                     |       |             |    |
| LVDS_25                    |                     |                     | -0.55 | -0.55       | ns |
| BLVDS_25                   |                     |                     | 0.04  | 0.04        | ns |
| MINI_LVDS_25               |                     | -0.56               | -0.56 | ns          |    |
| LVPECL_25                  |                     |                     | Input | Only        | ns |
| RSDS_25                    | -0.48               | -0.48               | ns    |             |    |
| DIFF_HSTL_I_1              | 18                  |                     | 0.42  | 0.42        | ns |
| DIFF_HSTL_III_             | _18                 |                     | 0.53  | 0.55        | ns |
| DIFF_SSTL18_               | I                   |                     | 0.40  | 0.40        | ns |
| DIFF_SSTL2_I               |                     |                     | 0.44  | 0.44        | ns |

#### Notes:

- 1. The numbers in this table are tested using the methodology presented in Table 95 and are based on the operating conditions set forth in Table 77, Table 80, and Table 82.
- 2. These adjustments are used to convert output- and three-state-path times originally specified for the LVCMOS25 standard with 12 mA drive and Fast slew rate to times that correspond to other signal standards. Do not adjust times that measure when outputs go into a high-impedance state.

# Master Serial and Slave Serial Mode Timing



| Fiaure 74: | Waveforms | for Master | Serial and | Slave \$ | Serial C | onfiguration |
|------------|-----------|------------|------------|----------|----------|--------------|
|            |           |            |            |          |          |              |

| Symbol                                                                 | Deceri                                                                                           | Slave/                     | All Speed Grades |               | Unite               |       |
|------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|----------------------------|------------------|---------------|---------------------|-------|
| Symbol                                                                 | The Description                                                                                  |                            | Master           | Min           | Max                 | Units |
| Clock-to-O                                                             | utput Times                                                                                      |                            |                  |               |                     |       |
| T <sub>CCO</sub>                                                       | The time from the falling transition on th DOUT pin                                              | Both                       | 1.5              | 10.0          | ns                  |       |
| Setup Time                                                             | S                                                                                                |                            |                  |               |                     |       |
| T <sub>DCC</sub>                                                       | The time from the setup of data at the CCLK pin                                                  | Both                       | 11.0             | -             | ns                  |       |
| Hold Times                                                             |                                                                                                  |                            |                  |               |                     |       |
| T <sub>CCD</sub>                                                       | The time from the active edge of the CCLK pin to the point when data is last held at the DIN pin |                            |                  | 0             | -                   | ns    |
| Clock Timir                                                            | ng                                                                                               |                            |                  |               |                     | •     |
| T <sub>CCH</sub>                                                       | High pulse width at the CCLK input pir                                                           | n                          | Master           | See Table 114 |                     |       |
|                                                                        |                                                                                                  |                            | Slave            | See Table 115 |                     |       |
| T <sub>CCL</sub>                                                       | Low pulse width at the CCLK input pin                                                            |                            |                  | See Table 114 |                     |       |
|                                                                        |                                                                                                  |                            |                  | See Table 115 |                     |       |
| F <sub>CCSER</sub> Frequency of the clock signal at the CCLK input pin |                                                                                                  | No bitstream compression   | Slave            | 0             | 66 <mark>(2)</mark> | MHz   |
|                                                                        |                                                                                                  | With bitstream compression |                  | 0             | 20                  | MHz   |

# Table 116: Timing for the Master Serial and Slave Serial Configuration Modes

#### Notes:

- 1. The numbers in this table are based on the operating conditions set forth in Table 77.
- 2. For serial configuration with a daisy-chain of multiple FPGAs, the maximum limit is 25 MHz.

# Table 133: CP132 Package Pinout (Cont'd)

| Bank   | XC3S100E<br>Pin Name | XC3S250E<br>XC3S500E<br>Pin Name | CP132 Ball | Туре   |
|--------|----------------------|----------------------------------|------------|--------|
| GND    | GND                  | GND                              | C10        | GND    |
| GND    | GND                  | GND                              | E3         | GND    |
| GND    | GND                  | GND                              | E14        | GND    |
| GND    | GND                  | GND                              | G2         | GND    |
| GND    | GND                  | GND                              | H14        | GND    |
| GND    | GND                  | GND                              | J1         | GND    |
| GND    | GND                  | GND                              | K12        | GND    |
| GND    | GND                  | GND                              | МЗ         | GND    |
| GND    | GND                  | GND                              | M7         | GND    |
| GND    | GND                  | GND                              | P5         | GND    |
| GND    | N.C. (GND)           | GND                              | P10        | GND    |
| GND    | GND                  | GND                              | P14        | GND    |
| VCCAUX | DONE                 | DONE                             | P13        | CONFIG |
| VCCAUX | PROG_B               | PROG_B                           | A1         | CONFIG |
| VCCAUX | ТСК                  | тск                              | B13        | JTAG   |
| VCCAUX | TDI                  | TDI                              | A2         | JTAG   |
| VCCAUX | TDO                  | TDO                              | A14        | JTAG   |
| VCCAUX | TMS                  | TMS                              | B14        | JTAG   |
| VCCAUX | VCCAUX               | VCCAUX                           | A5         | VCCAUX |
| VCCAUX | VCCAUX               | VCCAUX                           | E12        | VCCAUX |
| VCCAUX | VCCAUX               | VCCAUX                           | K1         | VCCAUX |
| VCCAUX | VCCAUX               | VCCAUX                           | P9         | VCCAUX |
| VCCINT | VCCINT               | VCCINT                           | A11        | VCCINT |
| VCCINT | VCCINT               | VCCINT                           | D3         | VCCINT |
| VCCINT | N.C. (VCCINT)        | VCCINT                           | D14        | VCCINT |
| VCCINT | N.C. (VCCINT)        | VCCINT                           | K2         | VCCINT |
| VCCINT | VCCINT               | VCCINT                           | L12        | VCCINT |
| VCCINT | VCCINT               | VCCINT                           | P2         | VCCINT |

# TQ144: 144-lead Thin Quad Flat Package

The XC3S100E and the XC3S250E FPGAs are available in the 144-lead thin quad flat package, TQ144. Both devices share a common footprint for this package as shown in Table 137 and Figure 82.

Table 137 lists all the package pins. They are sorted by bank number and then by pin name of the largest device. Pins that form a differential I/O pair appear together in the table. The table also shows the pin number for each pin and the pin type, as defined earlier. The TQ144 package only supports 20 address output pins in the Byte-wide Peripheral Interface (BPI) configuration mode. In larger packages, there are 24 BPI address outputs.

An electronic version of this package pinout table and footprint diagram is available for download from the Xilinx web site at:

http://www.xilinx.com/support/documentation/data\_sheets /s3e\_pin.zip

# **Pinout Table**

Table 137: TQ144 Package Pinout

| Bank | XC3S100E Pin Name | XC3S250E Pin Name | TQ144 Pin | Туре  |
|------|-------------------|-------------------|-----------|-------|
| 0    | 10                | IO                | P132      | I/O   |
| 0    | IO/VREF_0         | IO/VREF_0         | P124      | VREF  |
| 0    | IO_L01N_0         | IO_L01N_0         | P113      | I/O   |
| 0    | IO_L01P_0         | IO_L01P_0         | P112      | I/O   |
| 0    | IO_L02N_0         | IO_L02N_0         | P117      | I/O   |
| 0    | IO_L02P_0         | IO_L02P_0         | P116      | I/O   |
| 0    | IO_L04N_0/GCLK5   | IO_L04N_0/GCLK5   | P123      | GCLK  |
| 0    | IO_L04P_0/GCLK4   | IO_L04P_0/GCLK4   | P122      | GCLK  |
| 0    | IO_L05N_0/GCLK7   | IO_L05N_0/GCLK7   | P126      | GCLK  |
| 0    | IO_L05P_0/GCLK6   | IO_L05P_0/GCLK6   | P125      | GCLK  |
| 0    | IO_L07N_0/GCLK11  | IO_L07N_0/GCLK11  | P131      | GCLK  |
| 0    | IO_L07P_0/GCLK10  | IO_L07P_0/GCLK10  | P130      | GCLK  |
| 0    | IO_L08N_0/VREF_0  | IO_L08N_0/VREF_0  | P135      | VREF  |
| 0    | IO_L08P_0         | IO_L08P_0         | P134      | I/O   |
| 0    | IO_L09N_0         | IO_L09N_0         | P140      | I/O   |
| 0    | IO_L09P_0         | IO_L09P_0         | P139      | I/O   |
| 0    | IO_L10N_0/HSWAP   | IO_L10N_0/HSWAP   | P143      | DUAL  |
| 0    | IO_L10P_0         | IO_L10P_0         | P142      | I/O   |
| 0    | IP                | IP                | P111      | INPUT |
| 0    | IP                | IP                | P114      | INPUT |
| 0    | IP                | IP                | P136      | INPUT |
| 0    | IP                | IP                | P141      | INPUT |
| 0    | IP_L03N_0         | IP_L03N_0         | P120      | INPUT |
| 0    | IP_L03P_0         | IP_L03P_0         | P119      | INPUT |
| 0    | IP_L06N_0/GCLK9   | IP_L06N_0/GCLK9   | P129      | GCLK  |
| 0    | IP_L06P_0/GCLK8   | IP_L06P_0/GCLK8   | P128      | GCLK  |
| 0    | VCCO_0            | VCCO_0            | P121      | VCCO  |
| 0    | VCCO_0            | VCCO_0            | P138      | VCCO  |
| 1    | IO/A0             | IO/A0             | P98       | DUAL  |
| 1    | IO/VREF_1         | IO/VREF_1         | P83       | VREF  |
| 1    | IO_L01N_1/A15     | IO_L01N_1/A15     | P75       | DUAL  |
| 1    | IO_L01P_1/A16     | IO_L01P_1/A16     | P74       | DUAL  |
| 1    | IO_L02N_1/A13     | IO_L02N_1/A13     | P77       | DUAL  |

# Table 141: PQ208 Package Pinout (Cont'd)

| Bank | XC3S250E<br>XC3S500E<br>Pin Name | PQ208<br>Pin | Туре      |
|------|----------------------------------|--------------|-----------|
| 1    | IO_L15N_1/LDC0                   | P151         | DUAL      |
| 1    | IO_L15P_1/HDC                    | P150         | DUAL      |
| 1    | IO_L16N_1/LDC2                   | P153         | DUAL      |
| 1    | IO_L16P_1/LDC1                   | P152         | DUAL      |
| 1    | IP                               | P110         | INPUT     |
| 1    | IP                               | P118         | INPUT     |
| 1    | IP                               | P124         | INPUT     |
| 1    | IP                               | P130         | INPUT     |
| 1    | IP                               | P142         | INPUT     |
| 1    | IP                               | P148         | INPUT     |
| 1    | IP                               | P154         | INPUT     |
| 1    | IP/VREF_1                        | P136         | VREF      |
| 1    | VCCO_1                           | P114         | VCCO      |
| 1    | VCCO_1                           | P125         | VCCO      |
| 1    | VCCO_1                           | P143         | VCCO      |
| 2    | IO/D5                            | P76          | DUAL      |
| 2    | IO/M1                            | P84          | DUAL      |
| 2    | IO/VREF_2                        | P98          | VREF      |
| 2    | IO_L01N_2/INIT_B                 | P56          | DUAL      |
| 2    | IO_L01P_2/CSO_B                  | P55          | DUAL      |
| 2    | IO_L03N_2/MOSI/CSI_B             | P61          | DUAL      |
| 2    | IO_L03P_2/DOUT/BUSY              | P60          | DUAL      |
| 2    | IO_L04N_2                        | P63          | I/O       |
| 2    | IO_L04P_2                        | P62          | I/O       |
| 2    | IO_L05N_2                        | P65          | I/O       |
| 2    | IO_L05P_2                        | P64          | I/O       |
| 2    | IO_L06N_2                        | P69          | I/O       |
| 2    | IO_L06P_2                        | P68          | I/O       |
| 2    | IO_L08N_2/D6/GCLK13              | P75          | DUAL/GCLK |
| 2    | IO_L08P_2/D7/GCLK12              | P74          | DUAL/GCLK |
| 2    | IO_L09N_2/D3/GCLK15              | P78          | DUAL/GCLK |
| 2    | IO_L09P_2/D4/GCLK14              | P77          | DUAL/GCLK |
| 2    | IO_L11N_2/D1/GCLK3               | P83          | DUAL/GCLK |
| 2    | IO_L11P_2/D2/GCLK2               | P82          | DUAL/GCLK |
| 2    | IO_L12N_2/DIN/D0                 | P87          | DUAL      |
| 2    | IO_L12P_2/M0                     | P86          | DUAL      |
| 2    | IO_L13N_2                        | P90          | I/O       |
| 2    | IO_L13P_2                        | P89          | I/O       |
| 2    | IO_L14N_2/A22                    | P94          | DUAL      |
| 2    | IO_L14P_2/A23                    | P93          | DUAL      |
| 2    | IO_L15N_2/A20                    | P97          | DUAL      |
| 2    | IO_L15P_2/A21                    | P96          | DUAL      |
| 2    | IO_L16N_2/VS1/A18                | P100         | DUAL      |

# Table 141: PQ208 Package Pinout (Cont'd)

| Bank | XC3S250E PQ208<br>XC3S500E Pin |      | Туре      |
|------|--------------------------------|------|-----------|
| 2    |                                | P99  | DUAI      |
| 2    |                                | P103 | DUAL      |
| 2    | IO_L17P_2/VS0/A17              | P102 |           |
| 2    | IP                             | P54  | INPLIT    |
| 2    | IP                             | P91  |           |
| 2    | IP                             | P101 |           |
| 2    |                                | P58  |           |
| 2    | IP 1 02P 2                     | P57  |           |
| 2    | IP 107N 2//BEE 2               | P72  | VBEE      |
| 2    | IP 107P 2                      | P71  | INPLIT    |
| 2    | IP_L10N_2/M2/GCLK1             | P81  |           |
| 2    | IP L10P 2/RDWR B/              | P80  | DUAL/GCLK |
|      | GCLK0                          |      |           |
| 2    | VCCO_2                         | P59  | VCCO      |
| 2    | VCCO_2                         | P73  | VCCO      |
| 2    | VCCO_2                         | P88  | VCCO      |
| 3    | IO/VREF_3                      | P45  | VREF      |
| 3    | IO_L01N_3                      | P3   | I/O       |
| 3    | IO_L01P_3                      | P2   | I/O       |
| 3    | IO_L02N_3/VREF_3               | P5   | VREF      |
| 3    | IO_L02P_3                      | P4   | I/O       |
| 3    | IO_L03N_3                      | P9   | I/O       |
| 3    | IO_L03P_3                      | P8   | I/O       |
| 3    | IO_L04N_3                      | P12  | I/O       |
| 3    | IO_L04P_3                      | P11  | I/O       |
| 3    | IO_L05N_3                      | P16  | I/O       |
| 3    | IO_L05P_3                      | P15  | I/O       |
| 3    | IO_L06N_3                      | P19  | I/O       |
| 3    | IO_L06P_3                      | P18  | I/O       |
| 3    | IO_L07N_3/LHCLK1               | P23  | LHCLK     |
| 3    | IO_L07P_3/LHCLK0               | P22  | LHCLK     |
| 3    | IO_L08N_3/LHCLK3               | P25  | LHCLK     |
| 3    | IO_L08P_3/LHCLK2               | P24  | LHCLK     |
| 3    | IO_L09N_3/LHCLK5               | P29  | LHCLK     |
| 3    | IO_L09P_3/LHCLK4               | P28  | LHCLK     |
| 3    | IO_L10N_3/LHCLK7               | P31  | LHCLK     |
| 3    | IO_L10P_3/LHCLK6               | P30  | LHCLK     |
| 3    | IO_L11N_3                      | P34  | I/O       |
| 3    | IO_L11P_3                      | P33  | I/O       |
| 3    | IO_L12N_3                      | P36  | I/O       |
| 3    | IO_L12P_3                      | P35  | I/O       |
| 3    | IO_L13N_3                      | P40  | I/O       |
| 3    | IO_L13P_3                      | P39  | I/O       |
| 3    | IO_L14N_3                      | P42  | I/O       |

# Table 148: FG320 Package Pinout (Cont'd)

| Bank | XC3S500E Pin Name          | XC3S1200E Pin Name         | XC3S1600E Pin Name         | FG320<br>Ball | Туре                                   |
|------|----------------------------|----------------------------|----------------------------|---------------|----------------------------------------|
| 2    | IO_L20P_2                  | IO_L20P_2                  | IO_L20P_2                  | T12           | I/O                                    |
| 2    | N.C. (�)                   | IO_L21N_2                  | IO_L21N_2                  | P12           | 500E: N.C.<br>1200E: I/O<br>1600E: I/O |
| 2    | N.C. (◆)                   | IO_L21P_2                  | IO_L21P_2                  | N12           | 500E: N.C.<br>1200E: I/O<br>1600E: I/O |
| 2    | IO_L22N_2/A22              | IO_L22N_2/A22              | IO_L22N_2/A22              | R13           | DUAL                                   |
| 2    | IO_L22P_2/A23              | IO_L22P_2/A23              | IO_L22P_2/A23              | P13           | DUAL                                   |
| 2    | IO_L24N_2/A20              | IO_L24N_2/A20              | IO_L24N_2/A20              | R14           | DUAL                                   |
| 2    | IO_L24P_2/A21              | IO_L24P_2/A21              | IO_L24P_2/A21              | T14           | DUAL                                   |
| 2    | IO_L25N_2/VS1/A18          | IO_L25N_2/VS1/A18          | IO_L25N_2/VS1/A18          | U15           | DUAL                                   |
| 2    | IO_L25P_2/VS2/A19          | IO_L25P_2/VS2/A19          | IO_L25P_2/VS2/A19          | V15           | DUAL                                   |
| 2    | IO_L26N_2/CCLK             | IO_L26N_2/CCLK             | IO_L26N_2/CCLK             | U16           | DUAL                                   |
| 2    | IO_L26P_2/VS0/A17          | IO_L26P_2/VS0/A17          | IO_L26P_2/VS0/A17          | T16           | DUAL                                   |
| 2    | IP                         | IP                         | IP                         | V2            | INPUT                                  |
| 2    | IP                         | IP                         | IP                         | V16           | INPUT                                  |
| 2    | IP_L02N_2                  | IP_L02N_2                  | IP_L02N_2                  | V3            | INPUT                                  |
| 2    | IP_L02P_2                  | IP_L02P_2                  | IP_L02P_2                  | V4            | INPUT                                  |
| 2    | IP_L08N_2                  | IP_L08N_2                  | IP_L08N_2                  | R7            | INPUT                                  |
| 2    | IP_L08P_2                  | IP_L08P_2                  | IP_L08P_2                  | T7            | INPUT                                  |
| 2    | IP_L11N_2/VREF_2           | IP_L11N_2/VREF_2           | IP_L11N_2/VREF_2           | V8            | VREF                                   |
| 2    | IP_L11P_2                  | IP_L11P_2                  | IP_L11P_2                  | U8            | INPUT                                  |
| 2    | IP_L14N_2/M2/GCLK1         | IP_L14N_2/M2/GCLK1         | IP_L14N_2/M2/GCLK1         | T10           | DUAL/GCLK                              |
| 2    | IP_L14P_2/RDWR_B/<br>GCLK0 | IP_L14P_2/RDWR_B/<br>GCLK0 | IP_L14P_2/RDWR_B/<br>GCLK0 | U10           | DUAL/GCLK                              |
| 2    | IP_L17N_2                  | IP_L17N_2                  | IP_L17N_2                  | U11           | INPUT                                  |
| 2    | IP_L17P_2                  | IP_L17P_2                  | IP_L17P_2                  | T11           | INPUT                                  |
| 2    | IP_L23N_2                  | IP_L23N_2                  | IP_L23N_2                  | U14           | INPUT                                  |
| 2    | IP_L23P_2                  | IP_L23P_2                  | IP_L23P_2                  | V14           | INPUT                                  |
| 2    | VCCO_2                     | VCCO_2                     | VCCO_2                     | M8            | VCCO                                   |
| 2    | VCCO_2                     | VCCO_2                     | VCCO_2                     | M11           | VCCO                                   |
| 2    | VCCO_2                     | VCCO_2                     | VCCO_2                     | T6            | VCCO                                   |
| 2    | VCCO_2                     | VCCO_2                     | VCCO_2                     | T13           | VCCO                                   |
| 2    | VCCO_2                     | VCCO_2                     | VCCO_2                     | V10           | VCCO                                   |
| 3    | N.C. (♠)                   | IO                         | 10                         | D4            | 500E: N.C.<br>1200E: I/O<br>1600E: I/O |
| 3    | IO_L01N_3                  | IO_L01N_3                  | IO_L01N_3                  | C2            | I/O                                    |
| 3    | IO_L01P_3                  | IO_L01P_3                  | IO_L01P_3                  | C1            | I/O                                    |
| 3    | IO_L02N_3/VREF_3           | IO_L02N_3/VREF_3           | IO_L02N_3/VREF_3           | D2            | VREF                                   |
| 3    | IO_L02P_3                  | IO_L02P_3                  | IO_L02P_3                  | D1            | I/O                                    |
| 3    | IO_L03N_3                  | IO_L03N_3                  | IO_L03N_3                  | E1            | I/O                                    |
| 3    | IO_L03P_3                  | IO_L03P_3                  | IO_L03P_3                  | E2            | I/O                                    |

# User I/Os by Bank

Table 149 and Table 150 indicate how the available user-I/O pins are distributed between the four I/O banks on the FG320 package.

#### Table 149: User I/Os Per Bank for XC3S500E in the FG320 Package

| Package | I/O Bonk  | Maximum I/O | All Possible I/O Pins by Type |       |      |                     |                    |
|---------|-----------|-------------|-------------------------------|-------|------|---------------------|--------------------|
| Edge    | I/O Ballk |             | I/O                           | INPUT | DUAL | VREF <sup>(1)</sup> | CLK <sup>(2)</sup> |
| Тор     | 0         | 58          | 29                            | 14    | 1    | 6                   | 8                  |
| Right   | 1         | 58          | 22                            | 10    | 21   | 5                   | 0 <sup>(2)</sup>   |
| Bottom  | 2         | 58          | 17                            | 13    | 24   | 4                   | 0 <sup>(2)</sup>   |
| Left    | 3         | 58          | 34                            | 11    | 0    | 5                   | 8                  |
| TOTAL   |           | 232         | 102                           | 48    | 46   | 20                  | 16                 |

#### Notes:

1. Some VREF and CLK pins are on INPUT pins.

2. The eight global clock pins in this bank have optional functionality during configuration and are counted in the DUAL column.

#### Table 150: User I/Os Per Bank for XC3S1200E and XC3S1600E in the FG320 Package

| Package | I/O Bank | Maximum I/O | All Possible I/O Pins by Type |       |      |                     |                    |
|---------|----------|-------------|-------------------------------|-------|------|---------------------|--------------------|
| Edge    |          |             | I/O                           | INPUT | DUAL | VREF <sup>(1)</sup> | CLK <sup>(2)</sup> |
| Тор     | 0        | 61          | 34                            | 12    | 1    | 6                   | 8                  |
| Right   | 1        | 63          | 25                            | 12    | 21   | 5                   | 0 <sup>(2)</sup>   |
| Bottom  | 2        | 63          | 23                            | 11    | 24   | 5                   | 0(2)               |
| Left    | 3        | 63          | 38                            | 12    | 0    | 5                   | 8                  |
| TOTAL   |          | 250         | 120                           | 47    | 46   | 21                  | 16                 |

#### Notes:

1. Some VREF and CLK pins are on INPUT pins.

2. The eight global clock pins in this bank have optional functionality during configuration and are counted in the DUAL column.

### Table 155: User I/Os Per Bank for the XC3S1600E in the FG484 Package

| Package | I/O Bank Maximum I/O |     | All Possible I/O Pins by Type |       |      |                     |                    |
|---------|----------------------|-----|-------------------------------|-------|------|---------------------|--------------------|
| Edge    |                      |     | I/O                           | INPUT | DUAL | VREF <sup>(1)</sup> | CLK <sup>(2)</sup> |
| Тор     | 0                    | 94  | 56                            | 22    | 1    | 7                   | 8                  |
| Right   | 1                    | 94  | 50                            | 16    | 21   | 7                   | 0(2)               |
| Bottom  | 2                    | 94  | 45                            | 18    | 24   | 7                   | 0(2)               |
| Left    | 3                    | 94  | 63                            | 16    | 0    | 7                   | 8                  |
| TOTAL   |                      | 376 | 214                           | 72    | 46   | 28                  | 16                 |

#### Notes:

1. Some VREF and CLK pins are on INPUT pins.

2. The eight global clock pins in this bank have optional functionality during configuration and are counted in the DUAL column.

# **Footprint Migration Differences**

The XC3S1600E FPGA is the only Spartan-3E device offered in the FG484 package.

# **Revision History**

The following table shows the revision history for this document.

| Date     | Version | Revision                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 03/01/05 | 1.0     | Initial Xilinx release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 03/21/05 | 1.1     | Added XC3S250E in the CP132 package to Table 129. Corrected number of differential I/O pairs on CP132. Added pinout and footprint information for the CP132, FG400, and FG484 packages. Removed IRDY and TRDY pins from the VQ100, TQ144, and PQ208 packages.                                                                                                                                                                                                                                                                                                                            |
| 11/23/05 | 2.0     | Corrected title of Table 153. Updated differential pair numbering for some pins in Bank 0 of the FG400 package, affecting Table 152 and Figure 87. Pin functionality and ball assignment were not affected. Added Package Thermal Characteristics section. Added package mass values to Table 125.                                                                                                                                                                                                                                                                                       |
| 03/22/06 | 3.0     | Included I/O pins, not just input-only pins under the VREF description in Table 124. Clarified that some global clock inputs are Input-only pins in Table 124. Added information on the XC3S100E in the CP132 package, affecting Table 129, Table 130, Table 133, Table 134, Table 136, and Figure 81. Ball A12 on the XC3S1600E in the FG320 package a full I/O pin, not an Input-only pin. Corrected the I/O counts for the XC3S1600E in the FG320 package, affecting Table 129, Table 150, Table 151, and Figure 86. Corrected pin type for XC3S1600E balls N14 and N15 in Table 148. |
| 05/19/06 | 3.1     | Minor text edits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 11/09/06 | 3.4     | Added package thermal data for the XC3S100E in the CP132 package to Table 130. Corrected pin migration arrows for balls E17 and F4 between the XC3S500E and XC3S1600E in Table 151. Promoted Module 4 to Production status. Synchronized all modules to v3.4.                                                                                                                                                                                                                                                                                                                            |
| 03/16/07 | 3.5     | Minor formatting changes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 05/29/07 | 3.6     | Corrected 'Lxx' to 'Lxxy' in Table 124. Noted that some GCLK and VREF pins are on INPUT pins in Table 124 and Table 129. Added link before Table 127 to Material Declaration Data Sheets.                                                                                                                                                                                                                                                                                                                                                                                                |
| 04/18/08 | 3.7     | Added XC3S500E VQG100 package. Added Material Declaration Data Sheet links in Table 127. Updated Thermal Characteristics in Table 130. Updated links.                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 08/26/09 | 3.8     | Minor typographical updates.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 10/29/12 | 4.0     | Added Notice of Disclaimer. This product is not recommended for new designs.<br>Updated the XC3S250E-FT256 in Table 129.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

# **Notice of Disclaimer**

THE XILINX HARDWARE FPGA AND CPLD DEVICES REFERRED TO HEREIN ("PRODUCTS") ARE SUBJECT TO THE TERMS AND CONDITIONS OF THE XILINX LIMITED WARRANTY WHICH CAN BE VIEWED AT <a href="http://www.xilinx.com/warranty.htm">http://www.xilinx.com/warranty.htm</a>. THIS LIMITED WARRANTY DOES NOT EXTEND TO ANY USE OF PRODUCTS IN AN APPLICATION OR ENVIRONMENT THAT IS NOT WITHIN THE SPECIFICATIONS STATED IN THE XILINX DATA SHEET. ALL SPECIFICATIONS ARE SUBJECT TO CHANGE WITHOUT NOTICE. PRODUCTS ARE NOT DESIGNED OR INTENDED TO BE FAIL-SAFE OR FOR USE IN ANY APPLICATION REQUIRING FAIL-SAFE PERFORMANCE, SUCH AS LIFE-SUPPORT OR SAFETY DEVICES OR SYSTEMS, OR ANY OTHER APPLICATION THAT INVOKES THE POTENTIAL RISKS OF DEATH, PERSONAL INJURY, OR PROPERTY OR ENVIRONMENTAL DAMAGE ("CRITICAL APPLICATIONS"). USE OF PRODUCTS IN CRITICAL APPLICATIONS IS AT THE SOLE RISK OF CUSTOMER, SUBJECT TO APPLICABLE LAWS AND REGULATIONS.

#### **CRITICAL APPLICATIONS DISCLAIMER**

XILINX PRODUCTS (INCLUDING HARDWARE, SOFTWARE AND/OR IP CORES) ARE NOT DESIGNED OR INTENDED TO BE FAIL-SAFE, OR FOR USE IN ANY APPLICATION REQUIRING FAIL-SAFE PERFORMANCE, SUCH AS IN LIFE-SUPPORT OR SAFETY DEVICES OR SYSTEMS, CLASS III MEDICAL DEVICES, NUCLEAR FACILITIES, APPLICATIONS RELATED TO THE DEPLOYMENT OF AIRBAGS, OR ANY OTHER APPLICATIONS THAT COULD LEAD TO DEATH, PERSONAL INJURY OR SEVERE PROPERTY OR ENVIRONMENTAL DAMAGE (INDIVIDUALLY AND COLLECTIVELY, "CRITICAL APPLICATIONS"). FURTHERMORE, XILINX PRODUCTS ARE NOT DESIGNED OR INTENDED FOR USE IN ANY APPLICATIONS THAT AFFECT CONTROL OF A VEHICLE OR AIRCRAFT, UNLESS THERE IS A FAIL-SAFE OR REDUNDANCY FEATURE (WHICH DOES NOT INCLUDE USE OF SOFTWARE IN THE XILINX DEVICE TO IMPLEMENT THE REDUNDANCY) AND A WARNING SIGNAL UPON FAILURE TO THE OPERATOR. CUSTOMER AGREES, PRIOR TO USING OR DISTRIBUTING ANY SYSTEMS THAT INCORPORATE XILINX PRODUCTS, TO THOROUGHLY TEST THE SAME FOR SAFETY PURPOSES. TO THE MAXIMUM EXTENT PERMITTED BY APPLICABLE LAW, CUSTOMER ASSUMES THE SOLE RISK AND LIABILITY OF ANY USE OF XILINX PRODUCTS IN CRITICAL APPLICATIONS.